ESP32(MicroPython) LVGL多功能显示

ESP32(MicroPython)LVGL多功能显示

本程序显示内容与本人之前发布的TFT LCD多功能显示程序相似,显示日期、时间以及BMP280的温度、气压、高度读数。增加了图片显示。

本程序在由于按钮用于显示字符,为了方便更新字符内容,按钮不封装为类。图片仍然封装为类。图片显示实测只能到176*99分辨率,192*108分辨率的会出现内存分配不足的情况,如果更改固件的设定可能解决这一问题(实际上只使用了开发板的小部分内存)。

代码如下

import lvgl as lv
import time
from espidf import VSPI_HOST
from ili9XXX import ili9341
from xpt2046 import xpt2046
from machine import Pin
from machine import SoftI2C
from machine import RTC
import DS1302
import bmp280

# ------------------------------ 屏幕初始化操作 --start------------------------
# 屏幕宽高
WIDTH = 240
HEIGHT = 320


# 创建显示屏对象
disp = ili9341(miso=19, mosi=23, clk=18, cs=5, dc=26, rst=27, power=14, backlight=-1, backlight_on=0, power_on=0, rot=0x80,
        spihost=VSPI_HOST, mhz=60, factor=16, hybrid=True, width=WIDTH, height=HEIGHT,
        invert=False, double_buffer=True, half_duplex=False, initialize=True)

# 创建触摸屏对象
touch = xpt2046(cs=25, spihost=VSPI_HOST, mosi=-1, miso=-1, clk=-1, cal_y0 = 423, cal_y1=3948)
# ------------------------------ 屏幕初始化操作 --stop------------------------

#定义RTC控制对象
rtc=RTC()
#定义DS1302控制对象
ds1302=DS1302.DS1302(clk=Pin(13),dio=Pin(12),cs=Pin(15))
#定义星期
week=("Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday")
#初始化BMP280,定义第二个I2C接口i2c2用于连接BMP280
i2c2 = SoftI2C(sda=Pin(22), scl=Pin(21))
BMP = bmp280.BMP280(i2c2)

rtc_time=rtc.datetime()
ds_time=ds1302.DateTime()
if rtc_time[0]==ds_time[0] : #在电脑启动时会自动校准RTC,判断RTC时间没有重置时同步校准DS1302
    ds1302.DateTime([rtc_time[0],rtc_time[1],rtc_time[2],rtc_time[3],rtc_time[4],rtc_time[5],rtc_time[6]])
if rtc_time[0]!=ds_time[0] : #如果程序上电启动,RTC会因断电重置,此时用DS1302校准RTC
    rtc.datetime((ds_time[0],ds_time[1],ds_time[2],ds_time[3],ds_time[4],ds_time[5],ds_time[6],0))    

# 1. 创建显示screen对象。将需要显示的组件添加到这个screen才能显示
scr = lv.obj()

# 2. 封装要显示的组件
class MyWidget():
    def __init__(self, scr):
        # Create an image from the png file
        try:
            with open('./image.jpg', 'rb') as f:
                png_data = f.read()
        except:
            print("找不到图片文件...")
            sys.exit()

        img = lv.img_dsc_t({"data_size": len(png_data),"data": png_data})

        # 创建样式
        img_style = lv.style_t()
        img_style.init()
        # 设置背景颜色,圆角
        img_style.set_radius(5)
        img_style.set_bg_opa(lv.OPA.COVER)
        img_style.set_bg_color(lv.palette_lighten(lv.PALETTE.GREY, 3))
        # 设置边框以及颜色
        img_style.set_border_width(2)
        img_style.set_border_color(lv.palette_main(lv.PALETTE.BLUE))

        # 创建lvgl中的图片组件
        obj = lv.img(scr)
        # 添加图片数据
        obj.set_src(img)
        # 添加样式
        obj.add_style(img_style, 0)

        # 设置图片位置
        obj.align(lv.ALIGN.CENTER,0,-90)  # 距屏幕中心偏移量

btn1 = lv.btn(scr)  # 将当前按钮与screen对象进行关联
btn1.set_size(180, 30)  # 设置按钮的宽度为120, 高度为50
btn1.align(lv.ALIGN.CENTER,0,-10)  # 距屏幕中心偏移量
label1 = lv.label(btn1)  # 在按钮上创建一个标签Label,用来显示文字用
label1.set_text("Button")  # 设置文字内容
label1.center()  # 相对于父对象居中

btn2 = lv.btn(scr)  # 将当前按钮与screen对象进行关联
btn2.set_size(120, 30)  # 设置按钮的宽度为120, 高度为50
btn2.align(lv.ALIGN.CENTER,0,25)  # 距屏幕中心偏移量
label2 = lv.label(btn2)  # 在按钮上创建一个标签Label,用来显示文字用
label2.set_text("Button")  # 设置文字内容
label2.center()  # 相对于父对象居中

btn3 = lv.btn(scr)  # 将当前按钮与screen对象进行关联
btn3.set_size(180, 30)  # 设置按钮的宽度为120, 高度为50
btn3.align(lv.ALIGN.CENTER,0,65)  # 距屏幕中心偏移量
label3 = lv.label(btn3)  # 在按钮上创建一个标签Label,用来显示文字用
label3.set_text("Button")  # 设置文字内容
label3.center()  # 相对于父对象居中

btn4 = lv.btn(scr)  # 将当前按钮与screen对象进行关联
btn4.set_size(180, 30)  # 设置按钮的宽度为120, 高度为50
btn4.align(lv.ALIGN.CENTER,0,100)  # 居中(第1个0表示x的偏移量,第2个0表示相对于y的偏移量)
label4 = lv.label(btn4)  # 在按钮上创建一个标签Label,用来显示文字用
label4.set_text("Button")  # 设置文字内容
label4.center()  # 相对于父对象居中

btn5 = lv.btn(scr)  # 将当前按钮与screen对象进行关联
btn5.set_size(180, 30)  # 设置按钮的宽度为120, 高度为50
btn5.align(lv.ALIGN.CENTER,0,135)  # 居中(第1个0表示x的偏移量,第2个0表示相对于y的偏移量)
label5 = lv.label(btn5)  # 在按钮上创建一个标签Label,用来显示文字用
label5.set_text("Button")  # 设置文字内容
label5.center()  # 相对于父对象居中

# 3. 创建要显示的组件
MyWidget(scr)
# 4. 显示screen对象中的内容
lv.scr_load(scr)

try:
    from machine import WDT
    wdt = WDT(timeout=2000)  # enable it with a timeout of 2s
    print("提示: 按下Ctrl+C结束程序")
    while True:
        wdt.feed()
        rtc_time=rtc.datetime()
        label1.set_text(str(rtc_time[0])+'-'+str(rtc_time[1])+'-'+str(rtc_time[2])+'  '+str(week[rtc_time[3]]))  # 修改文字内容
        label2.set_text(str(rtc_time[4])+' : '+str(rtc_time[5])+' : '+str(rtc_time[6]))
        label3.set_text('Temperature: '+str(BMP.getTemp())+' C')
        label4.set_text('Pressure: '+str(BMP.getPress()) + ' Pa')
        label5.set_text('Altitude: '+str(BMP.getAltitude()) + ' M')
        time.sleep(0.9)
except KeyboardInterrupt as ret:
    print("程序停止运行,ESP32已经重启...")

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

路易斯720

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值