中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android MPAndroidChart開源圖表庫之如何實現餅狀圖

發布時間:2021-09-10 14:09:48 來源:億速云 閱讀:122 作者:小新 欄目:移動開發

這篇文章主要介紹Android MPAndroidChart開源圖表庫之如何實現餅狀圖,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

MPAndroidChart是一款基于Android的開源圖表庫,MPAndroidChart不僅可以在Android設備上繪制各種統計圖表,而且可以對圖表進行拖動和縮放操作,應用起來非常靈活。MPAndroidChart同樣擁有常用的圖表類型:線型圖、餅圖、柱狀圖和散點圖。

下面主要實現以下餅狀圖:

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其他類型的圖表。

以上是“Android MPAndroidChart開源圖表庫之如何實現餅狀圖”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

灯塔市| 井陉县| 乌拉特前旗| 清镇市| 江口县| 肇庆市| 宿迁市| 收藏| 蕉岭县| 农安县| 长寿区| 东阳市| 安平县| 福清市| 上林县| 龙游县| 登封市| 平塘县| 缙云县| 宁陵县| 腾冲县| 吴旗县| 门头沟区| 赣州市| 临邑县| 峨眉山市| 旬阳县| 梓潼县| 通江县| 嘉祥县| 思南县| 临朐县| 洛宁县| 道真| 观塘区| 甘泉县| 威远县| 博白县| 夏邑县| 高清| 龙南县|