android: 一次自繪控制元件的體驗
一個盆友在 qq 上面給我一個截圖,問我有沒有見過這種效果。我一看,貌似不太難,雖然我並不熟悉自定義控制元件,但是網上的教程很多,於是決定實現一下。
這個就是給我的截圖。不是很清晰,也不完整。但是重點突出出來了。
於是,我看了看 HenCoder 的教程1,決定實現一下。(當然,實現期間,也翻閱了一下其他人的部落格)
我實現的效果如下:
大體實現貼一下:
@Override
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
super.onSizeChanged(w, h, oldw, oldh);
this.mWidth = w;
this.mHeight = h;
min = Math.min(mWidth, mHeight);
tableList = DynamicData.getViewSource();
paint = new Paint();
LogUtils.w(tableList);
oval = new RectF(0, 0, min, min);
icon = new RectF();
diffLeft = min / 10;
diffRight = diffLeft;
}
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
drawLeft(canvas);
iconLength = 1f * min / 17;
int height = (int) (iconLength / 2);
for (Table t : tableList) {
float left = min + diffLeft;
float right = left + iconLength;
float top = 0;
float bottom = top + iconLength;
paint.setColor(t.color);
icon.set(left, height + top, right, height + bottom);
canvas.drawRect(icon, paint);
paint.setTextSize(iconLength);
paint.setColor(Color.BLACK);
canvas.drawText(t.name + "\t" + (int) t.percent + "%",
right + diffRight, height + bottom, paint);
height += iconLength * 3;
}
}
private void drawLeft(Canvas canvas) {
paint.setColor(Color.parseColor("#dbdbdb"));
canvas.drawRect(oval, paint);
int start = 180;
for (Table t : tableList) {
float angle = (float) t.percent / 100 * 360;
paint.setColor(t.color);
paint.setStrokeCap(Paint.Cap.ROUND);
scaleOval(t.scale);
canvas.drawArc(oval, start, angle,
true, paint);
start += angle;
}
paint.setColor(Color.WHITE);
canvas.drawCircle(1f * min / 2, 1f * min / 2, min * 1f / 12, paint);
scaleOval(1); // 要加這一句,不然 onStop 後再進來就變小了
}
private void scaleOval(float scale) {
oval.set(0, 0, min, min);
float left = 1f * min * (1 - scale) / 2;
float top = 1f * min * (1 - scale) / 2;
float right = 1f * min * scale + left;
float bottom = 1f * min * scale + top;
oval.set(left, top, right, bottom);
}
嗯,裡面的邏輯不復雜,主要是對系統 api 的呼叫,然後計算一下,每次畫的起始位置。
其實,這種東西,我之前看到也會害怕,但是,真的很一般,不難的。
不過,這裡還是有需要優化的地方,比如最小尺寸,如果設定成 wrap_conent 怎麼處理,等等。我這裡的邏輯全部是 onDraw()
需要的,其他的,我沒有去實現。
如果想看完整原始碼:獻醜了,戳我。。。
相關文章
- QML::自繪基礎控制元件控制元件
- Android自定義view-自繪ViewAndroidView
- AI 繪畫 - 如何 0 成本線上體驗 AI 繪畫的魅力AI
- Android DataBinding之初體驗Android
- AI繪圖之Midjourney初體驗AI繪圖
- Qt實現表格樹控制元件-自繪樹節點虛線QT控制元件
- QTableView表格控制元件區域選擇-自繪選擇區域QTView控制元件
- Android開發之自定義隨機驗證碼控制元件Android隨機控制元件
- Android列表控制元件Android控制元件
- Android 分享控制元件Android控制元件
- Android控制元件的fitSystemWindows屬性Android控制元件Windows
- Android View的繪製過程AndroidView
- flutter初體驗之基礎控制元件知識Flutter控制元件
- 一次微信小程式的快速開發體驗微信小程式
- Android 簡單控制元件Android控制元件
- Android Jetpack Navigation 深入體驗報告AndroidJetpackNavigation
- 新手做自媒體的3大經驗
- Android 繪圖基礎Android繪圖
- 重繪DevExpress的XtraMessageBox訊息提示框控制元件devExpress控制元件
- PyQt5視窗繪圖控制元件QT繪圖控制元件
- 【Android繪圖】繪圖之基礎篇(一)Android繪圖
- android獲取控制元件的幾種方法Android控制元件
- Android如何實現超級棒的沉浸式體驗Android
- Android高亮引導控制元件Android控制元件
- Android - 控制元件抖動效果Android控制元件
- 在 Maui 中自繪元件1:繪製UI元件
- Android OpenGLES繪製天空盒Android
- PyQt5——視窗繪圖類控制元件QT繪圖控制元件
- Android基本控制元件和Activity的基本應用Android控制元件
- Android自定義控制元件 帶文字提示的SeekBarAndroid控制元件
- Android常用控制元件-BannerView(無限輪播圖控制元件)Android控制元件View
- Android 控制元件架構與自定義控制元件詳解Android控制元件架構
- Android P 凹口屏支援,打造全面屏體驗Android
- Android 長連線初體驗(基於netty)AndroidNetty
- Android 提升使用者體驗之骨架屏Android
- 【Android】自定義樹形控制元件Android控制元件
- 自動識別Android不合理的記憶體分配Android記憶體
- 益智遊戲突圍新思路?《Just Draw》繪畫+解密的新穎體驗遊戲解密