【0811】LM4229(LCD240128)画矩形+反白显示
2008-08-11 23:09

===========================================
              忙活了一个晚上,矩形终于画出来了
            另外还加了反白显示,由一个参数控制
===========================================

程序设计部分
主函数中调用:draw_rect(19,5,160,87);

下面是LM4229驱动程序(0811更新)
//========================================
//---------   小波电子工作室   -----------
//      LM4229 液晶显示驱动程序
// 作者:聂金波   完成日期:2008/08/05
// http://hi.baidu.com/niejinbo
// 四川师范大学 电子工程学院 2005级5级
// 改进:2008/08/08增加显示5个32*32汉字程序
//        2008/08/10增加显示a*b大小照片(a为8的倍数)
//        2008/08/11增加反白显示、画直线和矩形
//----------------------------------------
//   本程序参考仿真社区(www.proteus.com.cn)一个网友
// 写的LCD240*128显示程序,在此表示感谢!
//=========================================

#include<en_code.h>
#include<cn_code.h>
#include<picture.h>

#define uchar unsigned char
#define uint unsigned int

#define DATA_PORT P0
//-------------------------------------------
//              管脚定义  
//------------------------------------------
sbit HALT=P2^0;   //暂不清楚
sbit FS1=P2^1;    //字体模式选择
sbit MD2=P2^2;    //方式选择
sbit RST=P2^3;    //复位
sbit CD=P2^4;     //数据(L)/命令(H)选择
sbit READ=P2^5;     //读,低电平有效
sbit WRIT=P2^6;     //写,低电平有效
sbit CE=P2^7;     //使能,低电平有效

//===========================================
//              函数声明
//-------------------------------------------
void delay_lcd(uchar);
void write_data(uchar);
void write_com(uchar);
void clr_lcd(uchar,uchar,uint);

//--------------------------------------------
//              延时函数
//--------------------------------------------
void delay_lcd(uchar t)
{
for(;t!=0; t--);
}

//--------------------------------------------
//              写数据函数
//--------------------------------------------
void write_data(uchar dat)
{
CD=0;          //数据
CE=0;          //LCD使能
WRIT=0;        //写
DATA_PORT=dat; //把数据送到P口
delay_lcd(1);      //当晶振较高时加延时
WRIT=1;        //关写
CE=1;          //关使能
}

//--------------------------------------------
//              写命令函数
//--------------------------------------------
void write_com(uchar com)
{
CD=1;    //命令
CE=0;
WRIT=0;
DATA_PORT=com;
delay_lcd(1);    //当晶振较高时加延时
WRIT=1;
CE=1;
}
//--------------------------------------------
//           指定位置、长度清屏
//--------------------------------------------
void clr_lcd(uchar x,uchar y,uint length)
{
uint i,place;
place=x*30+y;
write_data(place&0xff);
write_data(place/256);
write_com(0x24);        //设置
for(i=0;i<length;i++)
write_data(0xff);          //写入空格,清屏
write_com(0xb2);        //关闭自动写
}

//--------------------------------------------
//   ------- 【显示16*16字符】 -------
//--------------------------------------------
//         指定位置向LCD写入指定字符
// 参数说明:x、y 坐标 cha字符串 flag 反白显示标志 1正常,0反白
//
//--------------------------------------------
void write_lcd(uchar x,uchar y,char *cha,bit flag)
{
uint place,i=0;
uchar length,c1,c2,j,k;
for(length=0;cha[length]!=0;length++);
   do
    {
      c1=cha[i];      //取字符串的ASCII码
      c2=cha[i+1];
      place=x*30+y;
      if(c1<=128)        //#####小于128为字符,大于128为汉字
       {
        for(k=0;k<16;++k)     //字符设置为16*8
        {
          write_data(place&0xff);   //写入地址高位
          write_data(place/256);    //写入地址低位
          write_com(0x24);          //地址设置
          write_com(0xb0);          //设置数据自动写
          if(flag)
          {write_data(ASC_MSK[(c1-0x20)*16+k]);} /*---例如:0的ASCII码为0x30,
          在ASC_MSK中的位置为0x10*16 ---16字节字码依次写入LCD---*/
          else
          {write_data(~ASC_MSK[(c1-0x20)*16+k]);}
          write_com(0xb2);          //自动复位
          place=place+30;
        }
        if(y>28)            //y>28时候需要换行
          {x=x+16;y=0;}
        else                //否则,不换行,继续写下一个字符
          {y++;}
           i++;
      }
     else                   //#####c1大于128为汉字
      {
        for(j=0;j<sizeof(GB_16)/sizeof(GB_16[0]);j++) //找到汉字
         {
           if(c1==GB_16[j].Index[0]&&c2==GB_16[j].Index[1])
           break;            //汉字找到则跳出  
         }
        if(j<sizeof(GB_16)/sizeof(GB_16[0]))   //------如果汉字在子码表内
         {
          for(k=0;k<16;k++)     //字符设置为16*8
           {
            write_data(place&0xff);   //写入地址高位
            write_data(place/256);    //写入地址低位
            write_com(0x24);          //地址设置
            write_com(0xb0);          //设置数据自动写
            if(flag)
            {
             write_data(GB_16[j].Msk[k*2]);
       write_data(GB_16[j].Msk[k*2+1]); //16*16,每行2字节
            }
            else
            {
             write_data(~GB_16[j].Msk[k*2]);
       write_data(~GB_16[j].Msk[k*2+1]); //16*16,每行2字节
            }
            write_com(0xb2);                 //自动复位
            place=place+30;                  //下一行
           }
         }
        else             //-----没找到对应汉字则涂黑
         {
          for(k=0;k<16;k++)     //字符设置为16*8
           {
            write_data(place&0xff);   //写入地址高位
            write_data(place/256);    //写入地址低位
            write_com(0x24);          //地址设置
            write_com(0xb0);          //设置数据自动写
            write_data(0xff);
     write_data(0xff);
            write_com(0xb2);             //自动复位
            place=place+30;              //下一行
           }
         }
        if(y>27)      //-------换行
         {x+=16;y=0;}
        else          //--------不用换行,则下一个字
         {y+=2;}
         i+=2;
      }
    }
   while(i<length);
}

//--------------------------------------------
//         LM4229初始化函数
//--------------------------------------------
void lcd_init()
{
   FS1 = 0;//fs1管脚高电平时表示字体为8*6;
            //低电平时为8*8
MD2 = 0;
HALT = 0;
write_data(0);
write_data(0);        //图形首地址
write_com(0x42);     //图形首地址设置
write_data(30);
write_data(0);
write_com(0x43);     //图形区域设置
write_com(0x80);     //设置为OR模式
   write_com(0x98);    //关闭文本显示,开图形显示
}

//===================【显示5个大汉字】===================
//--------------------------------------------
//         LM4229在指定位置显示32*32汉字
//--------------------------------------------

void write_pic(uchar x,uchar y)
{
uint place;
uchar i,n;
place=x*30+y;

for(n=0;n<5;n++)   //5个汉字
{
   for(i=0;i<32;i++)   //32*32
    {
     write_data(place&0xff);
     write_data(place/256);
     write_com(0x24); //设置地址
     write_com(0xb0); //设置数据自动写
     write_data(tab_pic[4*i+0+128*n]);
     write_data(tab_pic[4*i+1+128*n]);
     write_data(tab_pic[4*i+2+128*n]);
     write_data(tab_pic[4*i+3+128*n]);
     write_com(0xb2);    //自动复位
     place=place+30;
    }
   place=x*30+y+4*(n+1);
}
}
//==================【显示图片部分】====================

//--------------------------------------------
//         LM4229在指定位置显示a*b图片
//     a为图片长,b为图片宽(a为8的倍数)
//--------------------------------------------
void write_image(uchar x,uchar y,uchar a,uchar b,uchar *tab_image)
{
uint place;
uchar i,j;
place=x*30+y;
for(i=0;i<b;i++)        //b行数据
{
    write_data(place&0xff);   //写地址低8位
    write_data(place/256);    //写地址高8位
    write_com(0x24); //设置地址
    write_com(0xb0); //设置数据自动写
    for(j=0;j<a/8;j++)    //a/8列数据
    {write_data(tab_image[(a/8)*i+j]);}
    write_com(0xb2);    //自动复位
    place=place+30;     //换行
}
}

//==================【画线和矩形部分】==============

//--------------------------------------------
//         LM4229在指定位置画横线a
//      参数说明:x、y 坐标     a 长度  
//              (a为8的倍数)
//--------------------------------------------
void draw_h(uchar x,uchar y,uchar a)
{
uint place;
uchar j;

//---- 画横线长 a -----
place=x*30+y;
write_data(place&0xff);   //写地址低8位
write_data(place/256);    //写地址高8位
write_com(0x24);       //设置地址
write_com(0xb0);       //设置数据自动写
for(j=0;j<=a/8;j++)    //a/8列数据
{write_data(0xff);}
write_com(0xb2);      //自动复位
}

//--------------------------------------------
//         LM4229在指定位置画竖线b
// 参数说明:x、y 坐标     b 长度   0000 0001   
//--------------------------------------------
void draw_lr(uchar x,uchar y,uchar b)
{
uint place;
uchar j;
place=x*30+y;
for(j=0;j<b;j++)    //a/8列数据
{
    write_data(place&0xff);   //写地址低8位
    write_data(place/256);    //写地址高8位
    write_com(0x24);       //设置地址
    write_com(0xb0);       //设置数据自动写
    write_data(0x01);
    write_com(0xb2);      //自动复位
    place=place+30;
}
}

//--------------------------------------------
//         LM4229在指定位置画竖线b
//   参数说明:x、y 坐标     b 长度   1000 0000   
//--------------------------------------------

void draw_ll(uchar x,uchar y,uchar b)
{
uint place;
uchar j;
place=x*30+y;
for(j=0;j<b;j++)    //a/8列数据
{
    write_data(place&0xff);   //写地址低8位
    write_data(place/256);    //写地址高8位
    write_com(0x24);       //设置地址
    write_com(0xb0);       //设置数据自动写
    write_data(0x80);
    write_com(0xb2);      //自动复位
    place=place+30;
}
}

//--------------------------------------------
//         LM4229在指定位置画矩形a*b
//     参数说明:x、y 坐标     a、b 长度
//            调用到上面几个函数
//--------------------------------------------
void draw_rect(uchar x,uchar y,uchar a,uchar b)
{
draw_h(x,y,a);        //画上边
draw_lr(x,y-1,b);     //画左宽
draw_ll(x,y+a/8,b);   //画右宽
draw_h(x+b,y,a-8);    //画下边 ;a-8下边长才和上边长一样,不知道为啥??
}

/*----- 测试数据------*/
/*draw_h(33,4,160);     //画上边
draw_lr(33,3,51);     //画左宽
draw_ll(33,3+21,51); //画右宽
draw_h(83,4,152);     // */
//-------------------

//===================================================

转:【0811】LM4229(LCD240128)画矩形+反白显示相关推荐

  1. ST7920LCD12864反白显示

    反白思想:  从使用手册上可知,扩展指令里的0x03+行号即可实现反白对应行.但是ST7920 控制器的128×64 点阵液晶其实原理上等同256×32 点阵,第三行对应的DDRAM 地址紧接第一行: ...

  2. ST7920驱动的LCD12864实现单行反白显示

    参考链接: ST7920驱动的LCD12864实现单行反白显示 - jqdy - 博客园 12864液晶模块的详细使用_Rainlee随笔记-CSDN博客_12864使用 GDRAM空间有64×256 ...

  3. matlab波形反白,基于MATLAB的海岸污染物浓度扩散实验分析

    海岸污染物图像序列隐含丰富的物质输移扩散的重要特征,通过CCD图片得到所需要的信息具有广泛的应用价值.传统的接触式和单点式测量方法很难全面高效地得到需要的实验结果,而利用CCD等摄像设备进行测量记录, ...

  4. linux中蓝色反白文件,Linux系统Terminal终端中的文件、文件夹的颜色修改方法

    ls 显示颜色修改 查看系统设置 echo ${LS_COLORS} 可以看到自己系统的颜色设置 no=00:fi=00:di=00;34:ln=00;36:pi=40;33:so=00;35:bd= ...

  5. 带字库LCD12864(ST7920)使用记录(命令 数据 地址 绘图 反白)

    [本文发布地址https://blog.csdn.net/Stack_/article/details/113833549,未经许可不得转载,转载须注明出处] 以前用LCD12864做显示直接用前人的 ...

  6. vtk窗宽窗位,以及图像反白思路

    普通图像的灰度范围一般是256级,而医学图像基于其特殊性,灰度级较普通图像会高很多.人体组织在CT上能分辨出2000个不同的灰度,而人眼只能分辨16个灰度,将这2000个CT值用16阶灰度反应的话,人 ...

  7. matlab示波器如何反白,stc12单片机写的简易示波器代码,求大神答疑

    #include #include #include sbit RS=P0^0; //并行的指令/数据选择信号, H数据, L命令 sbit RW=P0^1; //并行读写选择信号, H读, L写 s ...

  8. 数字图像处理——对图像进行反白、更改调色板信息、彩色图像变灰度、将图像数据保存于txt文件

    数字图像处理课的第一次实验,主要是对BMP图像的处理,并且学习熟悉excel可视化实验数据 实验环境 建立动态库工程,录入HXLBMPFILE类,建立相应动态库,将整个类作为动态库输出 (HXLBMP ...

  9. Java黑皮书课后题第6章:*6.4(反序显示一个整数)使用下面的方法体编写方法,反序显示一个整数…例如reverse(3456)返回6543,编写一个测试程序,提示用户输入一个整数,然后显示它的反序

    *6.4(反序显示一个整数)使用下面的方法体编写方法,反序显示一个整数-例如reverse(3456)返回6543,编写一个测试程序,提示用户输入一个整数,然后显示它的反序 题目 题目概述 破题 代码 ...

最新文章

  1. IOS4.x下UIWebView的显示问题
  2. oracle中怎么用累计,oracle实现累加,累计百分比计算
  3. 被乐高AI“照妖镜”一照,发现你的本体原来是人偶
  4. bugzilla dbd-mysql_Linux下安装Bugzilla——完整版
  5. 我眼中的Linux设备树(六 memorychosen节点)
  6. ubuntu下使用filezilla上传文件权限问题(open for write: permission denied)
  7. Android 调试工具集合
  8. mysql 触发器 定时触发_mysql 触发器和存储过程组合使用,实现定时触发操作
  9. java 常量接口_java接口定义常量研究
  10. leetcode122. 买卖股票的最佳时机 II
  11. 前人栽树,后人擦屁股
  12. c++设计地铁售票系统_地铁自动售票机中票务系统的设计与开发
  13. 关于网站速度优化的一点建议
  14. 解决问题Uncaught SyntaxError: The requested module ‘/node_modules/hls.js/dist/hls.js‘ does not provide
  15. 与 AI 博弈:从 AlphaGo 到 MuZero(三)
  16. 计算机架构设计的 8 个伟大思想
  17. 求求你,商用项目不要再使用jsdelivr的CDN服务了
  18. 10个你未必知道的CSS技巧与14种cssdiv中基本滤镜介绍
  19. 【量化投资实训】基于MATLAB实验三.指数移动平均SMA
  20. 区块链引爆金融媒体:同花顺固守,新浪财经反思,韭菜财经谋变

热门文章

  1. linux Ubuntu KUbuntu 系统安装相关
  2. win7下使用virtual pc 安装xp虚拟机
  3. 邂逅钱塘江畔,一场别开生面的合作伙伴沙龙来了
  4. R语言中的复制符号-和=
  5. Linux上传文件没有权限,添加文件权限命令
  6. python---6行代码,画花
  7. Bandizip安装教程---图文讲解
  8. linux 显示行号
  9. selenium+ChromeDriver测试网站
  10. Activity A页面启动Activity B页面的生命周期顺序(多种情况)