當(dāng)前位置:首頁 > 單片機 > 單片機
[導(dǎo)讀]1.編寫驅(qū)動,主要為Lcd驅(qū)動和觸摸屏驅(qū)動:lcd驅(qū)動實現(xiàn)畫點函數(shù)LCD2410_SetPixel(x,y,c)。對dm2410實驗板上的lcd,左上為原點(0,0)觸摸屏驅(qū)動計算出觸摸屏的坐標(x,y),對dm2410實驗板上的觸摸屏,左下為原點,

1.編寫驅(qū)動,主要為Lcd驅(qū)動和觸摸屏驅(qū)動:
lcd驅(qū)動實現(xiàn)畫點函數(shù)LCD2410_SetPixel(x,y,c)。對dm2410實驗板上的lcd,左上為原點(0,0)
觸摸屏驅(qū)動計算出觸摸屏的坐標(x,y),對dm2410實驗板上的觸摸屏,左下為原點,但不一定是(0,0)

2.觸摸屏校準:
測出左下最小坐標minX,minY和右上最大坐標maxX,maxY
如下填寫GUITouchConf.h:
#define GUI_TOUCH_AD_LEFT minX
#define GUI_TOUCH_AD_TOP maxY

#define GUI_TOUCH_AD_RIGHT maxX
#define GUI_TOUCH_AD_BOTTOM minY

#define GUI_TOUCH_SWAP_XY 0

#define GUI_TOUCH_MIRROR_X 1
#define GUI_TOUCH_MIRROR_Y 1

3.如下填寫GUIConf.h:
#define GUI_OS (1) /* Compile with multitasking support */
#define GUI_SUPPORT_TOUCH (1) /* Support a touch screen (req. win-manager) */
#define GUI_SUPPORT_UNICODE (1) /* Support mixed ASCII/UNICODE strings */
#define GUI_SUPPORT_CHINESE (1)

#define GUI_DEFAULT_FONT &GUI_Font6x8
#define GUI_ALLOC_SIZE 22500 /* Size of dynamic memory ... For WM and memory devices*/

#define GUI_WINSUPPORT 1 /* Window manager package available */
#define GUI_SUPPORT_MEMDEV 1 /* Memory devices available */
#define GUI_SUPPORT_AA 1

4.如下填寫LCDConf.h:
#define LCD_XSIZE (800) /* X-resolution of LCD, Logical coor. */
#define LCD_YSIZE (480) /* Y-resolution of LCD, Logical coor. */

#define LCD_BITSPERPIXEL (16)
#define LCD_CONTROLLER 1
#define LCD_SWAP_RB_0 1

5.ucgui與lcd驅(qū)動函數(shù)的連接:
在LCDWin.c中,去掉無用的頭文件包含。
#define SETPIXEL(x, y, c) LCD2410_SetPixel(x, y, c)
#define GETPIXEL(x, y) LCD2410_GetPixel(x,y)
即將“LCDSIM_XX”改成“LCD2410_XX”,這兩個函數(shù)位于lcd驅(qū)動文件中。

6.某些編譯器不會初始化全局變量,因此做如下事:
1)修改如下函數(shù)為:(位于GUICore.c)
static void _InitContext(GUI_CONTEXT* pContext) {

memset(pContext,0,sizeof(GUI_CONTEXT));//add

#if GUI_SUPPORT_MEMDEV
GUI_SelectLCD();
#else
LCD_SetClipRectMax();//LCD_L0_GetRect
#endif
pContext->pLCD_HL = &LCD_HL_APIList;
pContext->pAFont = GUI_DEFAULT_FONT;
pContext->pClipRect_HL = &GUI_Context.ClipRect;
pContext->PenSize = 1;
pContext->DrawMode = GUI_DRAWMODE_NORMAL;//add
pContext->TextMode = GUI_TEXTMODE_NORMAL;//add
pContext->TextAlign = GUI_TA_LEFT|GUI_TA_TOP;//add

pContext->AA_HiResEnable = 0;//add

/* Variables in WM module */
#if GUI_WINSUPPORT
pContext->hAWin = WM_GetDesktopWindow();
#endif
/* Variables in GUI_AA module */
pContext->AA_Factor = 3;
LCD_SetBkColor(GUI_DEFAULT_BKCOLOR);
LCD_SetColor(GUI_DEFAULT_COLOR);
}
2)自己編寫如下函數(shù):
void MyInit()
{
IsInitialized = 0;//MemDev
_IsInited = 0;//Win
WM__CreateFlags = 0;

GUI_CURSOR_pfTempHide = NULL;
GUI_Context.hDevData = 0;

WM__hCapture=0;
WM__hWinFocus=0;

WM_pfPollPID = 0;
WM_pfHandlePID = 0;

GUI_pfTimerExec = 0;

_KeyMsgCnt = 0;
}
該函數(shù)應(yīng)在GUI_Init()調(diào)用之前調(diào)用。

7.由于沒有加入ucos操作系統(tǒng),自己編寫如下函數(shù)模擬延時:

int ost = 0;
void My_X_Delay(int p)
{
int i = 0;
int j=0;
for(i=0; i for(j=0; j
ost += p;
}
void MyDly(int Period)
{

int EndTime;
int tRem; /* remaining Time */
ost = 0;
EndTime = ost + Period;
while (tRem = EndTime - ost, tRem>0) {
GUI_Exec();
My_X_Delay((tRem >100) ? 100 : tRem);
}
}
因此將示例中的GUI_Delay(x)該為MyDly(x).

8.修改如下函數(shù),接入lcd的初始化:(位于LCD.c)
int LCD_Init(void) {
int r;
GUI_DEBUG_LOG("nLCD_Init...");
LCD_SetClipRectMax();
if ((r = LCD2410_Init()) != 0) //LCD2410_Init(),設(shè)置lcd寄存器
return r;
#if LCD_NUM_DISPLAYS > 1
if ((r = LCD_L0_1_Init()) != 0)
return r;
#endif
LCD_InitLUT();
/* Clear video memory */
LCD_SetDrawMode(GUI_DRAWMODE_REV);
LCD_FillRect(0,0, GUI_XMAX, GUI_YMAX);
LCD_SetDrawMode(0);
/* Switch LCD on */
LCD_On();
return 0;
}

9.如下修改GUI_X.c:
int GUI_X_GetTime(void)
{
return 0;
// return OSTimeGet();
}

void GUI_X_Delay(int ms)
{
// OSTimeDly(ms);
int i=0;
for(i=0; i ;
}
void GUI_X_ExecIdle(void) {
GUI_X_Delay(1);
}
void GUI_X_Unlock(void)
{
// OSSemPost(DispSem);
}
void GUI_X_Lock(void)
{
// U8 err;
// OSSemPend(DispSem, 0, &err);
}

U32 GUI_X_GetTaskId(void)
{
// if(bGUIInitialized){
// return ((INT32U)(OSTCBCur->OSTCBPrio)); /* < 64(è???ó??è??) */
// }
// else{
return 100; /* ??òa±£?¤>64?′?é */
// }
}

void GUI_X_InitOS(void)
{
// DispSem = OSSemCreate(1);
}
void GUI_X_ErrorOut(const char *s){}

void GUI_X_Warn(const char *s){}

/*********************************************************************
*
* GUI_X_Init()
*
* Note:
* GUI_X_Init() is called from GUI_Init is a possibility to init
* some hardware which needs to be up and running before the GUI.
* If not required, leave this routine blank.
*/

void GUI_X_Init(void) {
SetTsInterrupt(); //此處接入觸摸屏的中斷設(shè)置
GUI_TOUCH_SetDefaultCalibration();//關(guān)鍵函數(shù)
}
int GUI_TOUCH_X_MeasureX(void) {
return TX;
}

int GUI_TOUCH_X_MeasureY(void){
return TY;
}

void GUI_TOUCH_X_ActivateX(void) {}
void GUI_TOUCH_X_ActivateY(void) {}
void GUI_X_Log(const char *s) {}

10.為了響應(yīng)觸摸屏,做如下事:
1)在觸摸屏中斷中,獲得觸摸坐標后,應(yīng)調(diào)用如下函數(shù):
GUI_TOUCH_Exec();
2)如下修改函數(shù) GUI_TOUCH_Exec():
void GUI_TOUCH_Exec(void) {
#ifndef WIN32
static U8 ReadState;
int x,y;
/* calculate Min / Max values */
if (xyMinMax[GUI_COORD_X].Min < xyMinMax[GUI_COORD_X].Max) {
xMin = xyMinMax[GUI_COORD_X].Min;
xMax = xyMinMax[GUI_COORD_X].Max;
} else {
xMax = xyMinMax[GUI_COORD_X].Min;
xMin = xyMinMax[GUI_COORD_X].Max;
}
if (xyMinMax[GUI_COORD_Y].Min < xyMinMax[GUI_COORD_Y].Max) {
yMin = xyMinMax[GUI_COORD_Y].Min;
yMax = xyMinMax[GUI_COORD_Y].Max;
} else {
yMax = xyMinMax[GUI_COORD_Y].Min;
yMin = xyMinMax[GUI_COORD_Y].Max;
}
/* Execute the state machine which reads the touch */
//switch (ReadState) {
//case 0:
yPhys = TOUCH_X_MeasureY();
// TOUCH_X_ActivateY(); /* Prepare X- measurement */
// ReadState++;
// break;
//default:
xPhys = TOUCH_X_MeasureX();
// TOUCH_X_ActivateX(); /* Prepare Y- measurement */
/* Convert values into logical values */
#if !GUI_TOUCH_SWAP_XY /* Is X/Y swapped ? */
x = xPhys;
y = yPhys;
#else
x = yPhys;
y = xPhys;
#endif

if ((x xMax) | (y yMax)) {
GUI_TOUCH_StoreUnstable(-1,-1);
} else {
x = AD2X(x);
y = AD2Y(y);
GUI_TOUCH_StoreUnstable(x,y);
}
/* Reset state machine */
//ReadState=0;
// break;
//}
#endif /* WIN32 */
}

注:若發(fā)現(xiàn)顯示較慢,看看是否開啟了Cache。也可適當(dāng)修改DrawBitmap函數(shù)。


本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉