本文主要是介绍解决OpenMV非官方LCD显示,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
以下代码可以解决花屏,就是屏幕被分割的情况,但是并不能够解决完全能解决,屏幕起码能看,额,最好的方式就是改变驱动。之后再说。感谢一位友的分享。
# SPI 控制
#
# 这个例子展示了,如何使用OpenMV的SPI总线
# LCD 扩展板没有使用内置的lcd驱动。而是使用了SPI。
# 需要插入LCD扩展板来运行这个例子import sensor, image, time
from pyb import Pin, SPIcs = Pin("P3", Pin.OUT_OD)
rst = Pin("P7", Pin.OUT_PP)
rs = Pin("P8", Pin.OUT_PP)
# # OpenMV上的硬件SPI总线都是2# 注意:SPI时钟频率将不总是所请求的频率。
# 硬件仅支持总线频率除以预分频器的频率(可以是2、4、8、16、32、64、128或256)。
spi = SPI(2, SPI.MASTER, baudrate=int(1000000000), polarity=0, phase=0)def write_command_byte(c):cs.low()rs.low()spi.send(c)cs.high()def write_data_byte(c):cs.low()rs.high()spi.send(c)cs.high()def write_command(c, *data):write_command_byte(c)if data:for d in data: write_data_byte(d)def write_image(img):cs.low()rs.high()spi.send(img)cs.high()def lcd2():write_command(0x2a)write_data_byte(0x00)write_data_byte(0x02)write_data_byte(0x00)write_data_byte(0x81)write_command(0x2b)write_data_byte(0x00)write_data_byte(0x01)write_data_byte(0x00)write_data_byte(0xa0)write_command(0x2c)# 重启
rst.low()
rst.high()write_command(0x11) # Sleep Exit 退出休眠# 存储器数据存取控制
# 写0xC8设置为BGR模式
write_command(0x36, 0xC0)# 设置 Pixel Format 接口
write_command(0x3A, 0x05)# 开启显示
write_command(0x29)sensor.reset() # 初始化摄像头感光元件
sensor.set_pixformat(sensor.RGB565) # 必须这样写
sensor.set_framesize(sensor.QQVGA2) # must be this
sensor.skip_frames(time = 2000) # 让新设置生效
clock = time.clock() # 跟踪FPS帧率while(True):clock.tick() # 跟踪snapshots()之间经过的毫秒数img = sensor.snapshot() # 拍一张照片并返回图像write_command(0x2C) # 编写图像命令lcd2()write_image(img)print(clock.fps())
这篇关于解决OpenMV非官方LCD显示的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!