ocGUI编写(4)--软件辅助图形解码

上面是我的微信和QQ群,欢迎新朋友的加入。

这个功能还在做,现在只做了解码IMG2LCD的数据,本来想做BMP解码,发现在开发板上FATFS没跑起来

先看实物图,照片看起来有点发白,实际上跟原图是差不多的

ocDrawImg2lcd(300,100,gImage_123);

使用很简单,直接用IMG2LCD转换就行,程序做数据解码

下面是程序接口:

/**********************************************
 * @brief :显示一个输入图形数组
 * @param : Xpos:      图片显示左上角X轴位置
 * @param : Ypos:      图片显示左上角Y轴位置
 * @param : pic:       图像数组
 * @note  :使用IMG2LCD软件转换,要包含图像头数据
 * @retval: 绘制成功返回oc_OK,失败返回oc_ON
**********************************************/
uint8_t ocDrawImg2lcd(uint16_t Xpos, uint16_t Ypos,const char *pic);

看这个解码网上资源不是很多,我分享一下

/**********************************************
 * @brief :显示一个输入图形数组
 * @param : Xpos:      图片显示左上角X轴位置
 * @param : Ypos:      图片显示左上角Y轴位置
 * @param : pic:       图像数组
 * @note  :使用IMG2LCD软件转换,要包含图像头数据
 * @retval: 绘制成功返回oc_OK,失败返回oc_ON
**********************************************/
uint8_t ocDrawImg2lcd(uint16_t Xpos, uint16_t Ypos,const char *pic)
{
	uint32_t picW=0,picH=0,showW = 0,showH = 0;//图片尺寸信息
	uint32_t arrayLen,showLen = 8;
	uint8_t dataBit;
	
	//数组协议,前八个数据包含数据信息
	//bit0:
		//0:0水平扫描,1垂直扫描
		//4:字序 0 高位在后 1 高位在前
		//6:垂直方向 0 顶-->底 1 顶<-- 底
	  //7:水平方向 0 左到右  1 右到左
	//bit1:0x04--16灰,0x10--16位真彩色,0x12--18位真彩色,0x18--24位真彩色,0x20--32位真彩色;
	//bit2~bit5:
		//第3~6个字节表示宽和高,假设图片数组BMP_BUF[],高位在前时
		//bmp_withd=BMP_BUF[2]|BMP_BUF[3]<<8
		//bmp_lenth=BMP_BUF[4]|BMP_BUF[5]<<8
		//数组大小 =  bmp_withd x bmp_lenth x (位数/8) + [ 8(包含头信息时)]
	//bit6:代表颜色数据的排列方式: 0 --- 565; 1 – 555; (16位真色彩)
	picW = pic[2] | (pic[3]<<8);//获取图片宽度
	picH = pic[4] | (pic[5]<<8);//获取图片高度
	dataBit = pic[1]/8;//计算数据位数
	arrayLen = picW*picH*dataBit;
	
	if(!pic[0])//水平扫描方式
	{
		while(showLen < arrayLen)
		{
			ocFontSet.textColor = 
								((pic[showLen]&0x000000ff)|
								((pic[showLen+1]&0x000000ff)<<8)|
								((pic[showLen+2]&0x000000ff)<<16));
			
			ocPutDot(showW + Xpos,showH + Ypos);
			showW++;
			if(showW >= picW)
			{
				showW = 0;
				showH++;
			}
			showLen += dataBit;
		}
	}
	else//垂直扫描方式
	{
		while(showLen < arrayLen)
		{
			ocFontSet.textColor = 
								((pic[showLen]&0x000000ff)|
								((pic[showLen+1]&0x000000ff)<<8)|
								((pic[showLen+2]&0x000000ff)<<16));
			
			ocPutDot(showW + Xpos,showH + Ypos);
			showH++;
			if(showH >= picH)
			{
				showH = 0;
				showW++;
			}
			showLen += dataBit;
		}
	}
		
	return oc_OK;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值