绘制K线第二章:背景网格绘制

绘制K线第二章:背景网格绘制

在第一章的基础上,我们简单修饰一下,补充一个背景九宫格的绘制功能。这个功能可以让K线图更加清晰易读,帮助用户快速定位价格和时间。

二、网格配置

确定网格的行数和列数

在绘制网格之前,我们需要确定:

  • 几行:将高度分成几等份(对应价格轴)
  • 几列:将宽度分成几等份(对应时间轴)

例如:4列5行,表示宽度分成4等份,高度分成5等份。

在Config中配置

为了灵活配置网格,我们在 KLineConfig 中添加了两个字段:

kotlin 复制代码
data class KLineConfig(
    // ... 其他配置 ...
    
    /**
     * 网格列数
     * 默认:4列
     */
    val gridColumnCount: Int = 4,
    
    /**
     * 网格行数
     * 默认:5行
     */
    val gridRowCount: Int = 5
)

模型改动

  • KLineConfig 新增 gridColumnCountgridRowCount 字段
  • 默认值:4列5行
  • 可以通过配置灵活调整网格密度

三、绘制网格线

计算网格线位置

核心公式

  • 列间距 = 宽度 ÷ 列数
  • 行间距 = 高度 ÷ 行数

绘制代码

kotlin 复制代码
private fun drawBackgroundGrid(canvas: Canvas, width: Float, height: Float) {
    val columnWidth = width / config.gridColumnCount
    val rowHeight = height / config.gridRowCount
    
    // 绘制竖线
    for (i in 1 until config.gridColumnCount) {
        val x = columnWidth * i
        canvas.drawLine(x, 0f, x, height, gridPaint)
    }
    
    // 绘制横线
    for (i in 1 until config.gridRowCount) {
        val y = rowHeight * i
        canvas.drawLine(0f, y, width, y, gridPaint)
    }
}

四、价格标签绘制

计算价格步长

价格标签显示在右侧Y轴,需要根据网格横线位置计算对应的价格值。

价格步长

ini 复制代码
val priceStep = (maxPrice - minPrice) / config.gridRowCount
  • 将价格范围(最高价-最低价)平均分成行数等份
  • 例如:价格范围1000-800=200,5行,步长=200÷5=40

获取具体价格

价格计算公式

lua 复制代码
for (i in 0 until config.gridRowCount) {
    val price = priceStep * (config.gridRowCount - i) + minPrice
}

五、时间标签绘制

计算网格竖线位置

时间标签显示在底部X轴,需要根据网格竖线位置找到对应的K线数据。

网格竖线X坐标

ini 复制代码
val columnWidth = width / config.gridColumnCount
val gridX = columnWidth * i  // i从0到gridColumnCount-1

从数据中获取时间

根据X坐标找到K线索引

scss 复制代码
val totalCandleWidth = config.getTotalCandleWidth()  // 每根K线宽度
val dataIndex = (gridX / totalCandleWidth).toInt().coerceIn(0, visibleData.size - 1)

逻辑说明

  • 将网格X坐标转换为K线索引
  • 索引 = 网格X坐标 ÷ 每根K线宽度(取整)
  • 限制在可见数据范围内

获取时间并绘制

scss 复制代码
val dateText = formatDate(visibleData[dataIndex].Date)
canvas.drawText(dateText, gridX, y, labelPaint)
  • 从对应K线数据的 Date 字段获取时间
  • 格式化后(如:yyyy/MM/dd → MM/dd)绘制在网格竖线位置

六、Case2 与 Case3 的区别

Case2(可见区间版本)

功能

  • 绘制蜡烛图
  • 处理可见区间
  • 无网格线和标签

Case3(网格+标签版本)

功能

  • 绘制蜡烛图
  • 处理可见区间
  • 新增:绘制背景网格(4列5行)
  • 新增:显示价格标签(右侧Y轴)
  • 新增:显示时间标签(底部X轴)

核心区别

功能 Case2 Case3
可见区间处理
背景网格
价格标签
时间标签

七、效果

相关推荐
东东5161 小时前
基于ssm的网上房屋中介管理系统vue
前端·javascript·vue.js
harrain2 小时前
什么!vue3.4开始,v-model不能用在prop上
前端·javascript·vue.js
fanruitian8 小时前
uniapp android开发 测试板本与发行版本
前端·javascript·uni-app
rayufo8 小时前
【工具】列出指定文件夹下所有的目录和文件
开发语言·前端·python
java干货8 小时前
<span class=“js_title_inner“>微服务:把一个简单的问题,拆成 100 个网络问题</span>
微服务·云原生·架构
STCNXPARM8 小时前
Android camera之硬件架构
android·硬件架构·camera
RANCE_atttackkk8 小时前
[Java]实现使用邮箱找回密码的功能
java·开发语言·前端·spring boot·intellij-idea·idea
成茂峰8 小时前
软考高级·系统架构设计师 | 一、绪论
架构·系统架构·软考高级·系统架构设计师
2501_944525549 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 支出分析页面
android·开发语言·前端·javascript·flutter
传感器与混合集成电路9 小时前
210℃与175℃高温存储器选型研究:LHM256MB与LDMF4GA-H架构与可靠性对比(下)
架构