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

最近,项目中遇到一个地方,要用到柱状图。所以这篇文章主要讲怎么搞一个柱子。100行代码,搞定柱状图!
圆角,头顶带数字。恩,这样用drawable也可以搞定。但是,这个柱子是有一个动画的,就是进入到界面的时候柱子不断的长高。这样的话,综合考虑还是用自定义View来做比较简便。效果如下图了:
完整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;
/**************************************
* *** http://weibo.com/lixiaodaoaaa **
* *** create at 2017/5/18 23:45 ****
* ******* by:lixiaodaoaaa **********
**************************************/
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();
}
}
/*
* Copyright 2016 GcsSloop
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* Last modified 2016-10-02 00:22:33
*
*/
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>
完整Demo地址请到我的github下载地址:
https://github.com/lixiaodaoaaa/ColumnAnimViewProject
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# Android
# 柱状图
# Android自定义柱状图表的方法实例
# Android实现简易的柱状图和曲线图表实例代码
# Android自定义view实现动态柱状图
# 详解Android自定义View--自定义柱状图
# Android自定义带增长动画和点击弹窗提示效果的柱状图DEMO
# MPAndroidChart开源图表库的使用介绍之饼状图、折线图和柱状图
# Android自定义圆角柱状图
# 是一个
# 就会
# 下载地址
# 要用
# 圆角
# 请到
# 最小值
# 是有
# 是由
# 这两个
# 很重要
# 自定义
# 很长
# 一个字
# 这篇文章
# 来做
# 三个字
# 都应
# 不能超过
相关文章:
内网网站制作软件,内网的网站如何发布到外网?
浅析上传头像示例及其注意事项
建站168自助建站系统:快速模板定制与SEO优化指南
如何做网站制作流程,*游戏网站怎么搭建?
官网自助建站平台指南:在线制作、快速建站与模板选择全解析
图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?
如何在万网主机上快速搭建网站?
在线制作视频网站免费,都有哪些好的动漫网站?
如何配置IIS站点权限与局域网访问?
c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗
济南企业网站制作公司,济南社保单位网上缴费步骤?
如何快速搭建个人网站并优化SEO?
大学网站设计制作软件有哪些,如何将网站制作成自己app?
,石家庄四十八中学官网?
如何在服务器上三步完成建站并提升流量?
天河区网站制作公司,广州天河区如何办理身份证?需要什么资料有预约的网站吗?
建站之星伪静态规则如何正确配置?
c# F# 的 MailboxProcessor 和 C# 的 Actor 模型
深圳网站制作案例,网页的相关名词有哪些?
网站制作培训多少钱一个月,网站优化seo培训课程有哪些?
ppt制作免费网站有哪些,ppt模板免费下载网站?
h5在线制作网站电脑版下载,h5网页制作软件?
如何在搬瓦工VPS快速搭建网站?
做企业网站制作流程,企业网站制作基本流程有哪些?
C#如何在一个XML文件中查找并替换文本内容
武汉网站制作费用多少,在武汉武昌,建面100平方左右的房子,想装暖气片,费用大概是多少啊?
兔展官网 在线制作,怎样制作微信请帖?
如何实现建站之星域名转发设置?
济南网站制作的价格,历城一职专官方网站?
建站之星代理商如何保障技术支持与售后服务?
建站之星安装路径如何正确选择及配置?
如何快速辨别茅台真假?关键步骤解析
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
实例解析angularjs的filter过滤器
建站之星如何实现网站加密操作?
如何通过免费商城建站系统源码自定义网站主题与功能?
JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)
如何快速完成中国万网建站详细流程?
建站之星官网登录失败?如何快速解决?
相册网站制作软件,图片上的网址怎么复制?
高端云建站费用究竟需要多少预算?
Java解压缩zip - 解压缩多个文件或文件夹实例
Thinkphp 中 distinct 的用法解析
建站主机助手选型指南:2025年热门推荐与高效部署技巧
模具网站制作流程,如何找模具客户?
手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?
如何构建满足综合性能需求的优质建站方案?
如何制作一个表白网站视频,关于勇敢表白的小标题?
php8.4新语法match怎么用_php8.4match表达式替代switch【方法】
如何获取PHP WAP自助建站系统源码?
*请认真填写需求信息,我们会在24小时内与您取得联系。