zoukankan      html  css  js  c++  java
  • 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中就可以使用。如图:


    注:写作本文是基于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<String> x = new ArrayList<String>(); for (int i = 0; i < count; i++) { // x轴显示的数据 x.add("x:" + i); } // y轴的数据 ArrayList<Entry> y = new ArrayList<Entry>(); 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<LineDataSet> mLineDataSets = new ArrayList<LineDataSet>(); mLineDataSets.add(mLineDataSet); LineData mLineData = new LineData(x, mLineDataSets); return mLineData; } }


    MainActivity.java须要的activity_main.xml :

    <RelativeLayout 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" >
    
    	<com.github.mikephil.charting.charts.LineChart
            android:id="@+id/chart"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />
        
    </RelativeLayout>


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

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

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


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


  • 相关阅读:
    python 垃圾回收机制
    @property 取代getter setter方法
    ==值相等 is同一性
    循环获取文件名,拼接路径打印
    python 闭包
    python生成器
    hadoop集群环境搭建之zookeeper集群的安装部署
    hadoop集群环境搭建之安装配置hadoop集群
    hadoop集群环境搭建准备工作
    linux下安装jdk
  • 原文地址:https://www.cnblogs.com/wgwyanfs/p/7338061.html
Copyright © 2011-2022 走看看