首页 > 系统 > Android > 正文

Android MPAndroidChart开源图表库之饼状图的代码

2019-10-22 18:11:09
字体:
来源:转载
供稿:网友

MPAndroidChart是一款基于Android的开源图表库,MPAndroidChart不仅可以在Android设备上绘制各种统计图表,而且可以对图表进行拖动和缩放操作,应用起来非常灵活。MPAndroidChart同样拥有常用的图表类型:线型图、饼图、柱状图和散点图。

GitHub地址

下面主要实现以下饼状图

1.从上面的地址中下载最新mpandroidchartlibrary-2-0-8.jar包, 然后copy到项目的libs中;

2.定义xml文件;

3.主要Java逻辑代码如下,注释已经都添加上了。

package com.jackie.mpandroidpiechart; import java.util.ArrayList; import com.github.mikephil.charting.charts.PieChart; import com.github.mikephil.charting.components.Legend; import com.github.mikephil.charting.components.Legend.LegendPosition; import com.github.mikephil.charting.data.Entry; import com.github.mikephil.charting.data.PieData; import com.github.mikephil.charting.data.PieDataSet; import android.support.v7.app.ActionBarActivity; import android.graphics.Color; import android.os.Bundle; import android.util.DisplayMetrics; public class MainActivity extends ActionBarActivity {  private PieChart mChart;  @Override  protected void onCreate(Bundle savedInstanceState) {  super.onCreate(savedInstanceState);  setContentView(R.layout.activity_main);  mChart = (PieChart) findViewById(R.id.spread_pie_chart);  PieData mPieData = getPieData(4, 100);  showChart(mChart, mPieData);  }  private void showChart(PieChart pieChart, PieData pieData) {  pieChart.setHoleColorTransparent(true);  pieChart.setHoleRadius(60f); //半径  pieChart.setTransparentCircleRadius(64f); // 半透明圈  //pieChart.setHoleRadius(0) //实心圆  pieChart.setDescription("测试饼状图");  // mChart.setDrawYValues(true);  pieChart.setDrawCenterText(true); //饼状图中间可以添加文字  pieChart.setDrawHoleEnabled(true);  pieChart.setRotationAngle(90); // 初始旋转角度  // draws the corresponding description value into the slice  // mChart.setDrawXValues(true);  // enable rotation of the chart by touch  pieChart.setRotationEnabled(true); // 可以手动旋转  // display percentage values  pieChart.setUsePercentValues(true); //显示成百分比  // mChart.setUnit(" ");  // mChart.setDrawUnitsInChart(true);  // add a selection listener // mChart.setOnChartValueSelectedListener(this);  // mChart.setTouchEnabled(false); // mChart.setOnAnimationListener(this);  pieChart.setCenterText("Quarterly Revenue"); //饼状图中间的文字  //设置数据  pieChart.setData(pieData);  // undo all highlights // pieChart.highlightValues(null); // pieChart.invalidate();  Legend mLegend = pieChart.getLegend(); //设置比例图  mLegend.setPosition(LegendPosition.RIGHT_OF_CHART); //最右边显示 // mLegend.setForm(LegendForm.LINE); //设置比例图的形状,默认是方形  mLegend.setXEntrySpace(7f);  mLegend.setYEntrySpace(5f);  pieChart.animateXY(1000, 1000); //设置动画  // mChart.spin(2000, 0, 360);  }  /**  *  * @param count 分成几部分  * @param range  */  private PieData getPieData(int count, float range) {  ArrayList<String> xValues = new ArrayList<String>(); //xVals用来表示每个饼块上的内容  for (int i = 0; i < count; i++) {  xValues.add("Quarterly" + (i + 1)); //饼块上显示成Quarterly1, Quarterly2, Quarterly3, Quarterly4  }  ArrayList<Entry> yValues = new ArrayList<Entry>(); //yVals用来表示封装每个饼块的实际数据  // 饼图数据  /**  * 将一个饼形图分成四部分, 四部分的数值比例为14:14:34:38  * 所以 14代表的百分比就是14%  */  float quarterly1 = 14;  float quarterly2 = 14;  float quarterly3 = 34;  float quarterly4 = 38;  yValues.add(new Entry(quarterly1, 0));  yValues.add(new Entry(quarterly2, 1));  yValues.add(new Entry(quarterly3, 2));  yValues.add(new Entry(quarterly4, 3));  //y轴的集合  PieDataSet pieDataSet = new PieDataSet(yValues, "Quarterly Revenue 2014"/*显示在比例图上*/);  pieDataSet.setSliceSpace(0f); //设置个饼状图之间的距离  ArrayList<Integer> colors = new ArrayList<Integer>();  // 饼图颜色  colors.add(Color.rgb(205, 205, 205));  colors.add(Color.rgb(114, 188, 223));  colors.add(Color.rgb(255, 123, 124));  colors.add(Color.rgb(57, 135, 200));  pieDataSet.setColors(colors);  DisplayMetrics metrics = getResources().getDisplayMetrics();  float px = 5 * (metrics.densityDpi / 160f);  pieDataSet.setSelectionShift(px); // 选中态多出的长度  PieData pieData = new PieData(xValues, pieDataSet);  return pieData;  } } 

 效果图如下:

android,开源图表库,MPAndroidChart,饼状图,代码

主要是一些基本属性和API的调用,具体每个API都有什么样的效果和作用,只能靠自己去尝试。后面还会陆陆续续为大家介绍MPAndroidChart其他类型的图表。

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


注:相关教程知识阅读请移步到Android开发频道。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表