MPAndroidChart個(gè)人使用總結(jié)(一)

最新項(xiàng)目當(dāng)中使用到了MPAndroidChart這個(gè)三方庫用來繪制相關(guān)的圖標(biāo).該庫能力確實(shí)十分強(qiáng)大,但是使用過程中缺遇到了很多坑,該庫在3.0版本進(jìn)行了一次較大的改動(dòng),相對(duì)于2.x的版本很多用法都發(fā)生了變化.本人使用的是3.03版本,所以內(nèi)容以3.03版本的API為準(zhǔn).項(xiàng)目當(dāng)中主要使用到了折線圖,蠟燭圖,餅狀圖以及組合圖,會(huì)針對(duì)這幾個(gè)圖表進(jìn)行一些整理.

首先po一下MPAndroidChart的Git地址 :?MPAndroidChart,以及對(duì)用的JavaDocs文檔 :?MPAndroidChartJavaDocs

通過JavaDocs可以大致看出來該庫主要分為幾大類:

1,Chart:圖表的基類,其子類則是我們?cè)趚ml當(dāng)中需要用到的各種線段圖控件.例如LineChart(折線圖),BarChart(柱狀圖),CandleChart(蠟燭圖),CombinedChart(組合圖)....

2,ChartData:圖表數(shù)據(jù)的基類,其子類與Chart類的子類一一對(duì)應(yīng),為圖表提供數(shù)據(jù).例如LineData與LineChart對(duì)應(yīng),BarData與BarChart對(duì)應(yīng),CandleChart與CandleData對(duì)應(yīng).用來添加DataSet.

3,BaseDataSet:圖表數(shù)據(jù)設(shè)置的基類.其子類與上述的規(guī)則雷同,例如LineDataSet.用來添加Entry,并且可以對(duì)該圖表中的數(shù)據(jù)進(jìn)行一系列的設(shè)置.

4,BaseEntry:其子類是真正用來添加數(shù)據(jù)的類.規(guī)則也與之前的類似.唯一不同的是折線圖的Entry直接使用Entry.不同的圖標(biāo)Entry需要添加的參數(shù)不同

通過這4個(gè)類,我們得出一個(gè)最基本的信息,不考慮其他效果,交互,僅僅使用最基本的展示圖表的時(shí)候,其用法如下(偽代碼):

折線圖為例:

ArrayList<Entry> lineEntries = new ArrayList<>();

//這里需要特殊說明,3.0版本的用法與2.x版本較大的不同在這里,2.x版本需要單獨(dú)定義一個(gè)存放x坐標(biāo)的集合,而3.0版本只要直接傳入即可

lineEntries.add(new Entry(x坐標(biāo)點(diǎn),實(shí)際的數(shù)據(jù)));? ? ??

LineDataSet lineDataSet = new LineDataSet(lineEntries,"line")? ? //第二個(gè)參數(shù)相當(dāng)于該Set的標(biāo)記,自定義

LineData? lineData = new LineData(lineDataSet);

LineChart.setData(lineData);

當(dāng)然,很多時(shí)候我們的需求不僅僅是單純的展示,還需要有一些列的設(shè)置,那么我們還可以從JavaDocs中找到很多的設(shè)置

1,Chart類的一些設(shè)置: 每個(gè)圖表都可以通過相對(duì)應(yīng)的設(shè)置開啟或關(guān)閉一些交互以及顯示,列舉一些常用的

?//是否可以縮放

setScaleEnabled(true);

//是否繪制邊框

setDrawBorders(true);? ? ?

//邊框的寬度

setBorderWith(1);

//邊框的顏色

setBorderColor(#000000);

//是否可以拖動(dòng)

setDragEnabled(true);

//Y軸是否可以縮放

setScaleYEnabled(false);

//是否啟用Y軸自動(dòng)縮放

setAutoScaleMinMaxEnabled(true);

//是否持續(xù)滾動(dòng)

setDragDecelerationEnabled(false);

//是否雙擊縮放

setDoubleTapToZoomEnabled(false)

//沒有加載到數(shù)據(jù)時(shí)文字顯示

setNoDataText(" ")

//沒有加載到數(shù)據(jù)時(shí)文字顏色

setNoDataTextColor(#000000)

還可以通過getDescription()和getLegend()得到描述對(duì)象和圖例對(duì)象的實(shí)例.并且通過Description和Legend自身的API設(shè)置圖表的描述信息和圖例.這個(gè)不再圖表類的API當(dāng)中,之后拿出來單獨(dú)說

2.DateSet類的一些設(shè)置: 每一種圖表的DateSet都有對(duì)于該圖表設(shè)置的特殊API,以下已LineDataSet,CandleDataSet,BarDataSet為例.

通用:

????//是否顯示數(shù)據(jù)集的數(shù)值? ? ? ??

????setDrawValues(false);?

????//設(shè)置高亮線的顏色,就是點(diǎn)擊或者長按出現(xiàn)的線? ? ? ??

????setHighLightColor(#FFFFFF);??

????//是否允許高亮線顯示

????setHighlightEnabled(false);

LIneDataSet :

? ? //設(shè)置折線圖折線的寬度

? ? setLineWidth();

? ? //設(shè)置折線的樣式? ??CUBIC_BEZIER:圓滑的直線,LINEAR:直線,HORIZONTAL_BEZIER:不是特別圓滑的直線,STEPPED:類似于柱狀圖的感覺? ?

????setMode(LineDAtaSet.Mode.CUBIC_BEZIER);

? ?//是否繪制兩個(gè)點(diǎn)之間的圓點(diǎn)

? ??setDrawCircles(false);

? ? //線的顏色

? ??setColor(#FFFFFF);

? ? //是否填充數(shù)據(jù)集

? ??setDrawFilled(true);

? ? //設(shè)置填充的樣式,可以自己通過shape去畫一個(gè)

? ??setFillDrawable(drawable);

CandleDataSet:

? ? //設(shè)置open < close 的顏色. 也就是跌的顏色

? ??setDecreasingColor(#FFFFFF);

? ? //設(shè)置open > close的顏色, 也就是漲的顏色

? ??setIncreasingColor(#FFFFFF);

? ? //設(shè)置open == close的顏色. 這個(gè)有個(gè)坑,如果不設(shè)置該蠟燭圖的位置是一片空白的

? ??setNeutralColor(#FFFFFF);

? ? //設(shè)置是否蠟燭圖上下的線于該蠟燭圖漲跌顏色相同

? ??setShadowColorSameAsCandle(true);

? ? //設(shè)置蠟燭圖上下線的寬度

????setShadowWidth();

? ?//設(shè)置漲幅蠟燭圖的樣式(空心,實(shí)心)

? ??setDecreasingPaintStyle(Paint.Style.FILL);

? ? //設(shè)置跌幅蠟燭圖的樣式(空心,實(shí)心)? ??

? ???setIncreasingPaintStyle(Paint.Style.FILL);

? ? //設(shè)置數(shù)據(jù)集繪制對(duì)

? ??setAxisDependency(YAxis.AxisDependency.LEFT)

BarDataSet:? ??

? ? //設(shè)置柱狀圖數(shù)據(jù)集的顏色

? ??setColors(ArrayList);

3.x軸和y軸的一些設(shè)置.CharData類是對(duì)整個(gè)圖表外部以及操作進(jìn)行一些設(shè)置,DataSet類是對(duì)圖表內(nèi)容進(jìn)行一些設(shè)置.那么自然也會(huì)有x軸y軸的設(shè)置.

x軸: x軸設(shè)置是通過Chart.getXAxis() 獲得一個(gè)XAxis的實(shí)例,調(diào)用XAxis的實(shí)例進(jìn)行一些對(duì)于x軸的設(shè)置

//是否允許x軸繪制

setDrawLabels(true);? ? 如果設(shè)置為false,則所有的x軸設(shè)置都不起作用

//是否繪制x軸的軸線

setDrawAxisLine(false);

//是否繪制x軸邊線

setDrawGridLines(false);

//設(shè)置x軸的最小偏移

setAxisMinimum(0.5f);

//設(shè)置x軸字體顏色

setTextColor();

//設(shè)置x軸字體大小

setTextSize()

//設(shè)置x軸的位置

setPosition(XAxis.XAxisPosition.BOTTOM);?

//設(shè)置x軸標(biāo)簽數(shù)量

setLabelCount(5,true);? ? 如果不傳第二個(gè)參數(shù)或者false則位置不會(huì)固定,傳入true則位置固定

y軸: y軸分為左邊和右邊兩個(gè)軸,通過getAxisLeft()和getAxisRight()獲得對(duì)應(yīng)的實(shí)例.基本設(shè)置的api與x軸雷同,舉例幾個(gè)能用上但是與x軸不太一樣的

//這是y軸標(biāo)簽

setPosition(YAxis.YAxisLabelPosition.INSIDE_CHART); 可以傳入兩種參數(shù),INSIDE在圖表內(nèi)部,OUTSIDE在外部

//是否允許最上邊的標(biāo)簽繪制

setDrawTopYLabelEntry();

//自定義y軸標(biāo)簽數(shù)值

setValueFormatter(); 內(nèi)部實(shí)現(xiàn)一個(gè)IAxisValueFormatter接口,可以通過里面對(duì)應(yīng)的value修改標(biāo)簽數(shù)值.比如數(shù)值太小轉(zhuǎn)成科學(xué)計(jì)數(shù)法或者截取到幾位等等

一些基本設(shè)置就暫時(shí)寫到這里,后續(xù)會(huì)記錄一下個(gè)人遇到的一些難點(diǎn)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市概荷,隨后出現(xiàn)的幾起案子危尿,更是在濱河造成了極大的恐慌,老刑警劉巖涩禀,帶你破解...
    沈念sama閱讀 219,039評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件亿汞,死亡現(xiàn)場離奇詭異亮垫,居然都是意外死亡羔沙,警方通過查閱死者的電腦和手機(jī)躺涝,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來扼雏,“玉大人坚嗜,你說我怎么就攤上這事夯膀。” “怎么了苍蔬?”我有些...
    開封第一講書人閱讀 165,417評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵诱建,是天一觀的道長。 經(jīng)常有香客問我碟绑,道長俺猿,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,868評(píng)論 1 295
  • 正文 為了忘掉前任蜈敢,我火速辦了婚禮辜荠,結(jié)果婚禮上汽抚,老公的妹妹穿的比我還像新娘抓狭。我一直安慰自己,他們只是感情好造烁,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,892評(píng)論 6 392
  • 文/花漫 我一把揭開白布否过。 她就那樣靜靜地躺著,像睡著了一般惭蟋。 火紅的嫁衣襯著肌膚如雪苗桂。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,692評(píng)論 1 305
  • 那天告组,我揣著相機(jī)與錄音煤伟,去河邊找鬼。 笑死木缝,一個(gè)胖子當(dāng)著我的面吹牛便锨,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播我碟,決...
    沈念sama閱讀 40,416評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼放案,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼!你這毒婦竟也來了矫俺?” 一聲冷哼從身側(cè)響起吱殉,我...
    開封第一講書人閱讀 39,326評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎厘托,沒想到半個(gè)月后友雳,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,782評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡铅匹,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,957評(píng)論 3 337
  • 正文 我和宋清朗相戀三年押赊,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片伊群。...
    茶點(diǎn)故事閱讀 40,102評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡考杉,死狀恐怖策精,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情崇棠,我是刑警寧澤咽袜,帶...
    沈念sama閱讀 35,790評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站枕稀,受9級(jí)特大地震影響询刹,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜萎坷,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,442評(píng)論 3 331
  • 文/蒙蒙 一凹联、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧哆档,春花似錦蔽挠、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至插佛,卻和暖如春杠巡,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背雇寇。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評(píng)論 1 272
  • 我被黑心中介騙來泰國打工氢拥, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人锨侯。 一個(gè)月前我還...
    沈念sama閱讀 48,332評(píng)論 3 373
  • 正文 我出身青樓嫩海,卻偏偏與公主長得像,于是被迫代替她去往敵國和親识腿。 傳聞我的和親對(duì)象是個(gè)殘疾皇子出革,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,044評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)渡讼,斷路器骂束,智...
    卡卡羅2017閱讀 134,661評(píng)論 18 139
  • 文章轉(zhuǎn)載自:https://github.com/tuteng/MPAndroidCharthttps://git...
    no白菜閱讀 5,139評(píng)論 0 8
  • 開始 ####安裝 為了使用 LineChart, BarChart, ScatterChart, CandleS...
    帥氣的豬豬閱讀 8,461評(píng)論 0 1
  • 圖表控件庫 MPAndroidChart 的使用 使用方法 項(xiàng)目源碼地址,包含了很多類型的圖標(biāo) https://g...
    jinchuang閱讀 821評(píng)論 0 0
  • 歲月靜好是騙人的成箫,歲月磨平了許多東西展箱,包括你對(duì)我的愛。 當(dāng)初的我們一點(diǎn)點(diǎn)的計(jì)劃未來蹬昌,談?wù)撝孔雍⒆榆囎踊斐郏F(xiàn)在我們...
    商祺閱讀 340評(píng)論 0 1