博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android统计图表MPAndroidChart
阅读量:6330 次
发布时间:2019-06-22

本文共 4837 字,大约阅读时间需要 16 分钟。



Android统计图表MPAndroidChart

MPAndroidChart是在Android平台上开源的第三方统计图表库,可以绘制样式复杂、丰富的各种统计图表,如一般常见的折线图、饼状图、柱状图、散点图、金融股票中使用的的“蜡烛”图、“泡泡”统计图、雷达状统计饼状图等等。简言之,AndroidMPChart基本上可以满足日常在Android平台上的统计图表开发需要。

AndroidMPChart在github上的项目主页:
在自己的项目的libs中,导入其发布的jar包即可使用MPAndroidChart。MPAndroidChart发布的jar包页面在:
AndroidMPChart使用方法:在上面的releases页面下载最新的jar包,复制到自己的项目libs中即可使用。如图:

注:写作本文是基于MPAndroidChart的版本:mpandroidchartlibrary-2-1-3.jar

现在,先做一个基础的AndroidMPChart折线图,折线图在平时的统计图表中应用最多,AndroidMPChart提供了丰富的功能给予支持。

效果图如下:

现给出实现上述统计图表的全部代码。

MainActivity.java的代码:

package zhangphil.linechart;import java.util.ArrayList;import com.github.mikephil.charting.charts.LineChart;import com.github.mikephil.charting.components.Legend;import com.github.mikephil.charting.components.Legend.LegendForm;import com.github.mikephil.charting.components.Legend.LegendPosition;import com.github.mikephil.charting.data.Entry;import com.github.mikephil.charting.data.LineData;import com.github.mikephil.charting.data.LineDataSet;import com.github.mikephil.charting.utils.ValueFormatter;import android.support.v7.app.ActionBarActivity;import android.graphics.Color;import android.os.Bundle;public class MainActivity extends ActionBarActivity {	@Override	protected void onCreate(Bundle savedInstanceState) {		super.onCreate(savedInstanceState);		setContentView(R.layout.activity_main);		LineChart chart = (LineChart) findViewById(R.id.chart);		// 制作7个数据点(沿x坐标轴)		LineData mLineData = makeLineData(7);		setChartStyle(chart, mLineData, Color.WHITE);	}	// 设置chart显示的样式	private void setChartStyle(LineChart mLineChart, LineData lineData,			int color) {		// 是否在折线图上添加边框		mLineChart.setDrawBorders(false);		mLineChart.setDescription("描述@ZhangPhil");// 数据描述		// 如果没有数据的时候,会显示这个,类似listview的emtpyview		mLineChart				.setNoDataTextDescription("如果传给MPAndroidChart的数据为空,那么你将看到这段文字。@Zhang Phil");		// 是否绘制背景颜色。		// 如果mLineChart.setDrawGridBackground(false),		// 那么mLineChart.setGridBackgroundColor(Color.CYAN)将失效;		mLineChart.setDrawGridBackground(false);		mLineChart.setGridBackgroundColor(Color.CYAN);		// 触摸		mLineChart.setTouchEnabled(true);		// 拖拽		mLineChart.setDragEnabled(true);		// 缩放		mLineChart.setScaleEnabled(true);		mLineChart.setPinchZoom(false);		// 设置背景		mLineChart.setBackgroundColor(color);		// 设置x,y轴的数据		mLineChart.setData(lineData);		// 设置比例图标示,就是那个一组y的value的		Legend mLegend = mLineChart.getLegend();		mLegend.setPosition(LegendPosition.BELOW_CHART_CENTER);		mLegend.setForm(LegendForm.CIRCLE);// 样式		mLegend.setFormSize(15.0f);// 字体		mLegend.setTextColor(Color.BLUE);// 颜色		// 沿x轴动画,时间2000毫秒。		mLineChart.animateX(2000);	}	/**	 * @param count	 *            数据点的数量。	 * @return	 */	private LineData makeLineData(int count) {		ArrayList
x = new ArrayList
(); for (int i = 0; i < count; i++) { // x轴显示的数据 x.add("x:" + i); } // y轴的数据 ArrayList
y = new ArrayList
(); for (int i = 0; i < count; i++) { float val = (float) (Math.random() * 100); Entry entry = new Entry(val, i); y.add(entry); } // y轴数据集 LineDataSet mLineDataSet = new LineDataSet(y, "测试数据集。by ZhangPhil"); // 用y轴的集合来设置参数 // 线宽 mLineDataSet.setLineWidth(3.0f); // 显示的圆形大小 mLineDataSet.setCircleSize(5.0f); // 折线的颜色 mLineDataSet.setColor(Color.DKGRAY); // 圆球的颜色 mLineDataSet.setCircleColor(Color.GREEN); // 设置mLineDataSet.setDrawHighlightIndicators(false)后, // Highlight的十字交叉的纵横线将不会显示, // 同时,mLineDataSet.setHighLightColor(Color.CYAN)失效。 mLineDataSet.setDrawHighlightIndicators(true); // 按击后,十字交叉线的颜色 mLineDataSet.setHighLightColor(Color.CYAN); // 设置这项上显示的数据点的字体大小。 mLineDataSet.setValueTextSize(10.0f); // mLineDataSet.setDrawCircleHole(true); // 改变折线样式,用曲线。 // mLineDataSet.setDrawCubic(true); // 默认是直线 // 曲线的平滑度,值越大越平滑。 // mLineDataSet.setCubicIntensity(0.2f); // 填充曲线下方的区域,红色,半透明。 // mLineDataSet.setDrawFilled(true); // mLineDataSet.setFillAlpha(128); // mLineDataSet.setFillColor(Color.RED); // 填充折线上数据点、圆球里面包裹的中心空白处的颜色。 mLineDataSet.setCircleColorHole(Color.YELLOW); // 设置折线上显示数据的格式。如果不设置,将默认显示float数据格式。 mLineDataSet.setValueFormatter(new ValueFormatter() { @Override public String getFormattedValue(float value) { int n = (int) value; String s = "y:" + n; return s; } }); ArrayList
mLineDataSets = new ArrayList
(); mLineDataSets.add(mLineDataSet); LineData mLineData = new LineData(x, mLineDataSets); return mLineData; }}

MainActivity.java需要的activity_main.xml :

MPAndroidChart提供了丰富的参数设计条件,可以设计样式丰富统计图表,比如在本例中,如果把注释掉的这段代码重新启用:

// 改变折线样式,用曲线。		// mLineDataSet.setDrawCubic(true);		// 默认是直线		// 曲线的平滑度,值越大越平滑。		// mLineDataSet.setCubicIntensity(0.2f);		// 填充曲线下方的区域,红色,半透明。		// mLineDataSet.setDrawFilled(true);		// mLineDataSet.setFillAlpha(128);		// mLineDataSet.setFillColor(Color.RED);

那么折线图的样式就变成这样:

你可能感兴趣的文章
最佳6款用于移动网站开发的 jQuery 图片滑块插件
查看>>
C++ String
查看>>
获取系统托盘图标的坐标及文本
查看>>
log4j Test
查看>>
HDU 1255 覆盖的面积(矩形面积交)
查看>>
Combinations
查看>>
SQL数据库无法附加,提示 MDF" 已压缩,但未驻留在只读数据库或文件组中。必须将此文件解压缩。...
查看>>
第二十一章流 3用cin输入
查看>>
在workflow中,无法为实例 ID“...”传递接口类型“...”上的事件“...” 问题的解决方法。...
查看>>
获取SQL数据库中的数据库名、所有表名、所有字段名、列描述
查看>>
Orchard 视频资料
查看>>
简述:预处理、编译、汇编、链接
查看>>
调试网页PAIP HTML的调试与分析工具
查看>>
路径工程OpenCV依赖文件路径自动添加方法
查看>>
玩转SSRS第七篇---报表订阅
查看>>
WinCE API
查看>>
POJ 3280 Cheapest Palindrome(DP 回文变形)
查看>>
oracle修改内存使用和性能调节,SGA
查看>>
SQL语言基础
查看>>
对事件处理的错误使用
查看>>