1. 程式人生 > >Android之玩轉MPAndroidChart讓(折線圖、柱形圖、餅狀圖、雜湊圖、雷達圖)優雅的舞動

Android之玩轉MPAndroidChart讓(折線圖、柱形圖、餅狀圖、雜湊圖、雷達圖)優雅的舞動

package com.example.chenyu.mpandroidcharttest;

import android.app.Fragment;
import android.graphics.Color;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.util.DisplayMetrics;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

import com.github.mikephil.charting.charts.PieChart;
import com.github.mikephil.charting.components.Legend;
import com.github.mikephil.charting.data.Entry;
import com.github.mikephil.charting.data.PieData;
import com.github.mikephil.charting.data.PieDataSet;

import java.util.ArrayList;

/**
 * Created by Think on 2015/11/29.
 */
public class PieCharFragment extends Fragment {
    public PieChart mChart;

    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.pie_chart, container, false);
        mChart = (PieChart) view.findViewById(R.id.pie_chart);
        PieData mPieData = getPieData(4, 100);
        showChart(mChart, mPieData);
        return view;
    }

    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.animateY(3000);
        //設定資料
        pieChart.setData(pieData);
        // undo all highlights
//      pieChart.highlightValues(null);
//      pieChart.invalidate();
        Legend mLegend = pieChart.getLegend();  //設定比例圖
        mLegend.setPosition(Legend.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;
    }
}
效果圖如下