亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 19264lcd.c

?? 普通19264圖形液晶模塊的單片機驅動程序
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*---------------------------------------------------------------------------------------------------
Keil C51編寫的192*64液晶片驅動程序,感謝很多網友提供了參考源程序,

本程序是在網友們提供的程序基礎上改寫而成,有很多地方得到高手們的耐

心指導,在此深表謝意。這是一個完整的C51源程序,我覺得對一位初學C51

的人來說,提供一個完整的簡單程序比較容易上手。
--------------------------------------------------------------------------------------------------*/
/*寫漢字液晶子程 液晶屏分為4行*12列漢字,全部使用模擬接口方式。
/* TGLCMLIMIT64A接口程序(模擬方式)
液晶模塊供應商:
Email: 
;***************************************************************************
;連線圖:
;*LCM---89C52* *LCM---89C52* *LCM-------89C52* *LCM----------89C52* *
;*DB0---P0.0* *DB4---P0.4* *D/I-------P2.6* *CS1----------P2.4* *
;*DB1---P0.1* *DB5---P0.5* *R/W-------P2.7* *CS2----------P2.5* *
;*DB2---P0.2* *DB6---P0.6* *RST--------VCC* *CS3----------P3.2* * 
;*DB3---P0.3* *DB7---P0.7* *E---------P2.3* *
;注:89C52的晶振頻率為12MHz *
;***************************************************************************/
//畫線部分請參照avr的c程序。
/*#pragma src /*生成ASM文件開關,必要時打開 */
#include<reg52.h>
#include<math.h>
#include<INTRINS.H>

#define Uchar unsigned char

/***********液晶顯示器接口引腳定義***************/

sbit CS1LCM= P1^3; //
sbit CS2LCM= P1^5; //
sbit CS3LCM= P1^6; /*這個連接只是做實驗的臨時接法。*/
sbit Dilcm= P1^0; //
sbit Rwlcm= P1^1; //
sbit Elcm= P1^2; //
/*
sbit CS1 =P1^3; //1片選
sbit CS2 =P1^5; //2片選
sbit CS3 =P1^6; //3片選
sbit RS  =P1^0; //數據指令
sbit RW  =P1^1; //讀寫
sbit E   =P1^2; //使能
sbit RST =P1^5;//復位  */
#define Datalcm P2 //數據口

/***********常用操作命令和參數定義***************/
#define DISPON 0x3f /*顯示on */
#define DISPOFF 0x3e /*顯示off */
#define DISPFIRST 0xc0 /*顯示起始行定義 */
#define SETX 0x40 /*X定位設定指令(頁) */
#define SETY 0xb8 /*Y定位設定指令(列) */
#define Lcdbusy 0x80 /*LCM忙判斷位 */

/**************顯示分區邊界位置*****************/
#define MODL 0x00 /*左區 */
#define MODM 0x40 /*左區和中區分界 */
#define MODR 0x80 /*中區和右區分界 */
#define LCMLIMIT 0xC0 /*顯示區的右邊界 */

/****************全局變量定義*******************/
Uchar col,row,cbyte; /*列x,行(頁)y,輸出數據 */
bit xy; /*畫線方向標志:1水平 */

/*****************函數列表**********************/
void Lcminit(void); /*液晶模塊初始化 */
void Delay(Uchar); /*延時,入口數為Ms */
void lcdbusyL(void); /*busy判斷、等待(左區) */
void lcdbusyM(void); /*busy判斷、等待(中區) */
void lcdbusyR(void); /*busy判斷、等待(右區) */
void Putedot(Uchar); /*半角字符輸出 */
void Putcdot(Uchar); /*全角(漢字)輸出 */
void Wrdata(Uchar); /*數據輸出給LCM */
void Lcmcls( void ); /*LCM全屏幕清零(填充0) */
void wtcom(void); /*公用busy等待 */
void Locatexy(void); /*光標定位 */
void WrcmdL(Uchar); /*左區命令輸出 */
void WrcmdM(Uchar); /*中區命令輸出 */
void WrcmdR(Uchar); /*右區命令輸出 */
void Putstr(Uchar *puts,Uchar i); /*中英文字符串輸出 */
void Rollscreen(Uchar x); /*屏幕向上滾動演示 */
void Rddata(void); /* 從液晶片上讀數據 */
void Linehv(Uchar length); /*橫(豎)方向畫線 */
void point(void); /*打點 */
void Linexy(Uchar endx,Uchar endy);

/******************數組列表*********************/
Uchar code Ezk[]; /*ASCII常規字符點陣碼表 */
Uchar code Hzk[]; /*自用漢字點陣碼表 */
Uchar code STR1[]; /*自定義字符串 */
Uchar code STR2[]; //
Uchar code STR3[]; //
Uchar code STR4[]; //


/********************************/
/* 演示主程序 */
/********************************/
void main(void)

{
Uchar x;
col=0;
row=0;
Delay(40); /*延時大約40Ms,等待外設準備好 */
Lcminit(); /*液晶模塊初始化,包括全屏幕清屏*/
Putstr(STR2,24); /*第一行字符輸出,24字節 */
col=0;
row=2;
Putstr(STR1,12); /*第二行字符輸出,12字節 */
col=0;
row=4;
Putstr(STR3,24); /*第三行字符輸出,24字節 */
col=0;
row=6;
Putstr(STR4,24); /*第四行字符輸出,12字節 */
x=0;
col=0;
row=0;
xy = 1; /*方向標志。定為水平方向 */
Linehv(192); /*畫一條橫線(0,0)-(191,0) */
col=0;
row=15;
xy = 1;
Linehv(192); /*畫一條橫線(0,15)-(191,15) */
col=0;
row=32;
xy = 1;
Linehv(192); /*畫一條橫線(0,32)-(191,32) */
col=0;
row=1;
xy = 0; /*方向標志。定為垂直方向 */
Linehv(31); /*畫一條豎線(0,1)-(0,31) */
col=191;
row=1;
xy = 0;
Linehv(31); /*畫一條豎線(191,1)-(191,31) */
col=0; /*設定斜線的起點坐標 */
row=63;
Linexy(44,31); /*畫一段斜線(0,63)-(44,31) */
col=44;
row=31;
Linexy(190,62); /*繼續畫斜線(44,31)-(191,63) */
while(1){
Rollscreen(x); /*定位新的顯示起始行 */
x++;
Delay(100); /*延時,控制滾動速度 */
};
}


/************************************************/
/*畫線。任意方向的斜線,不支持垂直的或水平線 */
/************************************************/

void Linexy(Uchar endx,Uchar endy)
{
register Uchar t;
int xerr=0,yerr=0,delta_x,delta_y,distance;
Uchar incx,incy;

/* compute the distance in both directions */
delta_x=endx-col;
delta_y=endy-row;

/* compute the direction of the increment ,
an increment of "0" means either a vertical or horizontal lines */

if(delta_x>0) incx=1;
else if( delta_x==0 ) incx=0;
else incx=-1;


if(delta_y>0) incy=1;
else if( delta_y==0 ) incy=0;
else incy=-1;

/* determine which distance is greater */
delta_x = cabs( delta_x );
delta_y = cabs( delta_y );

if( delta_x > delta_y ) distance=delta_x;
else distance=delta_y;

/* draw the line */
for( t=0;t <= distance+1; t++ ) {
point();
xerr += delta_x ;
yerr += delta_y ;
if( xerr > distance ) {
xerr-=distance;
col+=incx;
}
if( yerr > distance ) {
yerr-=distance;
row+=incy;
}

}
}

/****************************************/
/*畫線。只提供X或Y方向的,不支持斜線 */
/****************************************/
void Linehv(Uchar length)
{
Uchar xs,ys;
if (xy){ys = col;
for (xs=0;xs<length;xs++){
col = ys + xs;
point();}
}
else {xs = row;
for (ys=0;ys<length;ys++){
row = xs + ys;
point();}
}
}

/****************************************/
/* 畫點 */
/****************************************/

void point(void)
{
Uchar x1,y1,x,y;
x1=col;
y1=row;
row=y1>>3; /*取Y方向分頁地址 */
Rddata();
y=y1&0x07; /*字節內位置計算 */
x=0x01;
x=x<<y; /*移入所畫點 */
Wrdata(cbyte|x); /*畫上屏幕 */
col=x1; /*恢復xy坐標 */
row=y1;
}

/****************************************/
/* 屏幕滾動定位 */
/****************************************/
void Rollscreen(Uchar x)
{
cbyte = DISPFIRST|x; /*定義顯示起始行為x?*/
WrcmdL(cbyte);
WrcmdM(cbyte);
WrcmdR(cbyte);
}

/****************************************/
/* 一個字串的輸出 */
/****************************************/
void Putstr(Uchar *puts,Uchar i)
{
Uchar j,X;
for (j=0;j<i;j++)
{
X = puts[j];
if (X&0x80)
{
Putcdot(X&0x7f); /*只保留低7位*/
}
else Putedot(X-0x20); /*ascii碼表從0x20開始*/
}
}

/****************************************/
/* 半角字符點陣碼數據輸出 */
/****************************************/
void Putedot(Uchar Order)
{
Uchar i,bakerx,bakery; /*共定義4個局部變量 */
int x; /*偏移量,字符量少的可以定義為UCHAR */
bakerx = col; /*暫存x,y坐標,已備下半個字符使用 */
bakery = row;
x=Order * 0x10; /*半角字符,每個字符16字節 */
/*上半個字符輸出,8列 */
for(i=0;i<8;i++)
{
cbyte = Ezk[x]; /*取點陣碼,rom數組 */
Wrdata(cbyte); /*寫輸出一字節 */
x++;
col++;
if (col==LCMLIMIT){col=0;row++;row++;}; /*下一列,如果列越界換行*/
if (row>7) row=0; /*如果行越界,返回首行 */
} /*上半個字符輸出結束 */

col = bakerx; /*列對齊 */
row = bakery+1; /*指向下半個字符行 */
/*下半個字符輸出,8列 */
for(i=0;i<8;i++)
{
cbyte = Ezk[x]; /*取點陣碼 */
Wrdata(cbyte); /*寫輸出一字節 */
x++;
col++;
if (col==LCMLIMIT){col=0;row=row+2;}; /*下一列,如果列越界換行*/
if (row>7) row=1; /*如果行越界,返回首行 */
} /*下半個字符輸出結束 */
row=bakery;
} /*整個字符輸出結束 */


/****************************************/
/* 全角字符點陣碼數據輸出 */
/****************************************/
void Putcdot(Uchar Order)
{
Uchar i,bakerx,bakery; /*共定義3個局部變量 */
int x; /*偏移量,字符量少的可以定義為UCHAR */
bakerx = col; /*暫存x,y坐標,已備下半個字符使用 */
bakery = row;
x=Order * 0x20; /*每個字符32字節 */

/*上半個字符輸出,16列 */
for(i=0;i<16;i++)
{
Wrdata(Hzk[x]); /*寫輸出一字節 */
x++;
col++;
if (col==LCMLIMIT){ col=0;row++;row++;} /*下一列,如果列越界換行*/
if (row>6) row=0; /*如果行越界,返回首行 */
} /*上半個字符輸出結束 */

/*下半個字符輸出,16列 */
col = bakerx;
row = bakery+1;
for(i=0;i<16;i++) /*下半部分*/
{
Wrdata(Hzk[x]);
x++;
col++;
if (col==LCMLIMIT){col=0;row++;row++;} /*下一列,如果列越界換行*/
if (row>7) row=1; /*如果行越界,返回首行 */
} /*下半個字符輸出結束 */
row = bakery;
} /*整個字符輸出結束 */

/****************************************/
/* 清屏,全屏幕清零 */
/****************************************/
void Lcmcls( void )
{
for(row=0;row<8;row++)
for(col=0;col<LCMLIMIT;col++) Wrdata(0);
}

/****************************************/
/* 從液晶片上讀數據,保留在全局變量中 */
/****************************************/

void Rddata(void)
{
Locatexy(); /*坐標定位,返回時保留分區狀態不變 */
Datalcm=0xFF;
Dilcm = 1; /*數據*/
Rwlcm = 1; /*讀數據*/
Elcm = 1; /*讀入到LCM*/
_nop_();
cbyte = Datalcm; /*虛讀一次 */
Elcm = 0;
Locatexy(); /*坐標定位,返回時保留分區狀態不變 */
Datalcm=0xFF;
_nop_();
Dilcm = 1; /*數據*/
Rwlcm = 1; /*讀數據*/
Elcm = 1; /*讀入到LCM*/
_nop_();
cbyte = Datalcm; /*從數據口讀數據,真讀 */
Elcm = 0;
}

/****************************************/
/* 數據寫輸出 */
/****************************************/

void Wrdata(Uchar X)
{
Locatexy(); /*坐標定位,返回時保留分區狀態不變 */
// wtcom();
Dilcm = 1; /*數據輸出*/
Rwlcm = 0; /*寫輸出 */
Datalcm = X; /*數據輸出到數據口 */
Elcm = 1; /*讀入到LCM*/
_nop_();
Elcm = 0;
}

/****************************************/
/* 命令輸出,每次輸出一個分區控制口 */
/****************************************/

/*void Wrcmd(Uchar X)
// {
// Locatexy(); /*確定分區,返回時保留分區狀態不變 */
// wtcom(); /*等待LCM操作允許 */
// Dilcm = 0; /*數據操作 */
// Rwlcm = 0; /*寫輸出 */
// Datalcm = X; /*數據輸出到數據口 */
// Elcm = 1;_nop_();Elcm = 0; /*讀入到LCM*/
// }

/********************************/
/* 命令輸出到左區控制口 */
/********************************/

void WrcmdL(Uchar X)
{
lcdbusyL(); /*確定分區,返回時保留分區狀態不變*/
Dilcm = 0; /*命令操作 */
Rwlcm = 0; /*寫輸出 */
Datalcm = X; /*數據輸出到數據口 */
Elcm = 1;_nop_();Elcm = 0; /*讀入到LCM*/
}

/********************************/
/* 命令輸出到中區控制口 */
/********************************/

void WrcmdM(Uchar X)
{
lcdbusyM(); /*確定分區,返回時保留分區狀態不變*/
Dilcm = 0; /*命令操作 */
Rwlcm = 0; /*寫輸出 */
Datalcm = X; /*命令輸出到數據口 */
Elcm = 1;_nop_();Elcm = 0; /*讀入到LCM*/
}

/********************************/
/* 命令輸出到右區控制口 */
/********************************/

void WrcmdR(Uchar X)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91福利在线观看| 亚洲女性喷水在线观看一区| 久久影音资源网| 亚洲激情在线播放| 丁香桃色午夜亚洲一区二区三区| 欧美揉bbbbb揉bbbbb| 国产日韩欧美不卡| 奇米888四色在线精品| 91网站在线观看视频| 欧美电影免费观看完整版| 尤物av一区二区| www.亚洲人| 久久九九久精品国产免费直播| 亚洲一区二区三区四区在线观看| av不卡免费在线观看| 久久先锋影音av鲁色资源| 日韩av午夜在线观看| 欧美私模裸体表演在线观看| 国产精品视频麻豆| 国产aⅴ精品一区二区三区色成熟| 在线不卡免费欧美| 亚洲国产欧美日韩另类综合 | 中文字幕精品一区| 奇米色777欧美一区二区| 欧美日韩在线三级| 亚洲成人动漫在线观看| 91国在线观看| 亚洲一区中文在线| 在线观看网站黄不卡| 伊人婷婷欧美激情| 色综合中文综合网| 亚洲精品一区二区精华| 日韩精品高清不卡| 欧美裸体bbwbbwbbw| 亚洲大片在线观看| 欧美久久久久久蜜桃| 日本一区中文字幕 | 精品欧美一区二区三区精品久久| 国产精品视频一二三| 成人高清视频在线| 国产日韩欧美高清在线| av电影一区二区| 亚洲狠狠丁香婷婷综合久久久| av亚洲产国偷v产偷v自拍| 亚洲欧洲国产日韩| 91理论电影在线观看| 亚洲午夜私人影院| 日韩欧美一区二区在线视频| 国产在线不卡一卡二卡三卡四卡| 久久免费电影网| 99久久久国产精品免费蜜臀| 亚洲一区视频在线| 欧美不卡在线视频| 成人综合在线观看| 亚洲老司机在线| 欧美一区二区三区性视频| 精品一区二区三区免费| 国产精品久久久久久久久免费丝袜 | 欧美美女视频在线观看| 捆绑变态av一区二区三区| 国产亚洲欧洲一区高清在线观看| av亚洲产国偷v产偷v自拍| 五月开心婷婷久久| 精品成人a区在线观看| 99re这里都是精品| 免费一级片91| 中文字幕日韩一区| 欧美一区二区人人喊爽| 成人午夜视频免费看| 一区二区三区日韩| 2021国产精品久久精品| 色老头久久综合| 精品系列免费在线观看| 国产精品传媒入口麻豆| 欧美一区二区在线免费观看| 99久久久免费精品国产一区二区| 日本亚洲电影天堂| 国产精品动漫网站| 欧美精品一区二区三区一线天视频| 97久久人人超碰| 国内成人精品2018免费看| 亚洲精品乱码久久久久久| 国产亚洲欧美色| 日韩欧美高清dvd碟片| 在线观看国产日韩| 高清shemale亚洲人妖| 麻豆精品视频在线观看免费| 亚洲综合精品自拍| 亚洲特级片在线| 久久免费午夜影院| 日韩欧美一级片| 88在线观看91蜜桃国自产| 色综合欧美在线视频区| 国产91富婆露脸刺激对白| 久久草av在线| 日韩高清不卡在线| 亚洲成人黄色影院| 一区二区三区精品在线观看| 国产精品麻豆欧美日韩ww| 久久综合999| 久久综合狠狠综合| 亚洲精品在线免费观看视频| 91精品国产入口| 911精品国产一区二区在线| 在线观看中文字幕不卡| 91视频免费播放| av在线播放成人| www.性欧美| 91亚洲大成网污www| 97久久精品人人做人人爽50路| 99这里只有久久精品视频| av在线这里只有精品| 99视频精品免费视频| 懂色av一区二区三区免费看| 丁香五精品蜜臀久久久久99网站| 国产盗摄女厕一区二区三区| 国产a视频精品免费观看| 成人免费视频视频在线观看免费| 国产成人综合网站| 成人一区二区三区中文字幕| 成人理论电影网| 不卡欧美aaaaa| 在线观看精品一区| 欧美男同性恋视频网站| 91精选在线观看| 欧美大胆一级视频| 中文一区二区在线观看| 中文字幕在线观看不卡| 亚洲精品美国一| 日韩中文字幕1| 久久精品国产亚洲aⅴ| 国产成人在线免费| 色欧美片视频在线观看| 在线成人午夜影院| 久久免费视频一区| 亚洲欧美另类在线| 日韩电影免费一区| 国产一区二区不卡| 一本色道亚洲精品aⅴ| 欧美日韩国产另类不卡| 亚洲精品一区二区三区蜜桃下载| 国产日韩高清在线| 亚洲国产精品久久人人爱| 免费成人美女在线观看| av在线不卡网| 欧美一二三四区在线| 欧美国产国产综合| 亚洲妇熟xx妇色黄| 国产酒店精品激情| 欧美系列在线观看| 国产午夜精品美女毛片视频| 一区二区三区国产精华| 狠狠色综合播放一区二区| av亚洲精华国产精华| 日韩免费视频一区二区| 中文字幕综合网| 国内精品免费**视频| 欧美视频第二页| 日本一区二区三区国色天香| 午夜激情久久久| 97久久精品人人澡人人爽| 日韩美女在线视频| 亚洲国产你懂的| 99在线视频精品| 久久久久九九视频| 日韩av网站在线观看| 一本大道av一区二区在线播放| 久久久久久久综合色一本| 亚洲一区精品在线| av一区二区三区在线| 久久久亚洲欧洲日产国码αv| 婷婷中文字幕一区三区| 97精品国产露脸对白| 久久久精品人体av艺术| 免费在线视频一区| 欧美精品国产精品| 亚洲乱码国产乱码精品精小说| 国产一区二区三区精品欧美日韩一区二区三区 | 欧美精选在线播放| 亚洲男人的天堂一区二区| 国产寡妇亲子伦一区二区| 91精品国产色综合久久不卡电影 | 粉嫩av一区二区三区| 日韩欧美电影一二三| 亚洲电影欧美电影有声小说| 99麻豆久久久国产精品免费| 国产亚洲欧美激情| 国产一区二区免费视频| 欧美一卡二卡在线| 青青草国产精品亚洲专区无| 欧美女孩性生活视频| 香蕉成人啪国产精品视频综合网| 欧美偷拍一区二区| 午夜激情综合网| 6080日韩午夜伦伦午夜伦| 丝瓜av网站精品一区二区| 欧美精品久久久久久久久老牛影院| 婷婷开心久久网| 欧美剧情电影在线观看完整版免费励志电影 | 久久99热99|