RecyclerBezierChart曲線圖表繪制
曲線圖標(biāo)RecyclerBezierChart 的繪制
本篇介紹曲線圖標(biāo)RecyclerBezierChart 的繪制, 同樣圖表的公共部分的繪制這里不再做介紹,主體圖表的繪制邏輯在BezierChartRender類中,其中包含主體曲線的繪制以及底部fill部分的漸變色的繪制。
三階貝塞爾曲線
曲線的繪制用的三階貝塞爾曲線,關(guān)于貝塞爾曲線相關(guān)的知識(shí)讀者可自行Google,Android中的三階貝塞爾曲線的繪制API接口,以下為Path構(gòu)建三階曲線,其中包含兩個(gè)Control Points.

這里的繪制邏輯主要參考了MPAndroidChart中的曲線繪制.

首先將Entry的 Y值轉(zhuǎn)換成對(duì)應(yīng)的PointF,這個(gè)之前圖表都有同樣的操作,存入originPointFList, 然后通過originPointFList計(jì)算對(duì)應(yīng)的 Control Points List, 存入 controList, 其中ControlPoint 這個(gè)類筆者自定義的包含了兩個(gè)Control Point 點(diǎn),緊接著Control Point的計(jì)算再介紹。
得到originPointFList, controList后,每次迭代套用Path.cubicTo(controlPoint1, controlPoint2, endPoint) API即可,最終得到 cubicPath.
cubicPath
曲線圖底部是漸變Color區(qū)域,這里構(gòu)建了封閉的Path cubicFillPath, 其中包含了cubicPath。
private void drawCubicFill(RecyclerView parent, Canvas c, List<PointF> pointFList, Path spline, float bottom) {
spline.lineTo(pointFList.get(pointFList.size() - 1).x, bottom);
spline.lineTo(pointFList.get(0).x, bottom);
spline.close();
drawFilledPath(parent, c, spline);
}
整個(gè)主體圖表的繪制邏輯大致如上,非常簡(jiǎn)單。
下面是剛提到的關(guān)于 Control Point 的計(jì)算, 這里定義了一個(gè)類 ControlPoint, 包含兩個(gè)Control Point點(diǎn)。上面計(jì)算controList 方法也就作為 它的static 方法放在ControlPoint 中了。
List<ControlPoint> controlList = ControlPoint.getControlPointList(originPointFList, mBarChartAttrs.bezierIntensity);
其中 bezierIntensity 表示控制貝塞爾曲線曲率強(qiáng)度的一個(gè)參數(shù)系數(shù)。

對(duì)于不是第一個(gè),最后點(diǎn), 計(jì)算公式:
controlPoint.x = cur.x + (next.x - pre.x) * bezierIntensity; Y值同理。
兩個(gè)邊界位置Index 邊界的原因稍作變動(dòng),具體如下:

至此曲線圖的繪制結(jié)束,非常簡(jiǎn)單,最后附上一張RecyclerBezierChart的gif 圖。

本專欄到這里幾個(gè)常用的圖表的純繪制介紹完了,接下來大致兩到三章節(jié)介紹圖表動(dòng)態(tài)相關(guān)的邏輯,選中高亮的控制,長(zhǎng)按選中滑動(dòng)跟RecyclerView本身滑動(dòng)的一個(gè)沖突上的解決;控制同一天顯示在一屏?xí)r的回彈的控制邏輯。
以上就是RecyclerBezierChart曲線圖表繪制的詳細(xì)內(nèi)容,更多關(guān)于RecyclerBezierChart圖表繪制的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Android RecyclerView詳解及簡(jiǎn)單實(shí)例
這篇文章主要介紹了Android RecyclerView詳解及簡(jiǎn)單實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-01-01
Android自定義控件實(shí)現(xiàn)可左右滑動(dòng)的導(dǎo)航條
這篇文章主要介紹了Android自定義控件實(shí)現(xiàn)可左右滑動(dòng)的導(dǎo)航條,能響應(yīng)快速滑動(dòng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-07-07
android實(shí)現(xiàn)上傳本地圖片到網(wǎng)絡(luò)功能
這篇文章主要為大家詳細(xì)介紹了android實(shí)現(xiàn)上傳本地圖片到網(wǎng)絡(luò)功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-09-09
Android筆記之:App模塊化及工程擴(kuò)展的應(yīng)用
這篇文章是android開發(fā)人員的必備知識(shí),是我特別為大家整理和總結(jié)的,不求完美,但是有用2013-04-04
Android使用JobScheduler定期推送本地通知實(shí)例代碼
本篇文章主要介紹了Android使用JobScheduler定期推送本地通知實(shí)例代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06
Android反編譯看看手Q口令紅包的實(shí)現(xiàn)原理
這篇文章主要介紹了Android反編譯看看手Q口令紅包的實(shí)現(xiàn)原理,需要的朋友可以參考下2016-02-02
Android 中的危險(xiǎn)權(quán)限詳細(xì)整理
這篇文章主要介紹了Android 中的危險(xiǎn)權(quán)限詳細(xì)整理的相關(guān)資料,Android 中有上百種權(quán)限,現(xiàn)在將所有的權(quán)限歸為兩類,一類是普通權(quán)限,一類的危險(xiǎn)權(quán)限,危險(xiǎn)權(quán)限則表示那些可能會(huì)觸及到用戶安全隱私或者對(duì)設(shè)備安全造成影響的權(quán)限,需要的朋友可以參考下2017-07-07

