`
nathan09
  • 浏览: 155513 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
文章分类
社区版块
存档分类
最新评论

移植ucgui到s3c2410十大步

 
阅读更多

1.编写驱动,主要为Lcd驱动和触摸屏驱动:
lcd驱动实现画点函数LCD2410_SetPixel(x,y,c)。对dm2410实验板上的lcd,左上为原点(0,0)
触摸屏驱动计算出触摸屏的坐标(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驱动函数的连接:
在LCDWin.c中,去掉无用的头文件包含。
#define SETPIXEL(x, y, c) LCD2410_SetPixel(x, y, c)
#define GETPIXEL(x, y) LCD2410_GetPixel(x,y)
即将“LCDSIM_XX”改成“LCD2410_XX”,这两个函数位于lcd驱动文件中。

6.某些编译器不会初始化全局变量,因此做如下事:
1)修改如下函数为:(位于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)自己编写如下函数:
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;
}
该函数应在GUI_Init()调用之前调用。

7.由于没有加入ucos操作系统,自己编写如下函数模拟延时:

int ost = 0;
void My_X_Delay(int p)
{
int i = 0;
int j=0;
for(i=0; i<p; ++i)
for(j=0; j<p; ++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.修改如下函数,接入lcd的初始化:(位于LCD.c)
int LCD_Init(void) {
int r;
GUI_DEBUG_LOG("/nLCD_Init...");
LCD_SetClipRectMax();
if ((r = LCD2410_Init()) != 0) //LCD2410_Init(),设置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<ms*10; ++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(); //此处接入触摸屏的中断设置
GUI_TOUCH_SetDefaultCalibration();//关键函数
}
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.为了响应触摸屏,做如下事:
1)在触摸屏中断中,获得触摸坐标后,应调用如下函数:
GUI_TOUCH_Exec();
2)如下修改函数 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 <xMin) | (x>xMax) | (y <yMin) | (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 */
}

注:若发现显示较慢,看看是否开启了Cache。也可适当修改DrawBitmap函数。

本文属原创,转贴请注明出处。

欢迎来信交流:hongyhm@hotmail.com

分享到:
评论

相关推荐

    ucos_II+ucGUI+s3c2410+LCD+触摸屏整合

    ### ucos_II + ucGUI + s3c...通过上述步骤,可以成功地将 uCOS_II 和 ucGUI 移植到 s3c2410 平台上,实现基于 ARM9 的嵌入式系统开发。这种移植不仅可以增强系统的实时性,还可以为用户提供更加友好、直观的操作界面。

    ucosII_ucGUI_s3c2410_LCD.rar_S3C2410 UCGUI_UCGUI TOUCH_uCGUI 触摸屏

    《S3C2410 UCGUI 触摸屏在UCOS-II操作系统中的整合应用》 在嵌入式系统开发领域,S3C2410是一款广泛应用的ARM9微处理器,它集成了高性能的CPU核心以及丰富的外设接口,适合于构建各种嵌入式系统,尤其是涉及到图形...

    s3c2410基于ucosii的移植,以及ucgui

    在嵌入式开发领域,三星的S3C2410是一款非常常见的ARM9处理器,广泛应用于各种嵌入式系统和设备中。本教程将详细阐述如何在S3C2410上移植并运行μC/OS-II(以下简称UCOSII)实时操作系统,并集成UCGUI图形用户界面库...

    UCGUI移植到UCOS-II源码

    在PC104_2410板上移植UCGUI+UCOS-II,首先需要配置S3C2410的硬件环境,包括初始化LCD控制器,设置合适的时钟频率,以及配置其他必要的外设。接着,需要将UCOS-II操作系统内核移植到该平台上,包括编译内核、设置中断...

    FS2410 ucgui+ucos移植的程序

    本文将详细介绍如何在S3C2410处理器平台上,利用ADS1.2开发环境完成ucGUI和uC/OS的移植工作。 首先,S3C2410是一款由Samsung公司推出的基于ARM920T内核的微处理器,广泛应用于各种嵌入式设备中,其高性能和低功耗...

    基于S3C2410的GPS监视界面设计.pdf

    接着,设计团队将uCGUI移植到S3C2410平台,uCGUI是一个用于嵌入式应用的图形支持系统,它独立于处理器和LCD控制器,能提供高效的图形用户界面。在单任务或多任务环境下,uCGUI都能支持各种尺寸的显示屏,简化了在...

    ucos_ucgui.rar

    移植UCOS到S3C2410,意味着我们需要配置和编译UCOS源码,使其适应S3C2410的硬件环境,包括中断服务程序、内存管理、时钟管理等。 接下来,我们要介绍UCGUI,它是Microchip Technology公司开发的一款轻量级图形用户...

    用Embest IDE实现2410+uc/os-ii+ucGUI的工程以及代码

    在移植过程中,我们需要编写驱动程序,使ucGUI能够与S3C2410的显示控制器通信。这可能涉及到初始化LCD控制器、设置时钟、配置DMA等操作。同时,还需要处理触摸屏的中断和数据传输,以便用户能通过触摸屏幕进行交互。...

    lcd.rar_2410 LCD_LQ080V3DG01_gui ucos_ucgui_ucos

    1. **2410_lcd**:指的是三星S3C2410处理器,这是一个常见的ARM9微处理器,常用于嵌入式系统开发,特别是开发LCD显示功能。 2. **lq080v3dg01**:这是液晶显示器的型号,LQ080V3DG01是一种80x64点阵的单色STN LCD...

Global site tag (gtag.js) - Google Analytics