Flutter 112: 圖解自定義 ACEPieWidget 餅狀圖 (一)

????小菜準(zhǔn)備展示一個簡單的餅狀圖埋凯,因需要比較簡單單一点楼,所以小菜準(zhǔn)備自己繪制一個;今天小菜只嘗試?yán)L制過程白对,暫不涉及手勢操作掠廓;

ACEPieWidget

????小菜對于繪制分為三個步驟:

  1. 類別選項(xiàng)球;
  2. 切割繪制餅狀圖甩恼;
  3. 餅狀圖中繪制文字蟀瞧;

1. 類別選項(xiàng)球

????對于兩側(cè)不同顏色類別選項(xiàng)卡,僅需要簡單設(shè)置一下 Containerdecoration 裝飾器即可条摸,只是方便用戶查看餅狀圖分類而已悦污;

return Container(
    height: 45, width: 45,
    margin: EdgeInsets.symmetric(vertical: 2.5, horizontal: 10),
    decoration: BoxDecoration(color: _color, borderRadius: BorderRadius.circular((25.0))),
    child: Center(child: Text(_text, style: TextStyle(fontSize: 12, color: Colors.white))));

2. 餅狀圖繪制

????對于 Canvas 的基本繪制,小菜在之前的博客中有過簡單介紹钉蒲;此次小菜也是使用最基本的 drawArc 繪制扇形拼接為一個完整圓形方式切端;

  1. 獲取 ListData 總的數(shù)據(jù)值;
  2. 遍歷 ListData 根據(jù)各個子類別數(shù)據(jù)比例和旋轉(zhuǎn)角度進(jìn)行不同顏色的扇形圖繪制子巾;
  3. 最終拼接為完整餅狀圖帆赢;

????注意:在繪制扇形圖時需要注意扇形圖的起始角度和終止角度,需要累加上一次繪制的扇形圖角度线梗;

// 1. 設(shè)置畫筆
Paint _paint = Paint()..color = Colors.grey
    ..strokeWidth = 4.0..style = PaintingStyle.fill;
// 2. 獲取 ListData 總的數(shù)據(jù)值
_sumData() {
  if (_listData != null) {
    for (int i = 0; i < _listData.length; i++) {
      _sum += _listData[i].values.first;
    }
  }
}
// 3. 根據(jù)各個子類別數(shù)據(jù)比例和旋轉(zhuǎn)角度進(jìn)行不同顏色的扇形圖繪制
if (_listData != null) {
  for (int i = 0; i < _listData.length; i++) {
    startAngle += sweepAngle;
    sweepAngle = _listData[i].values.first * 2 * PI / _sum;
    canvas.drawArc(_circle, startAngle, sweepAngle, true,
        _paint..color = _subPaint(_listData[i].keys.first));
    }
  }
}

3. 文字繪制

????餅狀圖繪制好之后就是在各自的扇形面積上繪制文字椰于;其中小菜規(guī)定,只有扇形圖角度大于等于 30 度的時候才會進(jìn)行文字繪制仪搔,如果扇形圖角度太小繪制顯示效果不佳瘾婿;

  1. 文字的初始繪制點(diǎn)默認(rèn)是以屏幕左上角為坐標(biāo)原點(diǎn),此時在扇形面內(nèi)進(jìn)行繪制時首先需要通過 translate() 平移坐標(biāo)系至餅狀圖圓心烤咧;
  2. 繪制文字的角度要與扇形的角平分線平行偏陪,此時通過 rotate() 對坐標(biāo)系進(jìn)行適當(dāng)角度的旋轉(zhuǎn);
  3. 小菜無法得知文字占據(jù)坐標(biāo)長度煮嫌,但是可以通過 Paragraph 獲取文字繪制時所占據(jù)高度笛谦,因此在通過 drawParagraph 繪制文字時適當(dāng)設(shè)置文字起始坐標(biāo),y 軸坐標(biāo)向上平移文字高度的一半昌阿;
  4. 再文字繪制結(jié)束之后饥脑,將坐標(biāo)系 rotate() 旋轉(zhuǎn)回正常水平豎直方向恳邀,并將起始坐標(biāo) translate() 平移恢復(fù)至屏幕左上角;待下次文字繪制灶轰;
// 1. 繪制文筆屬性(顏色谣沸,尺寸等)和最大段落寬度
ParagraphBuilder _pb = ParagraphBuilder(ParagraphStyle(
    textAlign: TextAlign.left, fontWeight: FontWeight.w600,
    fontStyle: FontStyle.normal, fontSize: 14))
  ..pushStyle(ui.TextStyle(color: Colors.white));
ParagraphConstraints _paragraph = ParagraphConstraints(width: size.width * 0.5);

if (sweepAngle >= PI / 6) {
  // 2. 平移坐標(biāo)系
  canvas.translate(size.width * 0.5, size.height * 0.5);
  // 3. 設(shè)置旋轉(zhuǎn)角度
  canvas.rotate(startAngle + sweepAngle * 0.5);
  // 4. 文字繪制
  Paragraph paragraph = (_pb..addText(_subName)).build()..layout(_paragraph);
  canvas.drawParagraph(paragraph, Offset(50.0, 0.0 - paragraph.height * 0.5));
  // 5. 恢復(fù)旋轉(zhuǎn)角度
  canvas.rotate(-startAngle - sweepAngle * 0.5);
  // 6. 恢復(fù)起始坐標(biāo)
  canvas.translate(-size.width * 0.5, -size.height * 0.5);
}

????ACEPieWidget 案例源碼


????小菜僅簡短的介紹了一下基本餅狀圖的樣式繪制,其功能還不夠完善笋颤,后續(xù)會加入適當(dāng)?shù)氖謩莶僮魅楦剑蝗缬绣e誤,請多多指導(dǎo)伴澄!

來源: 阿策小和尚

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末赋除,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子非凌,更是在濱河造成了極大的恐慌贤重,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,482評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件清焕,死亡現(xiàn)場離奇詭異并蝗,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)秸妥,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評論 2 382
  • 文/潘曉璐 我一進(jìn)店門滚停,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人粥惧,你說我怎么就攤上這事键畴。” “怎么了突雪?”我有些...
    開封第一講書人閱讀 152,762評論 0 342
  • 文/不壞的土叔 我叫張陵起惕,是天一觀的道長荠割。 經(jīng)常有香客問我掷漱,道長,這世上最難降的妖魔是什么森爽? 我笑而不...
    開封第一講書人閱讀 55,273評論 1 279
  • 正文 為了忘掉前任督函,我火速辦了婚禮嘀粱,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘辰狡。我一直安慰自己锋叨,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,289評論 5 373
  • 文/花漫 我一把揭開白布宛篇。 她就那樣靜靜地躺著娃磺,像睡著了一般。 火紅的嫁衣襯著肌膚如雪叫倍。 梳的紋絲不亂的頭發(fā)上偷卧,一...
    開封第一講書人閱讀 49,046評論 1 285
  • 那天嘿般,我揣著相機(jī)與錄音,去河邊找鬼涯冠。 笑死,一個胖子當(dāng)著我的面吹牛逼庞,可吹牛的內(nèi)容都是我干的蛇更。 我是一名探鬼主播,決...
    沈念sama閱讀 38,351評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼赛糟,長吁一口氣:“原來是場噩夢啊……” “哼派任!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起璧南,我...
    開封第一講書人閱讀 36,988評論 0 259
  • 序言:老撾萬榮一對情侶失蹤掌逛,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后司倚,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體豆混,經(jīng)...
    沈念sama閱讀 43,476評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,948評論 2 324
  • 正文 我和宋清朗相戀三年动知,在試婚紗的時候發(fā)現(xiàn)自己被綠了皿伺。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,064評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡盒粮,死狀恐怖鸵鸥,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情丹皱,我是刑警寧澤妒穴,帶...
    沈念sama閱讀 33,712評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站摊崭,受9級特大地震影響讼油,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜呢簸,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,261評論 3 307
  • 文/蒙蒙 一汁讼、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧阔墩,春花似錦嘿架、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至忘苛,卻和暖如春蝉娜,著一層夾襖步出監(jiān)牢的瞬間唱较,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評論 1 262
  • 我被黑心中介騙來泰國打工召川, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留南缓,地道東北人。 一個月前我還...
    沈念sama閱讀 45,511評論 2 354
  • 正文 我出身青樓荧呐,卻偏偏與公主長得像汉形,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子倍阐,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,802評論 2 345

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