Android統計圖表MPAndroidChart.,mpandroidchart

來源:互聯網
上載者:User

Android統計圖表MPAndroidChart.,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中即可使用。

 

代碼如下:

  1 package com.lixu.zhexian;  2   3 import java.util.ArrayList;  4 import com.github.mikephil.charting.charts.LineChart;  5 import com.github.mikephil.charting.components.Legend;  6 import com.github.mikephil.charting.components.Legend.LegendForm;  7 import com.github.mikephil.charting.components.Legend.LegendPosition;  8 import com.github.mikephil.charting.components.XAxis.XAxisPosition;  9 import com.github.mikephil.charting.components.XAxis; 10 import com.github.mikephil.charting.data.Entry; 11 import com.github.mikephil.charting.data.LineData; 12 import com.github.mikephil.charting.data.LineDataSet; 13 import com.github.mikephil.charting.formatter.ValueFormatter; 14 import com.github.mikephil.charting.utils.ViewPortHandler; 15 import android.app.Activity; 16 import android.graphics.Color; 17 import android.os.Bundle; 18 import android.view.Window; 19  20 public class MainActivity extends Activity { 21  22     @Override 23     protected void onCreate(Bundle savedInstanceState) { 24         super.onCreate(savedInstanceState); 25         requestWindowFeature(Window.FEATURE_NO_TITLE); 26         setContentView(R.layout.activity_main); 27  28         LineChart mlinechart = (LineChart) findViewById(R.id.linechart); 29  30         LineData mLineData = LineData(30); 31         // 將x軸放到底部 預設在頂部 32         XAxis mXAxis = mlinechart.getXAxis(); 33         mXAxis.setPosition(XAxisPosition.BOTTOM); 34  35         setChartStyle(mlinechart, mLineData); 36     } 37  38     // 設定顯示樣式 39     private void setChartStyle(LineChart mlinechart, LineData mLineData) { 40         // 是否在折線上添加邊框 41         mlinechart.setDrawBorders(false); 42         // 資料描述 43         mlinechart.setDescription("溫度記錄資料"); 44         // 如果沒有資料的時候,會顯示這個,類似listview的emtpyview 45         mlinechart.setNoDataTextDescription("如果傳給MPAndroidChart的資料為空白,那麼你將看到這段文字。"); 46         // 是否繪製背景顏色。 47         // 如果mLineChart.setDrawGridBackground(false), 48         // 那麼mLineChart.setGridBackgroundColor()將失效; 49         mlinechart.setDrawGridBackground(true); 50         // 折線圖的背景 51         mlinechart.setGridBackgroundColor(Color.CYAN); 52         // 設定觸摸 53         mlinechart.setTouchEnabled(true); 54         // 設定拖拽 55         mlinechart.setDragEnabled(true); 56         // 設定縮放 57         mlinechart.setScaleEnabled(true); 58         mlinechart.setPinchZoom(false); 59         // x y 軸的背景 60         mlinechart.setBackgroundColor(Color.YELLOW); 61         // 設定x y軸的資料 62         mlinechart.setData(mLineData); 63         // 設定比例表徵圖,就是那一組y的value的 64         Legend mLegend = mlinechart.getLegend(); 65         mLegend.setPosition(LegendPosition.BELOW_CHART_CENTER); 66         // 樣式 67         mLegend.setForm(LegendForm.LINE); 68         // 字型 69         mLegend.setFormSize(20.0f); 70         // 下方字型顏色 71         mLegend.setTextColor(Color.BLUE); 72         // 設定x軸的動畫 73         mlinechart.animateX(15000); 74  75     } 76  77     private LineData LineData(int count) { 78         ArrayList<String> x = new ArrayList<String>(); 79         // x軸的資料 80         for (int i = 0; i < count; i++) { 81             x.add("第" + i + "天"); 82         } 83         // y軸的資料 84         ArrayList<Entry> y = new ArrayList<Entry>(); 85         for (int i = 0; i < count; i++) { 86             float f = (float) (Math.random() * 100); 87             Entry entry = new Entry(f, i); 88             y.add(entry); 89         } 90         // y軸的資料集 91         LineDataSet set = new LineDataSet(y, "資料集 --木子"); 92         // 用y軸的集合來設定參數 93         // 線寬 94         set.setLineWidth(3.0f); 95         // 顯示圓形大小 96         set.setCircleSize(5.0f); 97         // 折線的顏色 98         set.setColor(Color.BLACK); 99         // 圓球顏色100         set.setCircleColor(Color.RED);101         // 設定mLineDataSet.setDrawHighlightIndicators(false)後,102         // Highlight的十字交叉的縱橫線將不會顯示,103         // 同時,mLineDataSet.setHighLightColor()失效。104 105         set.setDrawHighlightIndicators(true);106         // 點擊後,十字交叉線的顏色107         set.setHighLightColor(Color.BLUE);108         // 設定顯示資料點字型大小109         set.setValueTextSize(10.0f);110         // mLineDataSet.setDrawCircleHole(true);111 112         // 改變折線樣式,用曲線。113         set.setDrawCubic(true);114         // 預設是直線115         // 曲線的平滑度,值越大越平滑。116         set.setCubicIntensity(0.2f);117 118         // 填充曲線下方的地區,紅色,半透明。119         set.setDrawFilled(true);120         // 數值越小 透明度越大121         set.setFillAlpha(150);122         set.setFillColor(Color.RED);123 124         // 填充折線上資料點、圓球裡麵包裹的中心空白處的顏色。125         set.setCircleColorHole(Color.YELLOW);126         // 設定折線上顯示資料的格式。如果不設定,將預設顯示float資料格式。127         set.setValueFormatter(new ValueFormatter() {128 129             @Override130             public String getFormattedValue(float value, Entry entry, int dataSetIndex,131                     ViewPortHandler viewPortHandler) {132                 int n = (int) value;133                 String str = n + "℃";134                 return str;135             }136         });137         ArrayList<LineDataSet> mLineDataSets = new ArrayList<LineDataSet>();138         mLineDataSets.add(set);139 140         LineData mLineData = new LineData(x, mLineDataSets);141         return mLineData;142 143     }144 }

xml檔案:

 1 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 2     xmlns:tools="http://schemas.android.com/tools" 3     android:layout_width="match_parent" 4     android:layout_height="match_parent" 5     android:orientation="vertical" > 6  7     <TextView 8         android:layout_width="match_parent" 9         android:layout_height="wrap_content"10         android:gravity="center"11         android:textSize="30sp"12         android:text="每日溫度記錄曲線圖"13         android:textColor="#ff0000" />14 15     <com.github.mikephil.charting.charts.LineChart16         android:id="@+id/linechart"17         android:layout_width="match_parent"18         android:layout_height="match_parent" />19 20 </LinearLayout>

運行:

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.