MPAndroidChart 自定義繪制最高點標(biāo)識

距離上次發(fā)布關(guān)于 MPAndroidChart 的文章已經(jīng)過去一個多月了曹抬,項目中新增了一個需求玛界,看起來很簡單棵逊。就是在最高點繪制矩形框伤疙,標(biāo)識最高點的數(shù)值,同時最高點處繪制一個小圈圈辆影,以及繪制平均數(shù)值線徒像,如下圖所示:

看起來很簡單,在 MPAndroidChart 的 demo 中也有 LineChart 具有小圓圈的和顯示數(shù)值的蛙讥,不過只在最高點繪制似乎是沒有锯蛀,并且也無法控制小空心圈圈的大小,所以只能自定義繪制了次慢。

在 LineChart 中自定義渲染繪制需要自定義一個 Render旁涤,繼承于 LineChartRenderer,然后重寫 drawValues 方法迫像。

接下來說說一個 LineChart 的基本構(gòu)成劈愚,每一個點都是一個 Entry,其兩個參數(shù)分別是 X 軸和 Y 軸的值闻妓,X 軸的必須為整型菌羽,Y 軸的是浮點型。LineDataSet 是由很多個點構(gòu)成由缆,所以其參數(shù)是 ArrayList<Entry>注祖,LineDataSet 能控制線的顏色和背景顏色,是否顯示小圈圈均唉,是否顯示每個點的數(shù)值標(biāo)簽是晨,遺憾的是不能精確到每個點,也就有了本文舔箭,再之上就是 LineData 了罩缴,其參數(shù)是 LineDataSet ,在此我默認(rèn)每個 LineChart 只有一組曲線圖,所以在 drawValues 中可以獲取 LineDataSet 以及 ArrayList<Entry> :

LineDataSet dataSet = (LineDataSet) mChart.getLineData().getDataSetByIndex(0);
List<Entry> entries = dataSet.getValues();

然后對 ArrayList<Entry> 遍歷靴庆,找到最大值时捌,然后獲取其 (X,Y) 軸的值,通過 MPAndroidChart 的內(nèi)置方法找到點在 Canvas 中的 (X,Y) 點的值炉抒。

Transformer trans = mChart.getTransformer(dataSet.getAxisDependency());
MPPointD pointD = trans.getPixelForValues(max_x, max_y);

接下來就可以在這個位置上繪制小圈圈奢讨,涉及到一點 Android Canvas 姿勢,這類的文章網(wǎng)上很多焰薄,我以前做過 C# WinForm GDI+ 相關(guān)的一些項目拿诸,對畫圖這塊略知一二理解起來尚不費力:

Paint paintDrawPointFill = new Paint(Paint.ANTI_ALIAS_FLAG);
paintDrawPointFill.setStyle(Paint.Style.FILL);
paintDrawPointFill.setColor(Color.WHITE);
c.drawCircle((float) pointD.x, (float) pointD.y, ScreenUnit.dp2px(context, 6),paintDrawPointFill);

接下來繪制最大值文字和實心圓角矩形,我的思路是先繪制文字塞茅,測量出文字的高度和寬度亩码,再在寬度分別左右加上邊距然后繪制實心圓角矩形。

String textTag="文字內(nèi)容";
Paint paint = new Paint(Paint.ANTI_ALIAS_FLAG);
paint.setTextSize(ScreenUnit.dp2px(context, 12));
paint.setColor(igsLineConfig.getMainColor());
Rect rectTextBounds = new Rect();
paint.getTextBounds(textTag, 0, textTag.length(), rectTextBounds);

獲取文字的寬和高:

 int textWidth = (rectTextBounds.right - rectTextBounds.left);
 int textHeight = (rectTextBounds.bottom - rectTextBounds.top);

然后為了適配能讓文字和矩形上下左右均保持一定距離野瘦,就類似于 Padding描沟,增加兩個參數(shù) OffsetX 和 OffsetY 兩個參數(shù),然后重新實例化一個矩形需要的坐標(biāo)系統(tǒng):

RectF rectF = new RectF((int) offset_x - textOffset,
                (int) offset_y - textHeight - textOffset,
                (int) offset_x + textWidth + textOffset,
                (int) offset_y + textOffset);

繪制圓角矩形:

c.drawRoundRect(rectF, igsLineConfig.getCorner(), igsLineConfig.getCorner(), paint);

還需要重新實現(xiàn)一個 LineChart鞭光,指定它的渲染為我們剛才實現(xiàn)對 LineChartRenderer 的實現(xiàn)吏廉,繼承 LineChart ,重寫 init 方法:

 @Override
    protected void init() {
        super.init();
        WindowManager wm = (WindowManager)getContext().getSystemService(Context.WINDOW_SERVICE);
        DisplayMetrics metrics = new DisplayMetrics();
        wm.getDefaultDisplay().getMetrics(metrics);
        MyChartDataRender dataRender = new MyChartDataRender(this, mAnimator, mViewPortHandler, metrics.widthPixels, tag);
        dataRender.context = getContext();
        dataRender.igsLineConfig = IgsChartConfigSingleton.instance.getIgsAltitudeLineConfig();
        mRenderer = dataRender;
    }

如果需要對 Canvas 繪制時做一些控制惰许,或者傳遞一些參數(shù)席覆,都可以在這個實現(xiàn)中去定義,比如我需要手動指定最大值的標(biāo)簽顯示等:

private double maxValue;

public double getMaxValue() {
        return maxValue;
}

public void setMaxValue(double maxValue) {
        this.maxValue = maxValue;
}

如果在 Render 的實現(xiàn)類中需要用到汹买,可以獲取圖表對象佩伤,然后強轉(zhuǎn)為我們寫的實現(xiàn)類:

 public void drawValues(Canvas c) {
        super.drawValues(c);
        MyLineChart  chartInstance = (MyLineChart) mChart;
}

至此就完成了最高點的標(biāo)識繪制了,還可以不用計算最高點值晦毙。改進(jìn)這個 LineChart 的實現(xiàn)生巡,自定義背景和前景都可以,然后共用一個 Render结序,話不多說障斋,上個圖。

畫平均線很簡單徐鹤,已經(jīng)內(nèi)置了實現(xiàn),你要做的就是計算出所有的 Y 軸的值的平均值邀层,或者數(shù)值如果來源于接口中返敬,直接設(shè)置就可以。

 LimitLine avgLine = new LimitLine((float) navg);
 avgLine.enableDashedLine(5.0f, 3.0f, 3.0f);
 avgLine.setLineColor(Color.parseColor("#33CC33"));
 lineChart1.getAxisLeft().addLimitLine(avgLine);

OK寥院,對 MPAndroidChart 的了解又更深一步了劲赠!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子凛澎,更是在濱河造成了極大的恐慌霹肝,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,039評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件塑煎,死亡現(xiàn)場離奇詭異沫换,居然都是意外死亡,警方通過查閱死者的電腦和手機最铁,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評論 3 395
  • 文/潘曉璐 我一進(jìn)店門讯赏,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人冷尉,你說我怎么就攤上這事漱挎。” “怎么了雀哨?”我有些...
    開封第一講書人閱讀 165,417評論 0 356
  • 文/不壞的土叔 我叫張陵磕谅,是天一觀的道長。 經(jīng)常有香客問我雾棺,道長膊夹,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,868評論 1 295
  • 正文 為了忘掉前任垢村,我火速辦了婚禮割疾,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘嘉栓。我一直安慰自己宏榕,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,892評論 6 392
  • 文/花漫 我一把揭開白布侵佃。 她就那樣靜靜地躺著麻昼,像睡著了一般。 火紅的嫁衣襯著肌膚如雪馋辈。 梳的紋絲不亂的頭發(fā)上抚芦,一...
    開封第一講書人閱讀 51,692評論 1 305
  • 那天,我揣著相機與錄音迈螟,去河邊找鬼叉抡。 笑死,一個胖子當(dāng)著我的面吹牛答毫,可吹牛的內(nèi)容都是我干的褥民。 我是一名探鬼主播,決...
    沈念sama閱讀 40,416評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼洗搂,長吁一口氣:“原來是場噩夢啊……” “哼消返!你這毒婦竟也來了载弄?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,326評論 0 276
  • 序言:老撾萬榮一對情侶失蹤撵颊,失蹤者是張志新(化名)和其女友劉穎宇攻,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體倡勇,經(jīng)...
    沈念sama閱讀 45,782評論 1 316
  • 正文 獨居荒郊野嶺守林人離奇死亡逞刷,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,957評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了译隘。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片亲桥。...
    茶點故事閱讀 40,102評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖固耘,靈堂內(nèi)的尸體忽然破棺而出题篷,到底是詐尸還是另有隱情,我是刑警寧澤厅目,帶...
    沈念sama閱讀 35,790評論 5 346
  • 正文 年R本政府宣布番枚,位于F島的核電站,受9級特大地震影響损敷,放射性物質(zhì)發(fā)生泄漏葫笼。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,442評論 3 331
  • 文/蒙蒙 一拗馒、第九天 我趴在偏房一處隱蔽的房頂上張望路星。 院中可真熱鬧,春花似錦诱桂、人聲如沸洋丐。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽友绝。三九已至,卻和暖如春肝劲,著一層夾襖步出監(jiān)牢的瞬間迁客,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評論 1 272
  • 我被黑心中介騙來泰國打工辞槐, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留掷漱,地道東北人。 一個月前我還...
    沈念sama閱讀 48,332評論 3 373
  • 正文 我出身青樓榄檬,卻偏偏與公主長得像切威,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子丙号,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,044評論 2 355

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

  • 圖表控件庫 MPAndroidChart 的使用 使用方法 項目源碼地址先朦,包含了很多類型的圖標(biāo) https://g...
    jinchuang閱讀 821評論 0 0
  • This chapter covers the basic setup for using this librar...
    ngugg閱讀 1,004評論 0 1
  • 開始 ####安裝 為了使用 LineChart, BarChart, ScatterChart, CandleS...
    帥氣的豬豬閱讀 8,461評論 0 1
  • 文章轉(zhuǎn)載自:https://github.com/tuteng/MPAndroidCharthttps://git...
    no白菜閱讀 5,139評論 0 8
  • 菡,如果說我想你了犬缨,你能感受得到嗎喳魏? 我想不會,你是不會想起我的怀薛!雙下午吃飯開的玩笑是關(guān)于你和我的刺彩。你應(yīng)該...
    lioooo1987閱讀 101評論 0 1