欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136
標題:
stm32串行st7920 128*64屏顯示字符源程序
[打印本頁]
作者:
GAOXIANG123
時間:
2017-7-18 20:10
標題:
stm32串行st7920 128*64屏顯示字符源程序
stm32單片機串行方式控制st7920 128*64屏顯示字符,附件里面有2個程序,全部都是經過測試ok的
b00d5298a8551fe631848e1e1e5d996a_604.jpg
(31.21 KB, 下載次數: 87)
下載附件
2017-7-19 01:11 上傳
單片機源程序如下:
/**********************************************************
* @ File name -> lcd12864.c
* @ Version -> V1.1.2
* @ Date -> 11-30-13
* @ Brief -> LCD12864驅動函數
* 適用于ST7920驅動芯片
V1.1
* @ Revise -> A、修正操作命令宏定義。
* @ -> B、增加串口、并口轉換宏定義,增加對高速度MCU控制通訊頻率延時函數
* @ -> C、顯示字符串函數增加顯示長度選擇,即顯示多少個ASCII可顯示字符,漢字x2即可
* @ -> D、去掉顯示數組函數,合并在字符串顯示里
V1.1.1
* @ Revise -> 增加字符串顯示函數,可以從要顯示的數組中任意位置顯示一定長度字符串
V1.1.2
* @ Revise -> A、增加對低速晶振系統的MCU通訊頻率是否使用的宏定義
* @ -> B、增加在檢測液晶忙超時退出,預防死循環
**********************************************************/
#include "lcd12864.h"
/**********************************************************
自定義顯示字符
**********************************************************/
#define CGRAM_Value 64 //寫入CGRAM數量
u8 code CGROM_Code[] = {
//天線圖形
0xff,0xff,0x80,0x01,0xbf,0xfd,0xdf,0xfb,0xec,0x37,0xf6,0x6f,0xfb,0xdf,0xfd,0xbf,
0xfe,0x7f,0xfe,0x7f,0xfe,0x7f,0xfe,0x7f,0xfe,0x7f,0xfe,0x7f,0xfe,0x7f,0xff,0xff,
//攝氏圖形
// 0x00,0x00,0x00,0x00,0x00,0x00,0x1c,0x70,0x14,0xd8,0x1d,0x88,0x01,0x80,0x01,0x80,
// 0x01,0x80,0x01,0x80,0x01,0x88,0x00,0xc8,0x00,0x70,0x00,0x00,0x00,0x00,0x00,0x00,
//藍牙圖形
0x07,0xe0,0x0e,0x70,0x1e,0xb8,0x3e,0xdc,0x36,0xec,0x3a,0xdc,0x3c,0xbc,0x3e,0x7c,
0x3e,0x7c,0x3c,0xbc,0x3a,0xdc,0x36,0xec,0x3e,0xdc,0x1e,0xb8,0x0e,0x70,0x07,0xe0,
//CD圖形
0xff,0xff,0xff,0xff,0xff,0xff,0xe3,0x07,0xc9,0xb3,0x9d,0xb9,0x9f,0xb9,0x9f,0xb9,
0x9f,0xb9,0x9f,0xb9,0x9d,0xb9,0xc9,0xb3,0xe3,0x07,0xff,0xff,0xff,0xff,0xff,0xff,
//右指向手型
0x00,0x00,0x1e,0x00,0x12,0x00,0x73,0xfc,0x52,0x02,0x52,0x1c,0x53,0xe0,0x52,0x10,
0x53,0xe0,0x52,0x10,0x53,0xe0,0x52,0x10,0x73,0xe0,0x12,0x00,0x1e,0x00,0x00,0x00
};
//=========================================================
#ifdef LCD_Work_Mode //如果定義了,則使用并口工作模式
//=========================================================
/**********************************************************
* 函數功能 ---> LCD12864判斷忙
* 入口參數 ---> none
* 返回數值 ---> none
* 功能說明 ---> none
**********************************************************/
void LCD_Check_Busy(void)
{
static u16 busytimeout; //忙超時
//=====================================================
#ifdef LCD_USE_DELAY /* 定義了則使用延時調整通訊頻率 */
//=====================================================
ktdata = 0xf0; //數據口全部置位
do
{
busytimeout++;
if(busytimeout > 300) break;
LCD_RS = 0;
LCD_Delay();
LCD_RW = 1;
LCD_Delay();
LCD_EN = 1;
LCD_Delay();
}while(ktdata & LCD_Busy == LCD_Busy); //等待LCD忙完
LCD_EN = 0;
//=====================================================
#else /* 沒定義則不使用 */
//=====================================================
ktdata = 0xf0; //數據口全部置位
do
{
busytimeout++;
if(busytimeout > 300) break;
LCD_RS = 0;
LCD_RW = 1;
LCD_EN = 1;
// LCD_Delay();
}while(ktdata & LCD_Busy == LCD_Busy); //等待LCD忙完
LCD_EN = 0;
//=====================================================
#endif
//=====================================================
if(busytimeout >= 300) printf("LCD Busy TimeOut...\r\n");
busytimeout = 0;
}
/**********************************************************
* 函數功能 ---> LCD寫入一個字節命令或者數據,判斷忙標志(8位數據一次發送完畢)
* 入口參數 ---> dat:要寫入的字節
* ord:判斷dat是命令還是數據依據,“0”為命令,“1”為數據
* 返回數值 ---> none
* 功能說明 ---> none
**********************************************************/
void LCD_Write_Byte(u8 dat,u8 ord)
{
//=====================================================
#ifdef LCD_USE_DELAY /* 定義了則使用延時調整通訊頻率 */
//=====================================================
LCD_Check_Busy(); //判斷是否在忙?
LCD_EN = 0;
LCD_Delay();
LCD_RW = 0;
LCD_Delay();
if(ord & 0x01) LCD_RS = 1; //放上數據或者命令判斷位
else LCD_RS = 0;
LCD_EN = 1;
LCD_Delay();
ktdata = dat; //放入數據
LCD_Delay();
LCD_EN = 0;
//=====================================================
#else /* 沒定義則不使用 */
//=====================================================
LCD_Check_Busy(); //判斷是否在忙?
LCD_EN = 0;
LCD_RW = 0;
if(ord & 0x01) LCD_RS = 1; //放上數據或者命令判斷位
else LCD_RS = 0;
LCD_EN = 1;
ktdata = dat; //放入數據
LCD_EN = 0;
//=====================================================
#endif
//=====================================================
}
//=========================================================
#else //沒定義則使用串口通訊模式
//=========================================================
/**********************************************************
* 函數功能 ---> LCD啟動字節
* 入口參數 ---> dt:傳輸的字節,高5位在函數內部設定為1
* 只是確定RW和RS為,最后那位也是內部確定
* 返回數值 ---> none
* 功能說明 ---> 首先傳送一個啟動字節,送入連續5個“1”用來啟
* 動一個周期,此時傳輸計數被重置,并且串行傳輸
* 被同步,緊接著的兩個位指定傳輸方向(R/W,確
* 定是讀還是寫)和傳輸性質(RS,確定是命令寄存
* 器還是數據寄存器),最后的第八位是一個“0”
**********************************************************/
void LCD12864_Start(u8 dt)
{
u8 dat,j;
dat = dt | 0xf8; //高5位設定為“1”,第八位設定為“0”
LCD_SCL = 0;
LCD_Delay();LCD_Delay();
LCD_CS = 1; //選中顯示屏,高電平有效
for(j = 0;j < 8;j++)
{
if(dat & 0x80) LCD_SDA = 1; //放數據到數據線
else LCD_SDA = 0;
LCD_Delay();LCD_Delay();LCD_Delay();
LCD_SCL = 1; //發送數據,上升沿有效
LCD_Delay();LCD_Delay();LCD_Delay();
LCD_SCL = 0;
dat <<= 1; //左移一位,先發的是高位
}
LCD_Delay();LCD_Delay();LCD_Delay();
LCD_SCL = 0;
LCD_Delay();LCD_Delay();LCD_Delay(); //等待硬件反應(等待數據發送完全)
}
/**********************************************************
* 函數功能 ---> LCD寫入一個字節命令或者數據
* 入口參數 ---> dat:要寫入的命令或者數據
* ord:命令或者數據判斷為。0為命令,1為數據
* 返回數值 ---> none
* 功能說明 ---> none
**********************************************************/
void LCD_Write_Byte(u8 dat,u8 ord)
{
u8 tem;
u8 i,j;
tem = dat & 0xf0; //先發送高4位
LCD12864_Start((ord << 1) | 0xf0); //置RW為“0”、RS為“ord”并啟動串行傳輸為數據格式
for(j = 0;j < 2;j++) //一個字節數據或者命令分兩次發送
{
LCD_SCL = 0; //允許數據線電平變化
LCD_Delay();LCD_Delay();LCD_Delay();
for(i = 0;i < 8;i++)
{
if(tem & 0x80) LCD_SDA = 1; //放上數據,屏蔽低4位
else LCD_SDA = 0;
LCD_Delay();LCD_Delay();LCD_Delay();
LCD_SCL = 1; //發送數據,上升沿有效
LCD_Delay();LCD_Delay();LCD_Delay();
LCD_SCL = 0;
tem <<= 1; //左移一位,先發的是高位
}
tem = (dat << 4) & 0xf0; //發完高4位,再次發送低4位
}
LCD_Delay();LCD_Delay();LCD_Delay();
LCD_SDA = 0;
LCD_Delay();LCD_Delay();LCD_Delay();
LCD_SCL = 0;
LCD_Delay();LCD_Delay();LCD_Delay();
LCD_CS = 0;
LCD_Delay();LCD_Delay();LCD_Delay(); //等待硬件反應(等待數據發送完全)
}
//=========================================================
#endif
//=========================================================
/**********************************************************
* 函數功能 ---> 設置LCD顯示位置
* 入口參數 ---> x:行,取值范圍:1 ~ 4
* y:列,取值范圍:0 ~ 7
* 返回數值 ---> none
* 功能說明 ---> none
**********************************************************/
void LCD_Set_xy(u8 x,u8 y)
{
switch(x)
{
case 1:
LCD_Write_Byte((One_LineAddress + y),0); //寫入操作地址
break;
case 2:
LCD_Write_Byte((Two_LineAddress + y),0); //寫入操作地址
break;
case 3:
LCD_Write_Byte((Three_LineAddress + y),0); //寫入操作地址
break;
case 4:
LCD_Write_Byte((Four_LineAddress + y),0); //寫入操作地址
break;
default:
LCD_Write_Byte((One_LineAddress + y),0); //寫入操作地址
break;
}
}
/**********************************************************
* 函數功能 ---> 寫入自定義字符到LCD的CGRAM
* 入口參數 ---> *data_code:寫入的數組
* 返回數值 ---> none
* 功能說明 ---> none
**********************************************************/
void LCD_Write_CGRAM(u8 *data_code)
{
u8 i;
LCD_Write_Byte(0x34,0); //打開字符擴展指令
LCD_Write_Byte(0x02,0); //SR=0,允許輸入
LCD_Write_Byte(0x30,0); //恢復基本指令
LCD_Write_Byte(0x40,0); //CGRAM地址
for(i = 0;i < CGRAM_Value;i++)
{
LCD_Write_Byte(data_code[i*2],1);
LCD_Write_Byte(data_code[i*2+1],1);
}
}
/**********************************************************
* 函數功能 ---> 顯示一個CGRAM內容
* 入口參數 ---> x:行
* y:列
* *str為要顯示的字符串
* add_h:CGRAM高位地址
* add_l:CGRAM低位地址
* 返回數值 ---> none
* 功能說明 ---> none
**********************************************************/
void Display_CGRAM(u8 x,u8 y,u8 add_h,u8 add_l)
{
LCD_Set_xy(x,y); //設置顯示地址
LCD_Write_Byte(add_h,1);
LCD_Write_Byte(add_l,1);
}
/**********************************************************
* 函數功能 ---> LCD顯示字符串
* 入口參數 ---> x:行
* y:列
* *str:要顯示的字符串
* len:顯示的長度
* 返回數值 ---> none
* 功能說明 ---> 只能從數組的開頭開始顯示len長度字符串
**********************************************************/
void Display_String(u8 x,u8 y,u8 *str,u8 len)
{
LCD_Set_xy(x,y); //設置顯示地址
while(len--)
{
LCD_Write_Byte(*str,1);
str++;
}
}
/**********************************************************
* 函數功能 ---> LCD顯示字符串
* 入口參數 ---> x:行
* y:列
* *str:要顯示的字符串
* len:顯示的長度
* 返回數值 ---> none
* 功能說明 ---> 可以從顯示數組的任意位置starsum開始顯示len長度的字符串
**********************************************************/
void Display_String1(u8 x,u8 y,u8 *str,u8 starsum,u8 len)
{
u8 i;
LCD_Set_xy(x,y); //設置顯示地址
for(i = starsum;i < starsum + len;i++)
{
LCD_Write_Byte(str[i],1);
}
}
/**********************************************************
* 函數功能 ---> LCD寫入GDRAM繪圖
* 入口參數 ---> x:行
* y:列
* width:顯示圖片的寬度
* hieght:顯示圖片的高度
* *bmp:要顯示的字符串
* dis_mode:顯示模式,是半屏顯示還是全屏顯示
* 0:半屏顯示。1:全屏顯示
* 返回數值 ---> none
* 功能說明 ---> none
**********************************************************/
void Display_GDRAM(u8 x,u8 y,u8 width,u8 height,u8 *bmp,u8 dis_mode)
{
u8 i,j,k;
u8 base_x,base_y; //起始坐標
/******全屏繪圖顯示******/
if(dis_mode)
{
switch(x)
{
case 1:
base_y = One_LineAddress + y;
break;
case 2:
base_y = Two_LineAddress + y;
break;
case 3:
base_y = Three_LineAddress + y;
break;
case 4:
base_y = Four_LineAddress + y;
break;
default: break;
}
LCD_Write_Byte(MPU_8bit_Expansion_Draw_Close,0); //擴充指令
LCD_Write_Byte(MPU_8bit_Expansion_Draw_Open,0); //打開繪圖功能
for(j = 0;j < height;j++) //32
{
LCD_Write_Byte(base_y + j,0); //寫入行號,即第幾行開始
LCD_Write_Byte(One_LineAddress,0); //橫坐標的第幾個字節開始寫
for(i = 0;i < width;i++) //上半屏
{
LCD_Write_Byte(bmp[width * j + i],1); //開始寫入數據
}
for(k = 0;k < width;k++) //下半屏
{
LCD_Write_Byte(bmp[width * (j + height) + k],1); //開始寫入數據
}
}
}
/******分開上半屏或者下半屏寫******/
else
{
switch(x) //判斷顯示的橫坐標,確定起始行
{
case 1: //上半屏
base_x = One_LineAddress; //起始地址為0x80
break;
case 2: //下半屏
base_x = One_LineAddress; //起始地址為0x80
break;
case 3: //下半屏
base_x = Three_LineAddress; //起始地址為0x88
break;
default:
break;
}
base_y = base_x + y; //x軸方向的偏移,基地址 + 偏移地址
LCD_Write_Byte(MPU_8bit_Expansion_Draw_Close,0); //擴充指令
LCD_Write_Byte(MPU_8bit_Expansion_Draw_Open,0); //打開繪圖功能
if(x == 1 || x == 3) //直接在同一個半屏的,直接寫完32位數據
{
for(i = 0;i < 32;i++) //寫地址有講究,先寫垂直再寫水平,詳見“設定繪圖RAM地址”說明
{
LCD_Write_Byte(One_LineAddress + i,0); //寫入垂直地址,不管上半屏還是下半屏
LCD_Write_Byte(base_y,0); //寫入水平地址
for(j = 0;j < 2;j++) //兩組8bit數據,組成16bit
{
LCD_Write_Byte(*bmp++,1); //寫入數據
}
}
}
if(x == 2) //數據顯示不在同一半屏上的,先寫上半屏,在寫下半屏
{
for(i = 0;i < 16;i++) //上半屏16行點陣數據
{
LCD_Write_Byte(Two_LineAddress + i,0); //寫入垂直地址
LCD_Write_Byte(base_y,0); //寫入水平地址
for(j = 0;j < 2;j++) //兩組8bit數據,組成16bit
{
LCD_Write_Byte(*bmp++,1); //寫入數據
}
}
for(i = 0;i < 16;i++) //下半屏16行點陣數據
{
LCD_Write_Byte(Three_LineAddress + i,0); //寫入垂直地址
LCD_Write_Byte(base_y + 8,0); //寫入水平地址
for(j = 0;j < 2;j++) //兩組8bit數據,組成16bit
{
LCD_Write_Byte(*bmp++,1); //寫入數據
……………………
…………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼
所有資料51hei提供下載:
STM32F103VCT612864.rar
(263.89 KB, 下載次數: 100)
2017-7-19 01:14 上傳
點擊文件名下載附件
下載積分: 黑幣 -5
lcd12864.zip
(8.03 KB, 下載次數: 83)
2017-7-19 01:14 上傳
點擊文件名下載附件
下載積分: 黑幣 -5
JN12864J使用說明書.pdf
(776.12 KB, 下載次數: 40)
2017-7-19 01:14 上傳
點擊文件名下載附件
下載積分: 黑幣 -5
作者:
by64214
時間:
2017-7-21 19:19
謝謝樓主分享 學習一下 現在能力只能模仿 無力獨立完成
作者:
sean0110
時間:
2018-5-13 20:16
謝謝樓主分享 學習一下 現在能力只能模仿 無力獨立完成
作者:
lzqs
時間:
2018-11-25 11:53
謝謝樓主分享 學習一下 現在能力只能模仿 無力獨立完成
作者:
zhaoxiaolong
時間:
2018-11-26 11:25
謝謝分享 學習一下
作者:
萬能的金果果
時間:
2019-7-29 14:16
謝謝樓主分享,新人學習一下
作者:
萬能的金果果
時間:
2019-7-29 14:16
謝謝樓主分享,學習一下
作者:
ia88k3
時間:
2020-4-7 00:00
謝謝!剛好需要,下來參考一下
歡迎光臨 (http://m.raoushi.com/bbs/)
Powered by Discuz! X3.1