本文介绍: 单片机如何 控制RA8889, 驱动 彩色液晶屏 显示图片?显示JPG? 显示PNG? 请看下文分解。

单片机驱动TFT彩色液晶屏系列讲座

目录

第一讲 单片机最小系统STM32F103C6T6通过RA8889驱动彩色液晶屏播放视频
第二讲 单片机最小系统STM32F103C6T6控制RA8889驱动彩色液晶屏硬件框架
第三讲 单片机驱动彩色液晶屏 控制RA8889软件:如何初始化
第四讲 单片机驱动彩色液晶屏 控制RA8889软件:绘图
第五讲 单片机驱动彩色液晶屏 控制RA8889软件:显示文字:Part1.内部字库
第六讲 单片机驱动彩色液晶屏 控制RA8889软件:显示文字:Part2.外接字库
第七讲 单片机驱动彩色液晶屏 控制RA8889软件:显示文字:Part3.自建字库
第八讲 单片机驱动彩色液晶屏 控制RA8889软件:显示图片
第九讲 单片机驱动彩色液晶屏 控制RA8889软件:显存操作
第十讲 单片机驱动彩色液晶屏 控制RA8889软件:图像运算
第十一讲 单片机驱动彩色液晶屏 控制RA8889软件:播放avi视频
第十二讲 单片机驱动彩色液晶屏 如何打包bin档
第十三讲单片机驱动彩色液晶屏 bin档的烧录方法

下面我们开始介绍如何显示图片了!一般情况图资建议存放在RA8889 / RA8876扩展的FLASH芯片,容量可依据实际需求来做选择。

显示图片有如下几种方式:
在这里插入图片描述

RA8889是支持QPI(Quad Peripheral Interface)通信方式,这可大大加快DMA速度,图片显示速度很快!同时结合JPG硬件解码,图片显示速度又再提高一个数量级,相当强大的功能!

显示BMP图片的API代码:

void DMA_24bit(unsigned char Clk ,unsigned short X1,unsigned short Y1,unsigned short X_W,unsigned short Y_H ,unsigned short P_W ,unsigned long Addr);
void DMA_32bit(unsigned char Clk ,unsigned short X1,unsigned short Y1,unsigned short X_W,unsigned short Y_H ,unsigned short P_W,unsigned long Addr);
采用DMA方式显示BMP图片

实现方法是MCU将要调用图片的宽高和地址发送给RA8889,尔后交给RA8889从FLASH内部连续获取图片数据,过程不需要MCU干预了,因此显示速度很快,若采用QPI通信则更快了!

显示JPG图片的API代码:

void JPG_NOR (unsigned long addr,unsigned long JPGsize,unsigned long IDEC_canvas_width,unsigned short x,unsigned short y);
采用MCU直接写入BMP图片

BMP图片还可以从MCU直接写入,直接写入的数据是存在MCU的FLASH中,这种方法速度比较慢,小的图片、图标可行,太大要考虑速度是否可接受了,再者图片大也可能存不进FLASH。

MCU写入图片调用的API函数如下:

void BTE_MCU_Write_MCU_8bit(unsigned long S1_Addr,unsigned short S1_W,unsigned short XS1,unsigned short YS1,unsigned long Des_Addr,unsigned short Des_W, unsigned short XDes,unsigned short YDes,unsigned int ROP_Code,unsigned short X_W,unsigned short Y_H,const unsigned char *data);
void BTE_MCU_Write_MCU_16bit(unsigned long S1_Addr,unsigned short S1_W,unsigned short XS1,unsigned short YS1,unsigned long Des_Addr,unsigned short Des_W, unsigned short XDes,unsigned short YDes,unsigned int ROP_Code,unsigned short X_W,unsigned short Y_H,const unsigned short *data);
显示JPG图片

JPG图片的显示也很简单,自动选择QPI通信方式,由于JPG数据经过压缩,容量是BMP图片的10%左右,再加上采用QPI获取数据,显示图片速度相比BMP图片会有一个指数级的提高。

也因此RA8889还支持AVI影片的播放,这部份内容在后文再作介绍。

显示PNG图片

PNG图片的显示类似BMP,不一样的是显存要先指定一个Buffer空间,用于处理透明色,处理完之后再复制到指定位置。

显示PNG图片的API代码:

void SPI_NOR_DMA_png (unsigned long dma_page_addr,unsigned long pic_buffer_Layer,unsigned long Show_pic_Layer,unsigned int picture_Width,unsigned int picture_Height);
显示图形光标

图形光标的显示会有点不同,RA8889内建4个32×32点阵可自定义的图形光标,建好的图形光标可类似桌面系统的光标(比如鼠标形状)自由指定坐标,光标是显示在另外一个图层。

图形光标实例演示:

图形光标效果演示

图形光标演示代码:

//文字光标演示
	Enable_Text_Cursor_Blinking();
	Blinking_Time_Frames(10);
	Text_Cursor_H_V(15,1);
	Enable_Text_Cursor();
	delay_seconds(1);
	Show_String("d");	delay_ms(300);
	Show_String("i");	delay_ms(300);
	Show_String("r");	delay_ms(300);
	Show_String(" ");	delay_ms(1000);
	for(i=0;i<14;i++)
	{
		delay_ms(300);
		Text_Cursor_H_V(15-i,1+i);	 
	}
	delay_seconds(3);
	Disable_Text_Cursor();
	
	BTE_Solid_Fill(0,canvas_image_width,0,32+24+4+28+20+28+28+20+28+108+28+24,0x4410,LCD_width,83);
	Foreground_color_65k(White); 
	Goto_Text_XY(0,32+24+4+28+20+28+28+20+28+108+28+24);
	Show_String("Demo graphic cursor:");

	CGROM_Select_Internal_CGROM();	//选择内部字库
	Font_Select_12x24_24x24();
	Set_Graphic_Cursor_Color_1(0xff);
	Set_Graphic_Cursor_Color_2(0x00);

	Graphic_cursor_initial();		//内部图形光标
	Graphic_Cursor_XY(0,32+24+4+28+20+28+28+20+28+108+28+28+28);
	Select_Graphic_Cursor_1();  
	delay_ms(1000);
	Select_Graphic_Cursor_2();
	delay_ms(1000);
	Select_Graphic_Cursor_3();
	delay_ms(1000);
	Select_Graphic_Cursor_4();
	delay_ms(1000);
	Select_Graphic_Cursor_1(); 
	
	for(j=0;j<6;j++)
	{
		for(i=0;i<800;i++)
		{
			Graphic_Cursor_XY(i,32+24+4+28+20+28+28+20+28+108+28+28+28-j*50);	
			delay_ms(3);   
	   }
	}
	Graphic_Cursor_XY(0,32+24+4+28+20+28+28+20+28+108+28+28+28);	
	delay_seconds(3);
	Disable_Graphic_Cursor();
BMP图片格式

补充一些说明,BMP图片即原图无压缩,每一个点是由RGB三个像素构成,如果是24位,则RGB为8:8:8,即3个字节表示一个点。我们画图软件描一张图,仅红绿蓝三个点:
在这里插入图片描述

用转档软件(ImageTool等软件)取出来点阵数据就可以烧进FLASH使用,我们可以打开查看数据的二进制内容如下图,前三个字节为取出来是0xFF0000,即表示红色;接下来是0x00FF00表示绿色;最后一个是0x0000FF表示蓝色。注意数据是LSB->MSB存放,因此倒过来拼在一起。
在这里插入图片描述
如果是16位,则RGB为5:6:5,即2个字节表示一个点。我们再打开查看数据的二进制内容如下图,前两个字节为取出来是0xF800,即表示红色;接下来是0x07E0表示绿色;最后一个是0x001F表示蓝色。在这里插入图片描述

如果是8位,则RGB为3:3:2,即1个字节表示一个点。我们再打开查看数据的二进制内容如下图,第一个字节为取出来是0xE0,即表示红色;接下来是0x1C表示绿色;最后一个是0x03表示蓝色。
在这里插入图片描述

BMP图片存入FLASH的格式即如此,RA8889 / RA8876进行DMA调用就是一点一点读取,然后再写入显存。

液晶屏初始化是8位色、16位色或者24位色,那么也只能显示相应位深的图片,实际使用时打包图片数据要注意选择好,使图片数据格式与初始化的格式一致。

关于显存,下一章节再进行介绍。

第八讲 THE END

了解更多信息:http://www.lcdvision.com.cn

原文地址:https://blog.csdn.net/weixin_43307086/article/details/135474330

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。

如若转载,请注明出处:http://www.7code.cn/show_55992.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注