博客
关于我
Raspberry pi pico|树莓派-pico驱动ILI9341+lvgl(c语言实现)
阅读量:486 次
发布时间:2019-03-07

本文共 3430 字,大约阅读时间需要 11 分钟。

文章目录

前言

前些日子到手了一块raspberry pico和2.2寸屏ILI9341,想通过ILI9341显示屏让pico的实验做起来更加丰富多彩。下图是我的实验成果:

raspberry-pico+ILI9341+lvgl

实验说明

实验中我使用的材料如下:

  • raspberry pico
  • 2.2寸屏ILI9341
  • 滑动变阻器

实验预期效果

pico在2.2寸屏ILI9341显示一个量规实时显示滑动变阻器的数值。

接线

raspberry pico外设资源

接线

测试代码

/** * Copyright (c) 2008-2021 深圳百问网科技有限公司
* * SPDX-License-Identifier: BSD-3-Clause */#include "pico/stdlib.h"#include "hardware/adc.h"#include "lvgl_src/lvgl.h"#include "ili9341/ili9341.h"#include "ili9341/lv_port_disp.h"//extern void ili9341_init();//extern void lv_port_disp_init(void);static void lv_100ask_adc_gauge_anim(lv_obj_t * gauge, lv_anim_value_t value);static void lv_100ask_widget_test_init(void);static void lv_100ask_widget_test_init(void){ lv_anim_t a; // 表盘动画 lv_anim_init(&a); lv_obj_t * adc_gauge = lv_gauge_create(lv_scr_act(), NULL); lv_gauge_set_range(adc_gauge, 0 ,3000); lv_gauge_set_critical_value(adc_gauge, 2400); // 设置临界值,超过临界值部分的颜色为 scale_end_color lv_obj_set_drag_parent(adc_gauge, true); lv_obj_set_size(adc_gauge, 200, 200); lv_obj_align(adc_gauge, NULL, 0, 0, 0); lv_obj_set_style_local_margin_top(adc_gauge, LV_GAUGE_PART_MAIN, LV_STATE_DEFAULT, LV_DPX(30)); lv_obj_set_style_local_value_font(adc_gauge, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, &lv_font_montserrat_14); // 设置文字大小 lv_obj_set_style_local_value_str(adc_gauge, LV_GAUGE_PART_MAIN, LV_STATE_DEFAULT, "ADC"); lv_obj_set_style_local_value_align(adc_gauge, LV_GAUGE_PART_MAIN, LV_STATE_DEFAULT, LV_ALIGN_CENTER); lv_obj_set_style_local_value_ofs_y(adc_gauge, LV_GAUGE_PART_MAIN, LV_STATE_DEFAULT, LV_DPX(80)); lv_obj_t * label = lv_label_create(adc_gauge, NULL); lv_obj_set_style_local_text_font(label, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, &lv_font_montserrat_10); // 设置文字大小 lv_obj_align(label, adc_gauge, LV_ALIGN_CENTER, 0, lv_obj_get_width(adc_gauge)/4); lv_anim_set_var(&a, adc_gauge); lv_anim_set_exec_cb(&a, (lv_anim_exec_xcb_t)lv_100ask_adc_gauge_anim); lv_anim_set_values(&a, 0, 1); lv_anim_set_time(&a, 500); lv_anim_set_repeat_count(&a, LV_ANIM_REPEAT_INFINITE); lv_anim_start(&a);}/* * 函数名: static void lv_100ask_adc_gauge_anim(lv_obj_t * gauge, lv_anim_value_t value) * 输入参数: 动画对象 * 输入参数: 传递给动画的数据 * 返回值: 无 * 函数作用: 更新展示ADC检测值*/static void lv_100ask_adc_gauge_anim(lv_obj_t * gauge, lv_anim_value_t value){ adc_select_input(0); uint adc_value = adc_read(); //adc_value = f_value*1000; lv_gauge_set_value(gauge, 0, adc_value); char tmpchar[32] = {0}; lv_snprintf(tmpchar, sizeof(tmpchar), "AD:%d\nVoltage:%f v", adc_value, (float)(adc_value * (3.3 / 4096))); lv_obj_t * label = lv_obj_get_child(gauge, NULL); lv_label_set_text(label, tmpchar); lv_obj_align(label, gauge, LV_ALIGN_IN_BOTTOM_MID, 0, -lv_obj_get_height(label)); }int main() { stdio_init_all(); // possibly set ili9341_config parameters if your pins/spi port don't match ili9341_init(); lv_init(); lv_port_disp_init(); adc_init(); // Make sure GPIO is high-impedance, no pullups etc adc_gpio_init(26); //lv_obj_t * scr = lv_obj_create(NULL, NULL); //lv_scr_load(scr); lv_100ask_widget_test_init(); while (true) { sleep_ms(5); /*Sleep for 5 millisecond*/ lv_task_handler(); lv_tick_inc(5); /*Tell LVGL that 5 milliseconds were elapsed*/ }}

LVGL中文手册

官方的教程是英文的,这个是我在做项目时顺便做出来的中文教程站点(持续更新维护),不仅仅只是照搬lvgl官方文档的翻译,同时总结了我们在实际开发中遇到的各种细节,让这个文档更加适合我们在实际开发中的需求。

  • lvgl官方原版教程:
  • lvgl中文教程(中文手册):

lvgl中文教程主页

转载地址:http://gdzcz.baihongyu.com/

你可能感兴趣的文章
mysql_secure_installation初始化数据库报Access denied
查看>>
MySQL_西安11月销售昨日未上架的产品_20161212
查看>>
Mysql——深入浅出InnoDB底层原理
查看>>
MySQL“被动”性能优化汇总
查看>>
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>
mysql一个字段为空时使用另一个字段排序
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>
Mysql下载以及安装(新手入门,超详细)
查看>>
MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
查看>>
MySQL不同字符集及排序规则详解:业务场景下的最佳选
查看>>
Mysql不同官方版本对比
查看>>
MySQL与Informix数据库中的同义表创建:深入解析与比较
查看>>
mysql与mem_细说 MySQL 之 MEM_ROOT
查看>>
MySQL与Oracle的数据迁移注意事项,另附转换工具链接
查看>>
mysql丢失更新问题
查看>>