?? lcddrive.c
字號:
* 入口參數(shù):dat 要填充的數(shù)據(jù)
* 出口參數(shù):無
***********************************************************************/
void LCD_FillAll(uint8 dat)
{ uint32 i;
LCD_WriteTCommand3(LCD_ADR_POS, 0x00, 0x00); // 置地址指針
LCD_WriteTCommand1(LCD_AUT_WR); // 自動寫
for(i=0;i<128*30;i++)
{ LCD_WriteTData1(dat); // 寫數(shù)據(jù)
}
LCD_WriteTCommand1(LCD_AUT_OVR); // 自動寫結(jié)束
LCD_WriteTCommand3(LCD_ADR_POS,0x00,0x00); // 重置地址指針
}
/****************************************************************************
* 名稱:LCD_UpdatePoint()
* 功能:在指定位置上畫點(diǎn),刷新某一點(diǎn)。
* 入口參數(shù): x 指定點(diǎn)所在列的位置
* y 指定點(diǎn)所在行的位置
* 出口參數(shù):返回值為1時表示操作成功,為0時表示操作失敗。
* 說明:操作失敗原因是指定地址超出緩沖區(qū)范圍。
****************************************************************************/
void LCD_UpdatePoint(uint32 x, uint32 y)
{ uint32 addr;
/* 找出目標(biāo)地址 */
addr = y*(GUI_LCM_XMAX>>3) + (x>>3);
LCD_WriteTCommand3(LCD_ADR_POS, addr&0xFF, addr>>8); // 置地址指針
/* 輸出數(shù)據(jù) */
LCD_WriteTCommand2(LCD_INC_WR, gui_disp_buf[y][x>>3]);
}
/****************************************************************************
* 與LCM相關(guān)的GUI接口函數(shù)
****************************************************************************/
/****************************************************************************
* 名稱:GUI_FillSCR()
* 功能:全屏填充。直接使用數(shù)據(jù)填充顯示緩沖區(qū)。
* 入口參數(shù):dat 填充的數(shù)據(jù)(對于黑白色LCM,為0的點(diǎn)滅,為1的點(diǎn)顯示)
* 出口參數(shù):無
****************************************************************************/
void GUI_FillSCR(uint8 dat)
{ uint32 i, j;
for(i=0; i<GUI_LCM_YMAX; i++) // 歷遍所有行
{ for(j=0; j<GUI_LCM_XMAX/8; j++) // 歷遍所有行
{ gui_disp_buf[i][j] = dat; // 填充數(shù)據(jù)
}
}
/* 填充LCM */
LCD_FillAll(dat);
}
/****************************************************************************
* 名稱:GUI_Initialize()
* 功能:初始化GUI,包括初始化顯示緩沖區(qū),初始化LCM并清屏。
* 入口參數(shù):無
* 出口參數(shù):無
****************************************************************************/
void GUI_Initialize(void)
{ LCD_Initialize(); // 初始化LCM模塊工作模式,純圖形模式
GUI_FillSCR(0x00); // 初始化緩沖區(qū)為0x00,并輸出屏幕(清屏)
}
/****************************************************************************
* 名稱:GUI_ClearSCR()
* 功能:清屏。
* 入口參數(shù):無
* 出口參數(shù):無
* 說明:用戶根據(jù)LCM的實(shí)際情況編寫此函數(shù)。
****************************************************************************/
void GUI_ClearSCR(void)
{ GUI_FillSCR(0x00);
}
uint8 const DCB_HEX_TAB[8] = {0x80, 0x40, 0x20, 0x10, 0x08, 0x04, 0x02, 0x01};
/****************************************************************************
* 名稱:GUI_Point()
* 功能:在指定位置上畫點(diǎn)。
* 入口參數(shù): x 指定點(diǎn)所在列的位置
* y 指定點(diǎn)所在行的位置
* color 顯示顏色(對于黑白色LCM,為0時滅,為1時顯示)
* 出口參數(shù):返回值為1時表示操作成功,為0時表示操作失敗。(操作失敗原因是指定地址超出有
* 效范圍)
* 說明:用戶根據(jù)LCM的實(shí)際情況編寫此函數(shù)。對于單色,只有一個位有效,則要使用左移的方法
* 實(shí)現(xiàn)point_dat = (point_dat&MASK_TAB [i]) | (color<<n),其它位數(shù)的一樣
* 處理。
****************************************************************************/
uint8 GUI_Point(uint32 x, uint32 y, TCOLOR color)
{ /* 參數(shù)過濾 */
if(x>=GUI_LCM_XMAX) return(0);
if(y>=GUI_LCM_YMAX) return(0);
/* 設(shè)置緩沖區(qū)相應(yīng)的點(diǎn) */
if( (color&0x01) != 0 ) gui_disp_buf[y][x>>3] |= DCB_HEX_TAB[x&0x07];
else gui_disp_buf[y][x>>3] &= (~DCB_HEX_TAB[x&0x07]);
/* 刷新顯示 */
LCD_UpdatePoint(x, y);
return(1);
}
/****************************************************************************
* 名稱:GUI_ReadPoint()
* 功能:讀取指定點(diǎn)的顏色。
* 入口參數(shù):x 指定點(diǎn)所在列的位置
* y 指定點(diǎn)所在行的位置
* ret 保存顏色值的指針
* 出口參數(shù):返回0時表示指定地址超出有效范圍。
* 說明:對于單色,設(shè)置ret的d0位為1或0,4級灰度則為d0、d1有效,8位RGB則d0--d7有效,
* RGB結(jié)構(gòu)則R、G、B變量有效。
****************************************************************************/
int GUI_ReadPoint(uint32 x, uint32 y, TCOLOR *ret)
{ TCOLOR bak;
/* 參數(shù)過濾 */
if(x>=GUI_LCM_XMAX) return(0);
if(y>=GUI_LCM_YMAX) return(0);
/* 取得該點(diǎn)顏色(用戶自行更改) */
bak = gui_disp_buf[y][x>>3];
if( (bak&DCB_HEX_TAB[x&0x07])!=0 ) *ret = 1;
else *ret = 0;
return(1);
}
/****************************************************************************
* 名稱:GUI_HLine()
* 功能:畫水平線。
* 入口參數(shù): x0 水平線起點(diǎn)所在列的位置
* y0 水平線起點(diǎn)所在行的位置
* x1 水平線終點(diǎn)所在列的位置
* color 顯示顏色(對于黑白色LCM,為0時滅,為1時顯示)
* 出口參數(shù):無
* 說明:操作失敗原因是指定地址超出緩沖區(qū)范圍。
****************************************************************************/
void GUI_HLine(uint32 x0, uint32 y0, uint32 x1, uint8 color)
{ uint32 bak;
if(x0>x1) // 對x0、x1大小進(jìn)行排列,以便畫圖
{ bak = x1;
x1 = x0;
x0 = bak;
}
if(x0==x1)
{ GUI_Point(x0, y0, color);
return;
}
do
{ /* 設(shè)置相應(yīng)的點(diǎn)為1 */
if(0!=color) gui_disp_buf[y0][x0>>3] |= DCB_HEX_TAB[x0&0x07];
else gui_disp_buf[y0][x0>>3] &= (~DCB_HEX_TAB[x0&0x07]);
/* 刷新顯示(一次刷新一字節(jié)) */
if( (x0&0x07)==0x07 ) LCD_UpdatePoint(x0, y0);
x0++;
}while(x1>x0);
/* 對最后一點(diǎn)顯示操作 */
if(0!=color) gui_disp_buf[y0][x0>>3] |= DCB_HEX_TAB[x0&0x07];
else gui_disp_buf[y0][x0>>3] &= (~DCB_HEX_TAB[x0&0x07]);
LCD_UpdatePoint(x0, y0);
}
/****************************************************************************
* 名稱:GUI_RLine()
* 功能:畫垂直線。
* 入口參數(shù): x0 垂直線起點(diǎn)所在列的位置
* y0 垂直線起點(diǎn)所在行的位置
* y1 垂直線終點(diǎn)所在行的位置
* color 顯示顏色(對于黑白色LCM,為0時滅,為1時顯示)
* 出口參數(shù):無
* 說明:操作失敗原因是指定地址超出緩沖區(qū)范圍。
****************************************************************************/
void GUI_RLine(uint32 x0, uint32 y0, uint32 y1, uint8 color)
{ uint32 bak;
if(y0>y1) // 對y0、y1大小進(jìn)行排列,以便畫圖
{ bak = y1;
y1 = y0;
y0 = bak;
}
if(y0==y1)
{ GUI_Point(x0, y0, color);
return;
}
do
{ GUI_Point(x0, y0, color); // 逐點(diǎn)顯示,描出垂直線
y0++;
}while(y1>y0);
GUI_Point(x0, y0, color);
}
?? 快捷鍵說明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -