返回顶部
首页 > 资讯 > 精选 >Android如何实现带动画柱状图
  • 548
分享到

Android如何实现带动画柱状图

android 2023-05-30 23:05:01 548人浏览 安东尼
摘要

这篇文章主要为大家展示了“Android如何实现带动画柱状图”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Android如何实现带动画柱状图”这篇文章吧。为何要用带动画的柱状图呢?最近,项目中遇

这篇文章主要为大家展示了“Android如何实现带动画柱状图”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Android如何实现带动画柱状图”这篇文章吧。

为何要用带动画的柱状图呢?

最近,项目中遇到一个地方,要用到柱状图。所以这篇文章主要讲怎么搞一个柱子。100行代码,搞定柱状图!

Android如何实现带动画柱状图

圆角,头顶带数字。恩,这样用drawable也可以搞定。但是,这个柱子是有一个动画的,就是进入到界面的时候柱子不断的长高。这样的话,综合考虑还是用自定义View来做比较简便。效果如下图了:

Android如何实现带动画柱状图

完整Demo地址请到我的GitHub下载地址:
https://github.com/lixiaodaoaaa/ColumnAnimViewProject

关于尺寸

控件尺寸直接来自xml中的设置,无需进行onMeasure测量。所以使用getWidth和getHeight获取高度。

关于数据范围

数据如果是一个柱子单独显示,则数据的范围不是很重要,但是柱状图通常是由很多柱子并列显示的,而这些柱子的单位高度都应该是一样的,所以提供设置最大值的范围,最小值就是0.

关于数字的文字大小

由于柱子的宽度就是整个View的宽度,所以数字的宽度不能超过柱子的宽度。因为这个原因,文字的size需要动态计算。意思就是 0和100000这两个数字显示的时候,文字的大小是不一样的。

关于边界值

0,是一个边界值(最小值),当显示0的时候,并不是柱子不显示的,而是显示一个最小高度的。

关于动画

不停的设置值,就会形成动画。意思是先设置数据1,然后紧接着设数据2.3.4.5……一直到最终的显示值,就会有动画效果。但是如果最终数值很大,1,1,1的增加就会很慢,动画时间很长。

完整代码如下:

package com.lixiaodaoaaa.view.pieview;import android.content.Context;import android.graphics.canvas;import android.graphics.Paint;import android.graphics.RectF;import android.support.annotation.Nullable;import android.util.AttributeSet;import android.view.View;import com.gCSSloop.graphics.R;import com.lixiaodaoaaa.uitls.DensityUtils;public class PColumn extends View {  int MAX = 100;//最大  int corner = 40;  int data = 0;//显示的数  int tempData = 0;  int textPadding = 20;  Paint mPaint;  int mColor;  Context mContext;  public PColumn(Context context) {    super(context);    mContext = context;  }  public PColumn(Context context, @Nullable AttributeSet attrs) {    super(context, attrs);    mContext = context;    initPaint();  }  public PColumn(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {    super(context, attrs, defStyleAttr);    mContext = context;    initPaint();  }  private void initPaint() {    mPaint = new Paint();    mPaint.setAntiAlias(true);    mColor = mContext.getResources().getColor(R.color.colorPrimary);    mPaint.setColor(mColor);  }  @Override  public void draw(Canvas canvas) {    super.draw(canvas);    if (data == 0) {      mPaint.setTextSize(getWidth() / 2);      RectF oval3 = new RectF(0, getHeight() - DensityUtils.pxTodip(mContext, 20), getWidth(), getHeight());// 设置个新的长方形      canvas.drawRoundRect(oval3, DensityUtils.pxTodip(mContext, corner), DensityUtils.pxTodip(mContext, corner), mPaint);      canvas.drawText("0",          getWidth() * 0.5f - mPaint.measureText("0") * 0.5f,          getHeight() - DensityUtils.pxTodip(mContext, 20) - 2 * DensityUtils.pxTodip(mContext, textPadding),          mPaint);      return;    }    //防止数值很大的的时候,动画时间过长    int step = data / 100 + 1;    if (tempData < data - step) {      tempData = tempData + step;    } else {      tempData = data;    }    //画圆角矩形    String S = tempData + "";    //一个字和两,三个字的字号相同    if (S.length() < 4) {      mPaint.setTextSize(getWidth() / 2);    } else {      mPaint.setTextSize(getWidth() / (S.length() - 1));    }    float textH = mPaint.ascent() + mPaint.descent();    float MaxH = getHeight() - textH - 2 * DensityUtils.pxTodip(mContext, textPadding);    //圆角矩形的实际高度    float realH = MaxH / MAX * tempData;    RectF oval3 = new RectF(0, getHeight() - realH, getWidth(), getHeight());// 设置个新的长方形    canvas.drawRoundRect(oval3, DensityUtils.pxTodip(mContext, corner), DensityUtils.pxTodip(mContext, corner), mPaint);    //写数字    canvas.drawText(S,        getWidth() * 0.5f - mPaint.measureText(S) * 0.5f,        getHeight() - realH - 2 * DensityUtils.pxTodip(mContext, textPadding),        mPaint);    if (tempData != data) {      postInvalidate();    }  }  public void setData(int data, int MAX) {    this.data = data;    tempData = 0;    this.MAX = MAX;    postInvalidate();  }}
package com.lixiaodaoaaa.graphics;import android.os.Bundle;import android.support.v7.app.AppCompatActivity;import com.GCssloop.graphics.R;import com.lixiaodaoaaa.view.pieview.PColumn;public class MainActivity extends AppCompatActivity {  private PColumn column_one;  private PColumn column_two;  private PColumn column_three;  @Override  protected void onCreate(Bundle savedInstanceState) {    super.onCreate(savedInstanceState);    setContentView(R.layout.activity_main);    initAllViews();  }  private void initAllViews() {    column_one = (PColumn) findViewById(R.id.column_one);    column_two = (PColumn) findViewById(R.id.column_two);    column_three = (PColumn) findViewById(R.id.column_three);    column_one.setData(0, 100);    column_two.setData(30, 100);    column_three.setData(40, 100);  }}

xml配置如下:

<?xml version="1.0" encoding="utf-8"?><LinearLayout  xmlns:android="Http://schemas.android.com/apk/res/android"  xmlns:tools="http://schemas.android.com/tools"  android:layout_width="match_parent"  android:layout_height="match_parent"  android:layout_weight="1"  android:paddingBottom="@dimen/activity_vertical_margin"  android:paddingLeft="@dimen/activity_horizontal_margin"  android:paddingRight="@dimen/activity_horizontal_margin"  android:paddingTop="@dimen/activity_vertical_margin"  tools:context="com.lixiaodaoaaa.graphics.MainActivity">  <View    android:layout_width="0dp"    android:layout_height="match_parent"    android:layout_weight="0.2"/>  <com.lixiaodaoaaa.view.pieview.PColumn    android:id="@+id/column_one"    android:layout_width="0dp"    android:layout_height="match_parent"    android:layout_weight="1"/>  <View    android:layout_width="0dp"    android:layout_height="match_parent"    android:layout_weight="2.4"/>  <com.lixiaodaoaaa.view.pieview.PColumn    android:id="@+id/column_two"    android:layout_width="0dp"    android:layout_height="match_parent"    android:layout_weight="1"/>  <View    android:layout_width="0dp"    android:layout_height="match_parent"    android:layout_weight="2.4"/>  <com.lixiaodaoaaa.view.pieview.PColumn    android:id="@+id/column_three"    android:layout_width="0dp"    android:layout_height="match_parent"    android:layout_weight="1"/>  <View    android:layout_width="0dp"    android:layout_height="match_parent"    android:layout_weight="0.2"/></LinearLayout>

以上是“Android如何实现带动画柱状图”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网精选频道!

--结束END--

本文标题: Android如何实现带动画柱状图

本文链接: https://lsjlt.com/news/221872.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Android如何实现带动画柱状图
    这篇文章主要为大家展示了“Android如何实现带动画柱状图”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Android如何实现带动画柱状图”这篇文章吧。为何要用带动画的柱状图呢?最近,项目中遇...
    99+
    2023-05-30
    android
  • vue如何用Echarts画柱状图
    vue如何用Echarts画柱状图,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。vue是什么Vue是一套用于构建用户界面的渐进式JavaScript框架,Vue与其它大型框...
    99+
    2023-06-26
  • echarts如何实现带百分比的横向柱状图
    目录实例代码效果图代码解析总结实例代码 var data = [220, 182, 191, 234, 290, 120, 65, 444]; var barWidth = 20...
    99+
    2024-04-02
  • Vue echart如何实现柱状图,电池图,3D柱图和3D圆柱图
    这篇文章主要为大家展示了“Vue echart如何实现柱状图,电池图,3D柱图和3D圆柱图”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Vue echart如何实现柱状图,电...
    99+
    2023-06-28
  • VUE中怎么渲染Echarts动画柱状图
    这篇文章主要介绍“VUE中怎么渲染Echarts动画柱状图”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“VUE中怎么渲染Echarts动画柱状图”文章能帮助大家解决问题。柱状图效果图安装Echart...
    99+
    2023-07-05
  • vue echarts实现柱状图动态展示
    本文实例为大家分享了vue echarts实现柱状图动态展示的具体代码,供大家参考,具体内容如下 轮播图形式展现 <template> <div clas...
    99+
    2024-04-02
  • Python实现动态柱状图的绘制
    目录一.基础柱状图二.基础时间线柱状图三.GDP动态柱状图绘制四.完整代码一.基础柱状图 如图 演示 from pyecharts.charts import Bar from p...
    99+
    2022-12-29
    Python绘制动态柱状图 Python动态柱状图 Python 柱状图
  • Android自定义带增长动画和点击弹窗提示效果的柱状图DEMO
    项目中最近用到各种图表,本来打算用第三方的,例如MPAndroid,这是一个十分强大的图表库,应用起来十分方便,但是最终发现和设计不太一样,没办法,只能自己写了。今天将写好的柱...
    99+
    2022-06-06
    弹窗 demo 动画 Android
  • .net+FusionChart实现动态显示的柱状图和饼状图
    html代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.or...
    99+
    2024-04-02
  • Android如何自定义圆角柱状图
    这篇文章主要为大家展示了“Android如何自定义圆角柱状图”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Android如何自定义圆角柱状图”这篇文章吧。具体内容如下需求:画一个圆角柱状图,显示...
    99+
    2023-06-29
  • vue+echart实现双柱状图
    本文实例为大家分享了vue+echart实现双柱状图的具体代码,供大家参考,具体内容如下 效果图: 一、安装 版本号建议安装"echarts": "^4.8.0”,其它版本init...
    99+
    2024-04-02
  • hightcharts柱状图怎么实现
    本文小编为大家详细介绍“hightcharts柱状图怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“hightcharts柱状图怎么实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学...
    99+
    2024-04-02
  • ECharts​怎么实现柱状图
    这篇文章主要讲解了“ECharts怎么实现柱状图”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“ECharts怎么实现柱状图”吧! //1、引入JS文件 ...
    99+
    2024-04-02
  • graphpad如何做柱状图
    这篇“graphpad如何做柱状图”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“graphpad如何做柱状图”文章吧。gra...
    99+
    2023-07-04
  • Android中怎么通过自定义view实现动态柱状图
    这篇文章将为大家详细讲解有关Android中怎么通过自定义view实现动态柱状图,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。自定义viewpublic class Hi...
    99+
    2023-05-30
    android view
  • React+CSS 实现绘制竖状柱状图
    前言: 页面结构分为两个部分,柱状图 + 文字为一部分,标注为为一部分。 先来看柱状图 + 文字这一部分。 宽度定为 width: 55, height ...
    99+
    2024-04-02
  • 如何使用C#实现运行状态堆叠柱状图
    小编给大家分享一下如何使用C#实现运行状态堆叠柱状图,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!具体内容如下需求通过柱状图显示设备运行时间停止时间,稼动率等通过...
    99+
    2023-06-29
  • echarts怎么实现带百分比的横向柱状图
    这篇文章主要讲解了“echarts怎么实现带百分比的横向柱状图”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“echarts怎么实现带百分比的横向柱状图”吧!实例代码var data...
    99+
    2023-06-25
  • C#如何绘制饼状图和柱状图
    这篇文章主要介绍C#如何绘制饼状图和柱状图,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体内容如下#代码如下:using System;using System.Collections;usin...
    99+
    2023-06-29
  • vue echarts实现横向柱状图
    本文实例为大家分享了vue echarts实现横向柱状图的具体代码,供大家参考,具体内容如下 实现效果: 代码: <template> <div clas...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作