android 机型 统计表,Android统计图表MPAndroidChart



Android统计图表MPAndroidChart

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

AndroidMPChart在github上的项目主页: https://github.com/PhilJay/MPAndroidChart

在自己的项目的libs中,导入其公布的jar包就可以使用MPAndroidChart。MPAndroidChart公布的jar包页面在: https://github.com/PhilJay/MPAndroidChart/releases

AndroidMPChart用法:在上面的releases页面下载最新的jar包。拷贝到自己的项目libs中就可以使用。如图:

44f90b4399a6e5aa84bc17e9aa78c752.png

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

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

效果图例如以下:

c300b22fe036075ca2679f422c7ca029.png

现给出实现上述统计图表的所有代码。

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 :

xmlns:tools="http://schemas.android.com/tools"

android:layout_width="match_parent"

android:layout_height="match_parent" >

android:id="@+id/chart"

android:layout_width="match_parent"

android:layout_height="match_parent" />

MPAndroidChart提供了丰富的參数设计条件,能够设计样式丰富统计图表。比方在本例中,假设把凝视掉的这段代码又一次启用:

// 改变折线样式,用曲线。

// mLineDataSet.setDrawCubic(true);

// 默认是直线

// 曲线的平滑度,值越大越平滑。

// mLineDataSet.setCubicIntensity(0.2f);

// 填充曲线下方的区域,红色。半透明。

// mLineDataSet.setDrawFilled(true);

// mLineDataSet.setFillAlpha(128);

// mLineDataSet.setFillColor(Color.RED);

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

3b9fec3d7d6e65dbcb11d2afd00d803a.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值