昨晚疯狂的打了一夜的LOL,感觉L多了,今天一天精神萎靡.还是继续把显示字符给看了,可是在犹豫要不要写这篇文章

事实上写的东西也就是copy别人家的代码,不想写那么多,就记录下自己困惑的地方吧.也许改天回来看的时候能让自己高速的明确

也也许能帮助到有些朋友..

看了奋斗给的样例和偷偷去下了正点原子的样例,事实上都是差点儿相同的,仅仅要略微改下都能够通用的,原理就在那里,跑不了.

奋斗给的样例,都是人家的

void lcd_wr_zf(u16 StartX, u16 StartY, u16 X, u16 Y, u16 Color, u8 Dir, u8 *chr)
{ unsigned int temp=0,num,R_dis_mem=0,Size=0,x=0,y=0,i=0; if(Dir==2) LCD_WR_CMD(0x0003,0x1010); //图像显示方向为右下起 行递减 列递增 AM=0 I/D[1:0]=00 <--
else if(Dir==3) LCD_WR_CMD(0x0003,0x1028); //图像显示方向为右上起 行递减 列递增 AM=1 I/D[1:0]=10 V
if(Dir==0){
LCD_WR_CMD(0x0003,0x1030); //图像显示方向为左上起 行递增 列递增 AM=0 I/D[1:0]=11 -->
LCD_WR_CMD(0x0210, StartX); //水平显示区起始地址 0-239
LCD_WR_CMD(0x0211, StartX+X-1); //水平显示区结束地址 0-239
LCD_WR_CMD(0x0212, StartY); //垂直显示区起始地址 0-399
LCD_WR_CMD(0x0213, StartY+Y-1); //垂直显示区结束地址 0-399
LCD_WR_CMD(0x0200, StartX); //水平显示区地址
LCD_WR_CMD(0x0201, StartY); //垂直显示区地址
LCD_WR_REG(0x0202); //准备写数据显示区
Size=X*Y; //字符串或字符占用的像素尺寸
while(i<Size){
temp=*chr++; //一个字节代表8个像素,因此加1代表索引到下8个像素
for(num=0; num<8; num++){ //数组的每一个字节代表了8个像素
if((temp&0x80)>0){ //对字节的各位进行推断,为1的用带入參数的16位颜色值标示,写入到像素位置。 LCD_WR_Data(Color);
}
else{
LCD_WR_CMD(0x0200, StartX+x); //水平显示区地址
LCD_WR_CMD(0x0201, StartY+y); //垂直显示区地址
LCD_WR_REG(0x0202); //准备读数据显示区
R_dis_mem=LCD_RD_data(); //读取背景色,为叠加产生透明效果作准备
LCD_WR_Data(R_dis_mem); //对字节的各位进行推断。为0的用当前背景像素16位颜色值标示。
}
temp=temp<<1; //字节各位的移出
x++;
if(x>=X){x=0; y++;} //计算像素递增为当前的x和y,为当前像素读背景颜色做准备
i++;
} }
}
else if(Dir==1){
LCD_WR_CMD(0x0003,0x1018); //图像显示方向为左下起 行递增 列递减 AM=1 I/D[1:0]=01 A
LCD_WR_CMD(0x0210, StartY); //水平显示区起始地址 0-239
LCD_WR_CMD(0x0211, StartY+Y-1); //水平显示区结束地址 0-239
LCD_WR_CMD(0x0212, 399-(StartX+X-1)); //垂直显示区起始地址 0-399
LCD_WR_CMD(0x0213, 399-StartX); //垂直显示区结束地址 0-399
LCD_WR_CMD(0x0200, StartY); //水平显示区地址
LCD_WR_CMD(0x0201, 399-StartX); //垂直显示区地址
LCD_WR_REG(0x0202); //准备写数据显示区 Size=X*Y; //字符串或字符占用的像素尺寸
while(i<Size){
temp=*chr++; //一个字节代表8个像素,因此加1代表索引到下8个像素
for(num=0; num<8; num++){ //数组的每一个字节代表了8个像素
if((temp&0x80)>0){ //对字节的各位进行推断。为1的用带入參数的16位颜色值标示。写入到像素位置。 LCD_WR_Data(Color);
}
else{
LCD_WR_CMD(0x0200, StartY+y); //水平显示区地址
LCD_WR_CMD(0x0201, 399-(StartX+x)); //垂直显示区地址
LCD_WR_REG(0x0202); //准备读数据显示区
R_dis_mem=LCD_RD_data(); //读取背景色。为叠加产生透明效果作准备
LCD_WR_Data(R_dis_mem); //对字节的各位进行推断,为0的用当前背景像素16位颜色值标示。
}
temp=temp<<1; //字节各位的移出
x++;
if(x>=X){x=0; y++;} //计算像素递增为当前的x和y,为当前像素读背景颜色做准备
i++;
}
}
}
}

程序没难么难理解的地方。慢慢看也就能懂了. 仅仅是感觉奋斗给的样例不够模块化,搞得一个函数要写这么行,事实上是能够分成几部分功能函数来实现的...

当然奋斗这个样例中的字符数组是直接用取模工具取得的,这种做是能够显示汉字,而经常使用的字符、数字、符号有个ASCII字符表,这里就截一部分图给看吧

这表百度一下都有的.

(仅仅是部分图)

大小16x8的

上面两幅图代表了两种表,都差点儿相同,就是大小不一样而已..

这里须要我们注意的是偏移量,上面是偏移量,按我自己的理解是一个字符真正開始的地方距离数组开头的长度,这里是32,为什么是32?

第0~32号及第127号(共34个)是控制字符或通讯专用字符,如控制符:LF(换行)、CR(回车)、FF(换页)、DEL(删除)、BEL(振铃)等;通讯专用字符:SOH(文头)、EOT(文尾)、ACK(确认)等;第33~126号(共94个)是字符,当中第48~57号为0~9十个阿拉伯数字;65~90号为26个大写英文字母。97~122号为26个小写英文字母,其余为一些标点符号、运算符号等

我没去下原始的ASCII表来看,但上面正点原子给的代码里的表应该是把前32个字符去掉了的..

所以正点原子给的代码中就有了num = num - ’ ‘这一行必须的代码,要不然就会出现乱码

void LCD_ShowChar(u16 x,u16 y,u8 num,u8 size,u8 mode)
{
#ifdef USE_HORIZONTAL
#define MAX_CHAR_POSX 312
#define MAX_CHAR_POSY 232
#else
#define MAX_CHAR_POSX 232
#define MAX_CHAR_POSY 312
#endif
u8 temp;
u8 pos,t;
u16 x0=x;
u16 colortemp=POINT_COLOR;
if(x>MAX_CHAR_POSX||y>MAX_CHAR_POSY)return;
//设置窗体
num=num-' ';//得到偏移后的值
if(!mode) //非叠加方式
{
for(pos=0;pos<size;pos++)
{
if(size==12)temp=asc2_1206[num][pos];//调用1206字体
else temp=asc2_1608[num][pos]; //调用1608字体
for(t=0;t<size/2;t++)
{
if(temp&0x01)POINT_COLOR=colortemp;
else POINT_COLOR=BACK_COLOR;
LCD_DrawPoint(x,y);
temp>>=1;
x++;
}
x=x0;
y++;
}
}else//叠加方式
{
for(pos=0;pos<size;pos++)
{
if(size==12)temp=asc2_1206[num][pos];//调用1206字体
else temp=asc2_1608[num][pos]; //调用1608字体
for(t=0;t<size/2;t++)
{
if(temp&0x01)LCD_DrawPoint(x+t,y+pos);//画一个点
temp>>=1;
}
}
}
POINT_COLOR=colortemp;
}

測试:LCD_ShowString(30,50,"Mini STM32 ^_^");

好了~ LCD篇差点儿相同也要学完了, 就剩下FSMC的一些问题了.

STM32学习之路-LCD(4)&lt;显示字符&gt;的更多相关文章

  1. STM32学习之路-LCD(3)&lt;显示图片&gt;

    祝大家端午和六一快乐!原本今天是想歇息歇息的,可是实在无奈没什么事干.所以就来学习学习LCD显示图片的函数 函数是照搬奋斗的样例,算是些笔记吧.只是奋斗的样例凝视的不是非常具体.今天去看了正点原子的论 ...

  2. STM32学习之路-LCD(2)

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/u011791262/article/details/27711881 这些天一直在研究LCD的初始化 ...

  3. STM32学习之路入门篇之指令集及cortex——m3的存储系统

    STM32学习之路入门篇之指令集及cortex——m3的存储系统 一.汇编语言基础 一).汇编语言:基本语法 1.汇编指令最典型的书写模式: 标号 操作码        操作数1, 操作数2,... ...

  4. (stm32学习总结)—LCD—液晶显示

    显示器简介 显示器属于计算机的 I/O 设备,即输入输出设备.它是一种将特定电子信息输出到屏幕上再反射到人眼的显示工具.常见的有 CRT 显示器.液晶显示器.LED 点阵显示器及OLED 显示器 本章 ...

  5. STM32学习之路之入门篇

    2006年ARM公司推出了基于ARMV7架构的cortex系列的标准体系结构,以满足各种技术得不同性能要求,包含了A,R,M三个分工明确的系列 其中A系列面向复杂的尖端应用程序,用于运行开放式的复杂操 ...

  6. STM32学习之路-感觉自己走到了一个天大的坑里了!

    先前兴致勃勃的来弄16位并口驱动LCD.本以为就须要改下LCD IC的初始化即可了,没想到弄了这么多天最终发现自己走进了一个深坑了 T T 原因是我的开发板是奋斗V5的, 它确实有MCU外扩IO口, ...

  7. STM32学习之路-SysTick的应用(时间延迟)

    开发板:奋斗V5 好~ 菜B要来搞实验了.. 前面已经说了SysTick的工作原理什么的了,这里就不说了.. 先来做第一个实验: 盗自奋斗的样例,嘿嘿, 用SysTick产生1ms的基准时间,产生中断 ...

  8. STM32学习之路之MDK安装篇

  9. Qt 学习之路 2(57):可视化显示数据库数据

    Qt 学习之路 2(57):可视化显示数据库数据(skip) 豆子 2013年6月26日 Qt 学习之路 2 26条评论 前面我们用了两个章节介绍了 Qt 提供的两种操作数据库的方法.显然,使用QSq ...

随机推荐

  1. Rancher 2:添加 NFS client provisioner 动态提供 Kubernetes 后端存储卷

    一.前提说明 1.说明: NFS client provisioner 利用 NFS Server 给 Kubernetes 作为持久存储的后端,并且动态提供PV. 默认 rancher 2 的存储类 ...

  2. B - Helpful Maths

    Problem description Xenia the beginner mathematician is a third year student at elementary school. S ...

  3. webApi上传服务,可重命名,可创建文件夹

    webApi上传服务,根据FileName重命名,根据Path创建文件夹 /// <summary> /// 上传文件 /// </summary> /// <retur ...

  4. HBase里的官方Java API

    见 https://hbase.apache.org/apidocs/index.html

  5. 【SQL】MERGE

    MERGE可以合并多个表中的数据,也可实现多表中数据的同步.使用MERGE语句对表中数据进行有条件的更新和插入.当查找的行存在时,UPDATE更新行中的数据:当查找的行不存在时,INSERT插入数据. ...

  6. 使用Ajax验证用户名

    Ajax是一项很重要的技术,下面简要举个例子,来解释如何使用Ajax.步骤如下:使用Ajax验证用户名使用文本框的onBlur事件 使用Ajax技术实现异步交互创建XMLHttpRequest对象通过 ...

  7. 【sqli-labs】 less24 POST- Second Order Injections *Real treat* -Stored Injections (POST型二阶注入 *真的好玩?* 存储注入)

    简单登陆浏览一遍后,发现是一个登陆注册修改密码的应用 审查一下代码 登陆页面的username,password使用了转义 注册页面的参数也进行了转义处理 但是在修改password的页面,直接从se ...

  8. (转)C#开发微信门户及应用(6)--微信门户菜单的管理操作

    http://www.cnblogs.com/wuhuacong/p/3701961.html 前面几篇继续了我自己对于C#开发微信门户及应用的技术探索和相关的经验总结,继续探索微信API并分享相关的 ...

  9. Dispatch Queues and Thread Safety

    Dispatch Queues and Thread Safety It might seem odd to talk about thread safety in the context of di ...

  10. Markdown 常用语法总结

    注意:Markdown使用#.+.*等符号来标记,符号后面必须跟上至少跟上 1个空格才有效! Markdown的常用语法 标题 Markdown标题支持两种形式. 1.用#标记 在标题开头加上1~6个 ...