栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 移动开发 > Android

Android自定义条形对比统计图

Android 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Android自定义条形对比统计图

本文实例为大家分享了Android自定义条形对比统计图的具体代码,供大家参考,具体内容如下

一、测试截图

二、实现方法

package com.xtravel.widget;
 
import java.util.Timer;
import java.util.TimerTask;
import android.annotation.SuppressLint;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.view.View;
 

public class DataCenterCustomBarChart extends View {
 
 // 框架起点坐标、中心坐标、宽高
 private final int frame_X = 20;
 private final int frame_Y = 20;
 private final int frame_WIDTH = 1000;
 private final int frame_HEIGHT = 350;
 private final int frame_CENTER_X = frame_WIDTH / 2 + frame_X;
 private final int frame_CENTER_Y = frame_HEIGHT / 2 + frame_Y;
 
 // 二维坐标系原点坐标
 private final int ORIGIN_X = frame_X + 100;
 private final int ORIGIN_Y = frame_Y + frame_HEIGHT - 100;
 
 // XY轴终点坐标
 private final int XAXIS_X = frame_X + frame_WIDTH - 200;
 private final int XAXIS_Y = ORIGIN_Y;
 private final int YAXIS_X = ORIGIN_X;
 private final int YAXIS_Y = frame_Y + 50;
 
 // XY轴刻度数
 private int countX;
 private int countY;
 
 // XY轴分度值、真实数据分度值
 private float intervalX;
 private float intervalY;
 private float intervalPress;
 
 // 单位名称
 private String nameX;
 private String nameY;
 
 // 图表名称
 private String chartTitle;
 
 // 用户数据
 private int[] data1;
 private int[] data2;
 
 private int currentPosition;
 
 
 public DataCenterCustomBarChart(Context context, String chartTitle,
  String nameXAxis, String nameYAxis, int countY,
  int[] thisYearWeekPerson, int[] lastYearWeekPerson) {
 super(context);
 this.chartTitle = chartTitle;
 
 // x轴刻度数量以用户数据最大数据为依据,y轴刻度数量由用户来指定
 this.countX = thisYearWeekPerson.length > lastYearWeekPerson.length ? thisYearWeekPerson.length
  : lastYearWeekPerson.length;
 this.countY = countY;
 
 this.nameX = nameXAxis;
 this.nameY = nameYAxis;
 this.data1 = thisYearWeekPerson;
 this.data2 = lastYearWeekPerson;
 
 // 计算XY轴分度值 = 轴长/刻度数
 this.intervalX = (XAXIS_X - ORIGIN_X) / countX;
 this.intervalY = (ORIGIN_Y - YAXIS_Y) / countY;
 
 // 计算用户数据分度值 = 用户数据最大值/ 刻度数
 float max1 = findMaxData(thisYearWeekPerson);
 float max2 = findMaxData(lastYearWeekPerson);
 this.intervalPress = (max1 > max2 ? max1 : max2) / countY;
 // startDrawDynomicBar();
 }
 
 
 public void freshDynomicBar() {
 final Timer timer = new Timer();
 TimerTask timerTask = new TimerTask() {
  @Override
  public void run() {
  currentPosition++;
  postInvalidate();
  if (currentPosition == countX) {
   timer.cancel();
  }
  }
 };
 timer.schedule(timerTask, 100, 800);
 }
 
 
 @SuppressLint("DrawAllocation")
 public void onDraw(Canvas canvas) {
 super.onDraw(canvas);
 canvas.drawColor(Color.WHITE);
 
 Paint paint = new Paint();
 initAXIS(canvas, paint, chartTitle);
 drawDynamicBar1(canvas, paint, data1);
 drawDynamicBar2(canvas, paint, data2);
 }
 
 
 private void initAXIS(Canvas canvas, Paint paint, String chartTitle) {
 
 // 画边框
 paint.setColor(Color.GRAY);
 paint.setStyle(Paint.Style.STROKE);
 paint.setStrokeWidth(6);
 canvas.drawRect(frame_X, frame_Y, frame_WIDTH, frame_HEIGHT, paint);
 
 // 画坐标轴
 paint.setColor(Color.BLACK);
 paint.setStyle(Paint.Style.STROKE);
 paint.setStrokeWidth(5);
 // X轴及方向箭头
 canvas.drawLine(ORIGIN_X, ORIGIN_Y, XAXIS_X, XAXIS_Y, paint);
 canvas.drawLine(XAXIS_X, XAXIS_Y, XAXIS_X - 10, XAXIS_Y - 10, paint);
 canvas.drawLine(XAXIS_X, XAXIS_Y, XAXIS_X - 10, XAXIS_Y + 10, paint);
 // Y轴及方向箭头
 canvas.drawLine(ORIGIN_X, ORIGIN_Y, YAXIS_X, YAXIS_Y, paint);
 canvas.drawLine(YAXIS_X, YAXIS_Y, YAXIS_X - 10, YAXIS_Y + 10, paint);
 canvas.drawLine(YAXIS_X, YAXIS_Y, YAXIS_X + 10, YAXIS_Y + 10, paint);
 
 // 图表名称(2014年五月第一周)
 paint.setColor(Color.BLACK);
 paint.setStyle(Paint.Style.FILL);
 paint.setTextSize(20);// 设置字体大小
 paint.setStrokeWidth(2);
 canvas.drawText(chartTitle, frame_CENTER_X - 100, frame_Y + 30, paint);
 
 // 绘制数据系列20*20矩形(今年、去年)
 paint.setColor(Color.CYAN);
 canvas.drawRect(frame_WIDTH - 100, frame_CENTER_Y - 30,
  frame_WIDTH - 70, frame_CENTER_Y, paint);
 canvas.drawText("今年", frame_WIDTH - 60, frame_CENTER_Y, paint);
 
 paint.setColor(Color.MAGENTA);
 canvas.drawRect(frame_WIDTH - 100, frame_CENTER_Y, frame_WIDTH - 70,
  frame_CENTER_Y + 30, paint);
 canvas.drawText("去年", frame_WIDTH - 60, frame_CENTER_Y + 30, paint);
 
 // 画网格线
 paint.setColor(Color.GRAY);
 paint.setStyle(Paint.Style.STROKE);
 paint.setStrokeWidth(2);
 
 // 横线(从x轴依次向上画)
 for (int i = 0; i <= countY; i++) {
  canvas.drawLine(ORIGIN_X, ORIGIN_Y - i * intervalY, XAXIS_X,
   ORIGIN_Y - i * intervalY, paint);
 }
 
 // 竖线(从y轴依次向右画)
 for (int i = 0; i <= countX; i++) {
  canvas.drawLine(ORIGIN_X + i * intervalX, ORIGIN_Y, ORIGIN_X + i
   * intervalX, YAXIS_Y, paint);
 }
 
 // X轴刻度值(沿X轴方向1、2、3...),轴名称
 paint.setColor(Color.BLUE);
 paint.setStyle(Paint.Style.FILL);
 paint.setStrokeWidth(2);
 paint.setTextSize(30);
 for (int i = 0; i <= countX; i++) {
  canvas.drawText("" + i, ORIGIN_X + i * intervalX, ORIGIN_Y + 50,
   paint);
 }
 
 paint.setTextSize(20);
 // Y轴刻度值(沿Y轴方向,用户提供的数据)轴名称
 for (int i = 1; i <= countY; i++) {
  canvas.drawText("" + (int) (i * intervalPress), ORIGIN_X - 80,
   ORIGIN_Y - i * intervalY + 5, paint);
 }
 
 paint.setTextSize(20);
 canvas.drawText("(" + nameX + ")", XAXIS_X + 40, XAXIS_Y + 50, paint);
 canvas.drawText("(" + nameY + ")", YAXIS_X - 30, YAXIS_Y - 20, paint);
 }
 
 
 @SuppressLint("ResourceAsColor")
 private void drawDynamicBar1(Canvas canvas, Paint paint, int[] data) {
 float curRectX_data1 = ORIGIN_X + intervalX - 30;
 float curRectY_data1;
 for (int i = 1; i < currentPosition; i++, curRectX_data1 += intervalX) {
  // 绘制data1的动态条形
  paint.setColor(Color.CYAN);
  curRectY_data1 = data[i - 1] / intervalPress * intervalY;
  canvas.drawRect(curRectX_data1, ORIGIN_Y - curRectY_data1,
   curRectX_data1 + 30, ORIGIN_Y, paint);
 }
 }
 
 
 @SuppressLint("ResourceAsColor")
 private void drawDynamicBar2(Canvas canvas, Paint paint, int[] data) {
 float curRectX_data2 = ORIGIN_X + intervalX;
 float curRectY_data2;
 for (int i = 1; i < currentPosition; i++, curRectX_data2 += intervalX) {
  // 绘制data2的动态条形
  paint.setColor(Color.MAGENTA);
  curRectY_data2 = data[i - 1] / intervalPress * intervalY;
  canvas.drawRect(curRectX_data2, ORIGIN_Y - curRectY_data2,
   curRectX_data2 + 30, ORIGIN_Y, paint);
 }
 }
 
 
 private int findMaxData(int[] data) {
 int max = data[0];
 for (int i = 1; i < data.length; i++) {
  if (data[i] > max) {
  max = data[i];
  }
 }
 return max;
 }
 
 
 public float getGrowthRate() {
 float sumYear = 0, sumLastYear = 0;
 for (int i = 0; i < data1.length; i++) {
  sumYear += data1[i];
  sumLastYear += data2[i];
 }
 return (sumYear - sumLastYear) / sumLastYear * 100;
 }
 
 
 public int getSumWeek() {
 int sum = 0;
 for (int i = 0; i < data1.length; i++) {
  sum += data1[i];
 }
 return sum;
 }
 
 
 public int getAverageWeek() {
 return getSumWeek() / data1.length;
 }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持考高分网。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/153977.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号