#include <stdarg.h>
#include <stdio.h>
#include <math.h>
#include <intrins.h>
#include <absacc.h>
#include <string.h>
#include <LCD_160128.h>
sbit RESET = P3^3;
#define ASC_CHR_WIDTH 8
#define ASC_CHR_HEIGHT 12
#define HZ_CHR_HEIGHT 12
#define HZ_CHR_WIDTH 12
uchar code LCD_WIDTH = 20;
uchar code LCD_HEIGHT= 128;
uchar code ASC_MSK[96*12]=
{
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
};
uchar gCurRow,gCurCol;
uchar tCurRow,tCurCol;
uchar ShowModeSW;
uint txthome,grhome;
uchar Status_BIT_01();
uchar Status_BIT_3();
uchar GetCol();
uchar GetRow();
uchar LCD_Write_Command(uchar cmd);
uchar LCD_Write_Command_P1(uchar cmd,uchar para1);
uchar LCD_Write_Command_P2(uchar cmd,uchar para1,uchar para2);
uchar LCD_Write_Data(uchar dat);
uchar LCD_Read_Data();
void cls();
uchar LCD_Initialise();
void Set_LCD_POS(uchar row,uchar col);
void charout(uchar *str);
uchar dprintf(uchar x,uchar y,uchar *fmt);
void OutToLCD(uchar Dat,uchar x,uchar y);
void Line(uchar x1,uchar y1,uchar x2,uchar y2,bit Mode);
void Pixel(uchar x,uchar y,bit Mode);
uchar Status_BIT_01()
{
uchar i;
for(i=5;i>0;i--)
{
if((LCMCW & 0x03)==0x03)
break;
}
return i;
}
uchar Status_BIT_3()
{
uchar i;
for(i=5;i>0;i--)
{
if((LCMCW & 0x08)==0x08)
break;
}
return i;
}
uchar LCD_Write_Command_P2(uchar cmd,uchar para1,uchar para2)
{
if(Status_BIT_01()==0) return 1;
LCMDW = para1;
if(Status_BIT_01()==0) return 2;
LCMDW = para2;
if(Status_BIT_01()==0) return 3;
LCMDW = cmd;
return 0;
}
uchar LCD_Write_Command_P1(uchar cmd,uchar para1)
{
if(Status_BIT_01()==0) return 1;
LCMDW = para1;
if(Status_BIT_01()==0) return 2;
LCMDW = cmd;
return 0;
}
uchar LCD_Write_Command(uchar cmd)
{
if(Status_BIT_01()==0) return 1;
LCMDW = cmd;
return 0;
}
uchar LCD_Write_Data(uchar dat)
{
if(Status_BIT_3()==0) return 1;
LCMDW = dat;
return 0;
}
uchar LCD_Read_Data()
{
if(Status_BIT_01()==0) return 1;
return LCMDW;
}
void Set_LCD_POS(uchar row,uchar col)
{
uint Pos;
Pos = row*LCD_WIDTH+col;
LCD_Write_Command_P2(LC_ADD_POS,Pos%256,Pos/256);
gCurRow = row;
gCurCol = col;
}
void cls()
{
uint i;
LCD_Write_Command_P2(LC_ADD_POS,0x00,0x00);
LCD_Write_Command(LC_AUT_WR);
for(i=0;i<0x2000;i++)
{
Status_BIT_3();
LCD_Write_Data(0x00);
}
LCD_Write_Command(LC_AUT_OVR);
LCD_Write_Command_P2(LC_ADD_POS,0x00,0x00);
gCurRow = 0;
gCurCol = 0;
}
uchar LCD_Initialise()
{
RESET = 0;
RESET = 1;
LCD_Write_Command_P2(LC_TXT_STP,0x00,0x00);
LCD_Write_Command_P2(LC_TXT_WID,LCD_WIDTH,0x00);
LCD_Write_Command_P2(LC_GRH_STP,0x00,0x00);
LCD_Write_Command_P2(LC_GRH_WID,LCD_WIDTH,0x00);
LCD_Write_Command_P1(LC_CGR_POS,CGRAMSTART >> 11);
LCD_Write_Command(LC_CUR_SHP | 0x01);
LCD_Write_Command(LC_MOD_OR);
LCD_Write_Command(LC_DIS_SW | 0x08);
grhome = GRSTART;
txthome = TXTSTART;
return 0;
}
uchar Display_Str_at_xy(uchar x,uchar y,uchar *fmt)
{
char c1,c2,cData;
uchar i=0,j,uLen;
uLen = strlen(fmt);
while(i<uLen)
{
c1 = fmt[i];
c2 = fmt[i+1];
Set_LCD_POS(y,x/8);
if(c1>=0)
{
if(c1<0x20)
{
switch(c1)
{
case CR:
case LF:
i++;
x=0;
if(y<112) y+=HZ_CHR_HEIGHT;
continue;
case BS:
i++;
if(y>ASC_CHR_WIDTH) y-=ASC_CHR_WIDTH;
cData=0x00;
break;
}
}
for(j=0;j<ASC_CHR_HEIGHT;j++)
{
if(c1>=0x1f)
{
cData = ASC_MSK[(c1-0x1f)*ASC_CHR_HEIGHT+j];
Set_LCD_POS(y+j,x/8);
if((x%8)==0)
{
LCD_Write_Command(LC_AUT_WR);
LCD_Write_Data(cData);
LCD_Write_Command(LC_AUT_OVR);
}
else
OutToLCD(cData,x,y+j);
}
Set_LCD_POS(y+j,x/8);
}
if(c1!=BS) x+=ASC_CHR_WIDTH;
}
i++;
}
return uLen;
}
void OutToLCD(uchar Dat,uchar x,uchar y)
{
uchar dat1,dat2,a,b;
b = x%8;
a = 8-b;
Set_LCD_POS(y,x/8);
LCD_Write_Command(LC_AUT_RD);
dat1 = LCD_Read_Data();
dat2 = LCD_Read_Data();
dat1 = (dat1 &(0xff<<a)) | (Dat>>b);
dat2 = (dat1 &(0xff>>b)) | (Dat<<a);
LCD_Write_Command(LC_AUT_OVR);
Set_LCD_POS(y,x/8);
LCD_Write_Command(LC_AUT_WR);
LCD_Write_Data(dat1);
LCD_Write_Data(dat2);
LCD_Write_Command(LC_AUT_OVR);
}
void Pixel(uchar x,uchar y,bit Mode)
{
uchar start_addr,dat;
start_addr=7-(x%8);
dat = LC_BIT_OP | start_addr;
if(Mode) dat |= 0x08;
Set_LCD_POS(y,x/8);
LCD_Write_Command(LC_BIT_OP | dat);
}
void Exchange(uchar *a,uchar *b)
{
uchar t;
t = *a;*a = *b;*b = t;
}
void Line(uchar x1,uchar y1,uchar x2,uchar y2,bit Mode)
{
uchar x,y;
float k,b;
if(abs(y1-y2)<=abs(x1-x2))
{
k=(float)(y1-y2)/(float)(x2-x1);
b=y1-k*x1;
if(x1>x2) Exchange(&x1,&x2);
for(x=x1;x<=x2;x++)
{
y=(uchar)(k*x+b);
Pixel(x,y,Mode);
}
}
else
{
k=(float)(x2-x1)/(float)(y2-y1);
b=x1-k*y1;
if(y1>y2) Exchange(&y1,&y2);
for(y=y1;y<=y2;y++)
{
x=(uchar)(k*y+b);
Pixel(x,y,Mode);
}
}
}
没有合适的资源?快使用搜索试试~ 我知道了~
单片机仿真 160128LCD图文演示.rar
共20个文件
obj:2个
c:2个
lst:2个
1.该资源内容由用户上传,如若侵权请联系客服进行举报
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
版权申诉
0 下载量 173 浏览量
2023-04-12
07:52:21
上传
评论
收藏 91KB RAR 举报
温馨提示
免责声明:资料部分来源于合法的互联网渠道收集和整理,部分自己学习积累成果,供大家学习参考与交流。收取的费用仅用于收集和整理资料耗费时间的酬劳。 本人尊重原创作者或出版方,资料版权归原作者或出版方所有,本人不对所涉及的版权问题或内容负法律责任。如有侵权,请举报或通知本人删除。
资源推荐
资源详情
资源评论
收起资源包目录
单片机仿真 160128LCD图文演示.rar (20个子文件)
160128LCD图文演示
code.rar 14KB
160128LCD图文演示.DSN 37KB
Last Loaded 160128LCD图文演示.DBK 37KB
160128LCD图文演示.PWI 885B
Keil C
160128LCD图形滚动演示 47KB
160128LCD图形滚动演示.hex 19KB
160128LCD显示的图像.bmp 60KB
code
LCD_160128.LST 12KB
15 40KB
main.OBJ 15KB
15.plg 676B
15.M51 25KB
15.Opt 1KB
LCD_160128.OBJ 29KB
LCD_160128.h 1KB
main.LST 6KB
15.lnp 57B
15.Uv2 2KB
LCD_160128.c 5KB
main.c 2KB
共 20 条
- 1
资源评论
荣华富贵8
- 粉丝: 150
- 资源: 7649
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功