lvgl9 Line(lv_line) 控件使用指南

文章目录

    • 前言
    • 主体
      • 1. **Line 控件概述**
      • 2. **使用场景**
      • 3. **控件的样式**
      • 4. **设置点**
      • 5. **自动大小**
      • 6. **y 坐标反转**
      • 7. **事件处理**
      • 8. **示例代码**
    • 总结


前言

在图形界面设计中,直线绘制是非常常见且重要的功能之一,尤其是在需要进行图形表示、数据可视化和图形界面设计时。LittlevGL 提供的 lv_line 控件使得在显示屏上绘制直线变得非常简单和灵活。通过设置一组点,lv_line 可以自动计算出并连接这些点,绘制出所需的直线图形。

主体

1. Line 控件概述

lv_line 控件能够绘制一条或多条直线。通过设置若干个点,它可以根据这些点的位置绘制出一个连贯的直线路径。它支持精确的像素坐标和百分比坐标,能够灵活适应不同的显示需求。

2. 使用场景

lv_line 控件常用于以下几种场景:

  • 数据可视化:在图表中,常常需要通过直线连接数据点,例如绘制折线图、曲线图等。
  • UI 装饰:在界面布局中,可以使用直线作为装饰元素,例如分割线或界面边界。
  • 路径绘制:在一些交互式应用中,可能需要绘制路径轨迹或用户操作轨迹,lv_line 通过精确的点连接,能够很好地展示路径形状。

3. 控件的样式

lv_line 的样式通过一个主要部分来控制:

  • LV_PART_MAIN:此部分使用所有典型的背景样式属性以及线条样式的属性。它控制了线条的颜色、宽度等。

4. 设置点

lv_line 的关键操作是设置点。用户需要将直线的各个端点存储在 lv_point_precise_t 数组中,并通过 lv_line_set_points() 函数将这些点传递给线条对象。例如:

lv_point_precise_t points[] = {{5, 10}, {15, 20}, {30, 40}};
lv_line_set_points(line, points, 3);  // 设置直线的3个点

这样,控件就会自动绘制连接这些点的直线。

此外,点的坐标可以使用原始的像素坐标指定(如 {5, 10}),或者使用表示为百分比的坐标。如果使用百分比坐标,您可能需要显式设置线条的宽度和高度,因为百分比值不会自动调整控件的边界。

5. 自动大小

默认情况下,lv_line 控件的宽度和高度会被设置为 LV_SIZE_CONTENT,这意味着控件会根据点的位置自动调整自己的大小以适应所有的点。如果您为控件设置了固定的宽度和高度,可能会导致线条的部分被裁剪掉或无法完全显示。

6. y 坐标反转

在默认情况下,lv_line 控件的 y=0 坐标在控件的顶部。然而,在某些情况下,这种坐标系统可能会显得不直观。例如,当您需要绘制与屏幕坐标系一致的图形时,可能需要反转 y 坐标轴。通过调用 lv_line_set_y_invert(line, true),您可以将 y=0 设置为控件的底部,方便与实际的坐标系保持一致。

7. 事件处理

与其他控件一样,lv_line 控件也支持通用的事件机制。但它本身并不触发特定的事件,通常用于绘制和显示静态图形。事件的处理机制与基础对象相同,可以与其他控件的事件进行联合操作。

8. 示例代码

以下是一个示例,展示如何使用 lv_line 绘制一条简单的直线:

#include "lvgl.h"lv_obj_t *line;void create_line() {line = lv_line_create(lv_scr_act());  // 创建一个线条对象lv_obj_align(line, LV_ALIGN_CENTER, 0, 0);  // 将线条置于屏幕中央// 设置一组点并绘制线条lv_point_precise_t points[] = {{10, 10}, {50, 50}, {100, 100}};lv_line_set_points(line, points, 3);
}int main() {lv_init();create_line();while (1) {lv_task_handler();  // 处理任务}
}

这个示例展示了如何创建一个简单的线条对象,并绘制三点之间的直线。


总结

lv_line 控件是 LittlevGL 提供的一个强大而灵活的工具,用于绘制直线图形。无论是在数据可视化、UI 设计还是路径绘制中,lv_line 都能提供准确和高效的直线绘制功能。通过设置点、调整样式、以及处理坐标和大小,您可以轻松定制和控制线条的外观和行为。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/35463.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

unity打包web,发送post请求,获取地址栏参数,解决TypeError:s.replaceAll is not a function

发送post请求 public string url "http://XXXXXXXXX";// 请求数据public string postData "{\"user_id\": 1}";// Start is called before the first frame updatevoid Start(){// Post();StartCoroutine(PostRequestCoroutine(url, postData…

恒创科技:如何区分网站的域名主机名

如何区分网站的域名主机名?它们都是网址机制的一部分,当你在地址栏输入它们,就能访问互联网上想去的地方。你可曾思考过主机名和域名的区别呢? 简单来说,域名就像网址,而主机名用于标识网络中的设备。不过,这只是表面…

【技巧学习】ArcGIS如何计算水库库容量?

ArcGIS如何计算水库库容量? 一、数据获取 DEM数据来源于地理空间数据云,该网站是由中科院计算机网络信息中心于2008年创立的地学大数据平台。 二、填洼 将DEM数据中凹陷的区域填充至与倾斜点同样高度,这里的【Z限制】说的是设定一个特定的值&#x…

机器学习——感知机模型

文章目录 前言1.感知机模型介绍1.1基本概念1.2数学表达1.3几何解释1.4优缺点 2.二分类应用2.1应用介绍2.2准备数据集2.2.1环境检查2.2.2数据集介绍2.2.3获取数据2.2.4划分数据集 2.3可视化训练集2.4训练过程2.4.1首轮梯度下降2.4.2多轮梯度下降 2.5可视化分类结果2.6在验证集验…

11.20[JAVAEXP3]重定向细究【DEBUG】

设置了根域名访问为testServlet,让他重定向到首页为test.jsp,事实上也都触发了,但是最后显示的为什么不是test.jsp生成页面,依然还是index.jsp生成的页面?? 重定向是通过Dispatcher进行的,而不是sendRedir…

YOLOv11模型改进-注意力-引入卷积和注意力融合模块(CAFM) 提升小目标和遮挡检测

本篇文章将介绍一个新的改进机制——卷积和注意力融合模块CAFM,并阐述如何将其应用于YOLOv11中,显著提升模型性能。首先,CAFM是为了融合卷积神经网络(CNNs)和 Transformer 的优势,同时对全局和局部特征进行…

APM装机教程(五):测绘无人船

文章目录 前言一、元生惯导RTK使用二、元厚HXF260测深仪使用三、云卓H2pro遥控器四、海康威视摄像头 前言 船体:超维USV-M1000 飞控:pix6c mini 测深仪:元厚HXF160 RTK:元生惯导RTK 遥控器:云卓H12pro 摄像头&#xf…

基于MinIO打造高可靠分布式“本地”文件系统

MinIO是一款高性能的对象存储服务,而S3协议是由亚马逊Web服务(AWS)制定的一种标准协议,用于云存储服务之间的数据交换。MinIO与S3协议的关系在于,MinIO实现了S3协议的接口,这意味着用户可以使用与AWS S3相同…

Luma 视频生成 API 对接说明

Luma 视频生成 API 对接说明 随着 AI 的应用变广,各类 AI 程序已逐渐普及。AI 已逐渐深入到人们的工作生活方方面面。而 AI 涉及的行业也越来越多,从最初的写作,到医疗教育,再到现在的视频。 Luma 是一个专业高质量的视频生成平…

基础算法——搜索与图论

搜索与图论 图的存储方式2、最短路问题2.1、Dijkstra算法(朴素版)2.2、Dijkstra算法(堆优化版)2.3、Bellman-Ford算法2.4、SPFA求最短路2.5、SPFA判负环2.6、Floyd算法 图的存储方式 2、最短路问题 最短路问题可以分为单源最短路…

Online Monocular Lane Mapping

IROS 2023 港科大 文章链接:http://arxiv.org/abs/2307.11653 github:GitHub - HKUST-Aerial-Robotics/MonoLaneMapping: Online Monocular Lane Mapping Using Catmull-Rom Spline (IROS 2023) 动机 摆脱高精地图,使用车端的传感器来实现车端…

29.两数相除 python

两数相除 题目题目描述示例 1:示例 2:提示:题目链接 题解解题思路python实现代码解释提交结果 题目 题目描述 给你两个整数,被除数 dividend 和除数 divisor。将两数相除,要求 不使用 乘法、除法和取余运算。 整数除法应该向零截断&#x…

MicroBlaze软核开发(二):GPIO

实现功能:使用 MicroBlaze软核,配置GPIO用拨码开关控制LED灯 Vivado版本:2018.3 目录 引言 vivado部分: 一、配置GPIO 二、生成HDL文件编译 SDK部分: 一、导出硬件启动SDK 二、新建应用程序工程 三、编写程序代…

sdk项目的git 标记新tag的版本号

在 Git 中,tag 是用来标记某个特定的提交点(通常是发布版本或重要的里程碑)的工具。通过 git tag,你可以为版本号创建标记,帮助团队跟踪不同版本的代码。 如果你想创建一个新的版本号标签,可以按照以下步骤…

40分钟学 Go 语言高并发:服务注册与发现

服务注册与发现 一、系统架构设计 让我们先通过流程图了解服务注册与发现的整体架构: 二、核心组件实现 1. 服务注册中心 package discoveryimport ("context""sync""time" )// ServiceInstance 服务实例 type ServiceInstance…

〔 MySQL 〕索引

目录 1. 没有索引,可能会有什么问题 2. 认识磁盘 MySQL与存储 先来研究一下磁盘: 在看看磁盘中一个盘片​编辑 扇区 定位扇区​编辑 结论 磁盘随机访问(Random Access)与连续访问(Sequential Access) 3. MySQL 与磁盘交互基本单位 4. 建立共识…

微信小程序里的小游戏研发需要什么技术栈

研发小程序里的小游戏通常需要以下技术栈: 前端技术 HTML5 / CSS3:用于构建游戏的界面布局和样式。JavaScript:作为核心编程语言,实现游戏的逻辑和交互。小程序开发框架:如微信小程序的开发框架,了解其 API…

php 生产者-消费者实现

一、项目背景 mes报工需求,原项目接口接收产线上位抛来的数据,处理无误后存储在本地,最后抛给工厂接口。 但是有时候工厂数据响应太慢,也导致mes响应给上位变慢,拖慢了mes系统。 现要求,将原接口中抛给工厂…

SpringBoot 解决跨域问题

SpringBoot 解决跨域问题 遇到前端跨域访问问题,类似于这样的: 在Springboot项目里加上这个配置文件CorsConfig.java,重启之后即可实现跨域访问,前端无需再配置跨域。 1、添加跨域工具包CorsConfig 2、写跨域代码 import org.sp…

IO基础(缓冲流)

FileInputStream、FileOutputStream、FileReader、FileWriter属于基础流。 缓冲流是高级流。能够高效的处理数据。原理:底层自带了长度为8192的缓冲区提高性能 字节缓冲流:BufferedInputStream、BufferedOutputStream 字符缓冲流:Buffered…