K230 CanMV Lcd模块API手册#

cover

版权所有©2023北京嘉楠捷思信息技术有限公司

免责声明#

您购买的产品、服务或特性等应受北京嘉楠捷思信息技术有限公司(“本公司”,下同)及其关联公司的商业合同和条款的约束,本文档中描述的全部或部分产品、服务或特性可能不在您的购买或使用范围之内。除非合同另有约定,本公司不对本文档的任何陈述、信息、内容的正确性、可靠性、完整性、适销性、符合特定目的和不侵权提供任何明示或默示的声明或保证。除非另有约定,本文档仅作为使用指导参考。

由于产品版本升级或其他原因,本文档内容将可能在未经任何通知的情况下,不定期进行更新或修改。

商标声明#

logo、“嘉楠”和其他嘉楠商标均为北京嘉楠捷思信息技术有限公司及其关联公司的商标。本文档可能提及的其他所有商标或注册商标,由各自的所有人拥有。

版权所有 © 2023北京嘉楠捷思信息技术有限公司。保留一切权利。 非经本公司书面许可,任何单位和个人不得擅自摘抄、复制本文档内容的部分或全部,并不得以任何形式传播。

目录#

[TOC]

前言#

概述#

此文档介绍CanMV lcd模块,用以指导开发人员如何调用MicroPython API实现图像输出功能。

读者对象#

本文档(本指南)主要适用于以下人员:

  • 技术支持工程师

  • 软件开发工程师

缩略词定义#

简称

说明

VO

Video Output

DSI

Display Serial Interface

修订记录#

文档版本号

修改说明

修改者

日期

V1.0

初版

赵忠祥

2024-04-25

1. 概述#

此文档介绍CanMV lcd模块,用以指导开发人员如何调用Micro Python API实现图像输出功能。

2. API描述#

2.1 lcd.init#

【描述】

初始化整个lcd通路,包括VO模块、DSI模块、LCD/HDMI

【语法】

lcd.init(type)

【参数】

参数名称

描述

输入/输出

type

输出接口参数

输入

【返回值】

返回值

描述

0

成功。

非 0

失败,其值为[错误码]

【注意】

【举例】

【相关主题】

2.2 lcd.set_backlight#

【描述】

设置LCD背光

【语法】

lcd.set_backlight(level)

【参数】

参数名称

描述

输入/输出

level

0:关闭LCD背光;1:打开LCD背光

输入

【返回值】

返回值

描述

0

成功。

非 0

失败,其值为[错误码]

【注意】

set_backlight仅适用于LCD输出

【举例】

【相关主题】

2.3 lcd.set_plane#

【描述】

设置VO通道参数,set_plane方法主要用来设置和Camera、vdec、DPU、AI2D绑定的VO通道

【语法】

lcd.set_plane(x, y, width, height, pixelformat, rotate, chn, mirror)

【参数】

参数名称

描述

输入/输出

x

起始坐标的x值

输入

y

起始坐标的y值

输入

width

宽度

输入

height

高度

输入

pixelformat

像素格式

输入

rotate

顺时针旋转功能

输入

chn

VO通道

输入

mirror

翻转功能

输入

【返回值】

返回值

描述

0

成功。

非 0

失败,其值为[错误码]

【注意】

只有DISPLAY_CHN_VIDEO1通道支持rotate功能和mirror功能

【举例】

【相关主题】

2.4 lcd.display#

【描述】

输出image到VO通道

【语法】

lcd.display(image, x, y, chn)

【参数】

参数名称

描述

输入/输出

image

待输出的图像

输入

x

起始坐标的x值

输入

y

起始坐标的y值

输入

chn

VO通道

输入

【返回值】

返回值

描述

0

成功。

非 0

失败,其值为[错误码]

【注意】

【举例】

【相关主题】

2.5 lcd.disable_plane#

【描述】

关闭VO通道

【语法】

lcd.disable_plane(chn)

【参数】

参数名称

描述

输入/输出

chn

VO通道

输入

【返回值】

返回值

描述

0

成功。

非 0

失败,其值为[错误码]

【注意】

通过disable_plane方法关闭的VO通道,可以通过set_plane方法或者display方法重新打开

【举例】

【相关主题】

2.6 lcd.deinit#

【描述】

执行反初始化,deinit方法会关闭整个lcd通路,包括VO模块、DSI模块、LCD/HDMI

【语法】

lcd.deinit()

【返回值】

返回值

描述

0

成功。

非 0

失败,其值为[错误码]

【注意】

【举例】

【相关主题】

3. 数据结构描述#

3.1 type#

【说明】

输出接口参数

【定义】

【成员】

成员名称

描述

HX8377_1080X1920_30FPS

VO和DSI模块输出1080X1920 30FPS时序到LCD

ST7701_V1_MIPI_2LAN_480X800_30FPS

VO和DSI模块输出480x800 30FPS时序到LCD

LT9611_1920X1080_30FPS

VO和DSI模块输出1920X1080 30FPS时序到HDMI

LT9611_MIPI_4LAN_1920X1080_60FPS

VO和DSI模块输出1920X1080 60FPS时序到HDMI

LT9611_MIPI_4LAN_1280X720_60FPS

VO和DSI模块输出1280x720 60FPS时序到HDMI

LT9611_MIPI_4LAN_1280X720_50FPS

VO和DSI模块输出1280x720 50FPS时序到HDMI

LT9611_MIPI_4LAN_1280X720_30FPS

VO和DSI模块输出1280x720 30FPS时序到HDMI

LT9611_MIPI_4LAN_640X480_60FPS

VO和DSI模块输出640x480 30FPS时序到HDMI

【注意事项】

3.2 chn#

【说明】

VO通道

【定义】

【成员】

成员名称

描述

DISPLAY_CHN_VIDEO1

VO模块video 1 通道,支持DISPLAY_OUT_NV12输出

DISPLAY_CHN_VIDEO2

VO模块video 2 通道,支持DISPLAY_OUT_NV12输出

DISPLAY_CHN_OSD0

VO模块OSD 0 通道,支持DISPLAY_OUT_ARGB8888、DISPLAY_OUT_RGB888、DISPLAY_OUT_RGB565输出

DISPLAY_CHN_OSD1

VO模块OSD 1 通道,支持DISPLAY_OUT_ARGB8888、DISPLAY_OUT_RGB888、DISPLAY_OUT_RGB565输出

DISPLAY_CHN_OSD2

VO模块OSD 2 通道,支持DISPLAY_OUT_ARGB8888、DISPLAY_OUT_RGB888、DISPLAY_OUT_RGB565输出

DISPLAY_CHN_OSD3

VO模块OSD 3 通道,支持DISPLAY_OUT_ARGB8888、DISPLAY_OUT_RGB888、DISPLAY_OUT_RGB565输出

【注意事项】

只有DISPLAY_CHN_VIDEO1通道支持rotate功能和mirror功能

3.3 pixelformat#

【说明】

像素格式

【定义】

【成员】

成员名称

描述

DISPLAY_OUT_NV12

输出NV12

DISPLAY_OUT_ARGB8888

输出ARGB8888

DISPLAY_OUT_RGB888

输出RGB888

DISPLAY_OUT_RGB565

输出RGB565

【注意事项】

3.4 mirror#

【说明】

水平方向和垂直方向镜像翻转功能

【定义】

【成员】

成员名称

描述

DISPLAY_ROTATE_0

不进行旋转

DISPLAY_ROTATE_90

顺时针旋转90度

DISPLAY_ROTATE_180

顺时针旋转180度

DISPLAY_ROTATE_270

顺时针旋转270度

DISPLAY_MIRROR_NONE

不进行翻转

DISPLAY_MIRROR_HOR

水平方向翻转180度

DISPLAY_MIRROR_VER

垂直方向翻转180度

DISPLAY_MIRROR_BOTH

水平方向和垂直方向都翻转180度

【注意事项】

4. 示例程序#

例程


from media.lcd import *
from media.media import *
import time, os, urandom, sys

DISPLAY_WIDTH = ALIGN_UP(1920, 16)
DISPLAY_HEIGHT = 1080

def lcd_test():
    print("lcd test")
    # use hdmi for lcd
    lcd.init(LT9611_1920X1080_30FPS)  // 实始化lcd
    # config vb for osd layer
    config = k_vb_config()            // 配置内存
    config.max_pool_cnt = 1
    config.comm_pool[0].blk_size = 4*DISPLAY_WIDTH*DISPLAY_HEIGHT
    config.comm_pool[0].blk_cnt = 1
    config.comm_pool[0].mode = VB_REMAP_MODE_NOCACHE
    # meida buffer config
    media.buffer_config(config)
    # media buffer init
    media.buffer_init()
    # request media buffer for osd image
    globals()["buffer"] = media.request_buffer(4 * DISPLAY_WIDTH * DISPLAY_HEIGHT)

    # create image for drawing
    img = image.Image(DISPLAY_WIDTH, DISPLAY_HEIGHT, image.ARGB8888)
    # create image for osd
    buffer = globals()["buffer"]
    osd_img = image.Image(DISPLAY_WIDTH, DISPLAY_HEIGHT, image.ARGB8888, alloc=image.ALLOC_VB, phyaddr=buffer.phys_addr, virtaddr=buffer.virt_addr, poolid=buffer.pool_id)
    osd_img.clear()
    lcd.display(osd_img, 0, 0, DISPLAY_CHN_OSD0) // 显示
    try:
        while True:
            img.clear()
            for i in range(10):
                x = (urandom.getrandbits(11) % img.width())
                y = (urandom.getrandbits(11) % img.height())
                r = (urandom.getrandbits(8))
                g = (urandom.getrandbits(8))
                b = (urandom.getrandbits(8))
                # If the first argument is a scaler then this method expects
                # to see x, y, and text. Otherwise, it expects a (x,y,text) tuple.
                # Character and string rotation can be done at 0, 90, 180, 270, and etc. degrees.
                img.draw_string(x, y, "Hello World!", color = (r, g, b), scale = 2, mono_space = False,
                                char_rotation = 0, char_hmirror = False, char_vflip = False,
                                string_rotation = 0, string_hmirror = False, string_vflip = False) // 绘图
            img.copy_to(osd_img)
            time.sleep(1)
            os.exitpoint()
    except KeyboardInterrupt as e:
        print("user stop: ", e)
    except BaseException as e:
        sys.print_exception(e)

    # deinit lcd
    lcd.deinit()
    os.exitpoint(os.EXITPOINT_ENABLE_SLEEP)
    time.sleep_ms(100)
    # release media buffer
    media.release_buffer(globals()["buffer"])
    # deinit media buffer
    media.buffer_deinit()

if __name__ == "__main__":
    os.exitpoint(os.EXITPOINT_ENABLE)
    lcd_test()