網站首頁 編程語言 正文
概述
有時我們需要實時滾動顯示一段時間的數據,使用一些圖表框架可能不夠靈活,不能滿足定制化的需求,所以自定義一個控件,使我們可以為所欲為。
演示
環境
開發工具:Android Studio
開發語言:Kotlin
實現
第一步:新建項目RealTimeChartDemo
第二步:新建RealTimeChart類
這個類便是要自定義的控件,需要繼承自View類。
此類中需要重寫 onSizeChanged 和 onDraw方法。
第三步:添加自定義變量
首先需要有控件的寬度和高度
然后需要把要繪制的點在此控件范圍內,所以需要有轉換系數
然后為了顯示X軸和Y軸的一些標簽,需要有邊界的大小
然后為了繪制坐標點,需要有坐標的集合,繪制線(Path)
然后需要有個中標簽,線等等的顏色,樣式,寬度等等Paint
需要定義一個Point的類
第四步:初始化基礎參數
初始化Paint的各種參數
第五步:初始化寬高等參數
第六步:定義添加坐標點方法
第七步:定義坐標偏移方法
由于左上下都留出了顯示標簽的位置,所以在實際繪制時需要進行一定的偏移
第八步:定義繪制網格線方法
在繪制網格顯示,順便將Y軸標簽一起繪制
第九步:定義繪制X軸標簽方法
第十步:定義繪制坐標點方法
每次有新點時都重新繪制圖表,達到動態滾動的效果
第十一步:繪制
在onDraw方法中,添加繪制輔助線和繪制坐標點方法
第十二步:在activity_main.xml中使用控件
第十三步:在MainActivity中模擬添加數據點
原文鏈接:https://www.jianshu.com/p/e151fddcb40f
相關推薦
- 2022-05-15 Redis中有序集合的內部實現方式的詳細介紹_Redis
- 2023-01-11 Pytorch可視化(顯示圖片)及格式轉換問題_python
- 2022-04-26 ASP.NET?Core中的Razor頁面使用視圖組件_基礎應用
- 2022-05-10 setAttribute() 與 getAttribute() 用法剖析及選項卡操作的實例展示,這一
- 2023-07-26 node中的內置模塊path和fs
- 2022-07-19 簡單認清深拷貝和淺拷貝
- 2022-06-06 Python數據可視化Pyecharts制作Heatmap熱力圖_python
- 2022-12-28 Qt開發之QTreeWidget的使用教程詳解_C 語言
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支