当前位置: 首页 > news >正文

Android 中 实现折线图自定义控件

一、基本思路

  • 创建自定义控件的数据模型;
  • 创建一个自定义 View 类,继承自 View;
  • 在初始化方法中获取自定义属性的值。
  • 创建设置数据方法,将数据模型列表转换成自定义绘制时的数据;
  • 重写 onDraw 方法,以实现自定义的绘制逻辑。

二、主要绘制方法

1、drawLine 绘制直线

public void drawLine(float startX, float startY, float stopX, float stopY, Paint paint)

  • startX 和 startY:起点的 x 和 y 坐标。
  • stopX 和 stopY:终点的 x 和 y 坐标。
  • 线条的样式是 Paint.Style.STROKE。

2、 drawLines 绘制一系列直线

public void drawLines(@Size(multiple = 4) @NonNull float[] pts, int offset, int count, @NonNull Paint paint)

  • pts:包含点坐标的数组。每条线由数组中的 4 个连续值定义,例如 pts[0] 和 pts[1] 是起点,pts[2] 和 pts[3] 是终点。因此,数组的长度必须是 4 的倍数
  • offset:从数组中跳过的值的数量。
  • count:在跳过 offset 个值后要处理的值的数量。由于每条线需要 4 个值,因此实际绘制的线条数量为 count / 4,也说明 count 值必须是 4 的倍数
  • 应用场景:drawLines 方法适用于绘制简单的直线,例如:绘制网格线,绘制坐标轴,绘制界线,在游戏或图表中绘制路径

3、drawText 绘制文本

public void drawText(@NonNull String text, float x, float y, @NonNull Paint paint)

  • text:要绘制的字符串。
  • x 和 y:文本的起始点坐标(y 是基线的坐标)。
  • paint:用于绘制文本的 Paint 对象。
  • 绘制文本时,可通过设置 paint 属性来配置文本的颜色、大小、样式(粗体、斜体、下划线)等属性。
	val paint = Paint()// 设置文本颜色paint.color = resources.getColor(R.color.red, null)// 设置文本大小paint.textSize = resources.getDimension(R.dimen.sp_18)// 设置文本为粗体paint.isFakeBoldText = true// 设置文本为斜体paint.textSkewX = -0.2f// 设置文本为下划线paint.isUnderlineText = true

4、drawCircle 绘制圆形

public void drawCircle(float cx, float cy, float radius, @NonNull Paint paint)

  • cx:圆心的 x 坐标。
  • cy:圆心的 y 坐标。
  • radius:圆的半径。如果半径小于或等于 0,则不会绘制任何内容。
  • paint:用于绘制圆形的 Paint 对象,可以设置颜色、样式等属性。
  • Paint 样式:Paint.Style.FILL 样式绘制实心圆形;Paint.Style.STROKE 样式绘制空心圆形,绘制空心圆形时,还需要设置 trokeWidth 来定义线条宽度;Paint.Style.FILL_AND_STROKE:填充圆形并绘制边框。
  • 抗锯齿:可以通过 paint.setAntiAlias(true) 开启抗锯齿,使圆形边缘更平滑。

三、demo 示例

1、数据模型定义

	data class ChartModel(val label: String, val value: Int)

2、res/values/attrs.xml 中自定义属性

    <declare-styleable name="LineChartView"><attr name="android:textColor" format="color"/><attr name="android:textSize" format="dimension"/><attr name="android:max" format="integer"/></declare-styleable>

3、自定义折线图控件

	package com.android.androidfunctiondemo.customviewimport android.content.Contextimport android.graphics.Canvasimport android.graphics.Paintimport android.util.AttributeSetimport android.view.Viewimport androidx.core.content.withStyledAttributesimport com.android.androidfunctiondemo.Rimport java.text.NumberFormatimport java.util.Localeclass LineChartView @JvmOverloads constructor(context: Context,attrs: AttributeSet? = null,defStyleAttr: Int = 0,) : View(context, attrs, defStyleAttr) {// 折线颜色private var chartColor = resources.getColor(R.color.red, null)private val chartNodeRadius = resources.getDimension(R.dimen.dp_5)// 坐标文本字体大小、颜色private var labelTextSize = resources.getDimension(R.dimen.sp_18)private var labelTextColor = resources.getColor(R.color.textColor, null)// 坐标线颜色private val coordinateLineColor = resources.getColor(R
http://www.dtcms.com/a/304644.html

相关文章:

  • BGP高级特性之ORF
  • spring 使用三级缓存解决循环依赖详解
  • 09 RK3568 Debian11 ES8388 模拟音频输出
  • 【腾讯云】EdgeOne免费版实现网站加速与安全防护
  • AI定义2025世界人工智能大会,腾讯/微美全息立足浪潮催生开源模型生态产业
  • 飞书 —— 多维表格 —— AI生成
  • 【术语扫盲】MCU与MPU
  • Spring框架中自定义标签的解析过程
  • 关于“高帧率放大了模型对位置噪声的敏感性”的理解
  • Kubernetes 全面解析:从基础设施变革到核心架构详解
  • Dify 从入门到精通(2/100 篇):Dify 的核心组件 —— 从节点到 RAG 管道
  • 利用 C# 实现 Word 文档多维度统计(字数、字符数、页数、段落数、行数)
  • 当 AI 重构审计流程,CISA 认证为何成为破局关键
  • 计算机视觉-图像基础处理
  • 双引擎驱动智能检索:混合搜索如何重构RAG系统底层逻辑
  • 智能健康项链专利拆解:ECG 与 TBI 双模态监测的硬件架构与信号融合
  • 算法提升之数论(矩阵+快速幂)
  • 隐藏文件行尾符CRLF
  • PostgreSQL缓冲区管理器
  • 2-verilog-基础语法
  • AI: 告别过时信息, 用RAG和一份PDF 为LLM打造一个随需更新的“外脑”
  • go install报错: should be v0 or v1, not v2问题解决
  • React图标库推荐与选择建议
  • 【Spring-cloud-OpenFegin源码解析】
  • VitePress学习笔记
  • 编程算法在金融、医疗、教育、制造业的落地应用。
  • 云服务器上基于lora微调Qwen2.5-VL-7b-Instruct模型之Lora微调代码讲解
  • Netty中InternalThreadLocalMap的作用
  • Rust实现GPU驱动的2D渲染引擎
  • Vue3 学习教程,从入门到精通, Vue3 自定义指令语法知识点及案例(20)