移植ucgui到s3c2410十大步

发布者:算法之手最新更新时间:2016-12-03 来源: eefocus关键字:移植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   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.修改如下函数,接入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   ;
}
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 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 */
}

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


关键字:移植ucgui  s3c2410 引用地址:移植ucgui到s3c2410十大步

上一篇:怎样数s3c2410的interrupt controller中的中断源数量
下一篇:UDA1341框架分析

推荐阅读最新更新时间:2024-03-16 15:22

基于嵌入式Linux平台的图像采集与传输设计
引言   随着嵌入式技术的迅猛发展和Linux在信息行业中的广泛应用,视频采集与传输系统作为远程视频监控、可视电话会议和工业自动控制领域的一项核心技术,近年来已经得到了飞速的发展。本文在基于嵌入式Linux系统平台上,采用USB摄像头捕捉视频信号,利用V4L内核应用编程接口函数,实现了视频连续帧图像的采集,并保存成文件的形式利用无线传输方式传输给接收端。这里着重讨论视频采集发送端的实现。   1 系统组成   1.1 统的硬件构成   本系统包括发送端和接收端2部分,两部分均采用Samsung公司生产的S3C2410处理器做硬件开发平台。S3C2410在片上集成了丰富的组件:分开的16 KB指令Cache和16 KB数据
[单片机]
基于嵌入式Linux平台的图像采集与传输设计
S3C2410中断处理
在介绍2410的中断处理之前,我们不得不先看看先把ARM的异常向量表(Exception Vectors),下面对异常向量表(Exception Vectors),做一个简单的介绍: ARM的异常向量表一般存放在0x00000000处,ARM920T能处理有7个异常,他们分别是:Reset,Undefined instruction,Software Interrupt,Abort (prefetch),Abort (data),IRQ,FIQ 下面是系统源码片段: _start: b Handle_Reset b HandleUndef b HandleSWI b HandlePrefetchAbort b Ha
[单片机]
基于Linux和S3C2410的嵌入式图象传输系统设计
1 引言 如何更好的获得监控现场的图象数据一直是棘手的一个问题,传统的方法是采用CCD摄象机获取现场的视频信息,这种方法易于实现,但成本较高。随着ARM系列处理器应用的越来越广和基于linux的嵌入式技术的迅速发展,利用linux自身带有的TCP/IP协议来实现远程监控、图象传输已成为可能。本文提出的正是一种这样的方法,利用市场上很常见的中星微系列的USB摄象头来得到现场的图象数据,利用linux内核中的Video4Linux编程接口函数采集图象,并把得到的图象通过Internet传输到上位机PC上,在PC上实现图象的保存和显示。 2 硬件系统设计原理 系统的硬件功能框图如图1所示,CPU采用的是三星公司的S3C2410。该
[应用]
触摸屏的移植s3c2410
触摸屏驱动的名称: dev/mounse0 我们看一下/proc/devices # cat /proc/devices Character devices: 6 lp 7 vcs 10 misc 13 input 29 fb 90 mtd 查看触摸屏: cat /proc/interrupts 53: 596 s3c-ext eth0 60: 1 s3c-ext s3c-mci 70: 28 s3c-uart0 s3c2410-uart 71: 832 s3c-uart0 s3c2410-uart 79: 16 s3c-
[单片机]
s3c2410 RTC驱动框架linux内核源码分析
/********************************************************************************************************* * @Description:s3c2410的rtc驱动的实现,rtc(real time clock)实时时钟的驱动是个很好的 * 理解如果编写驱动的硬件,它包括了最基本的硬中断,软中断的底层机制; * s3c2410的RTC驱动的实现个人认为更是对linux设备驱动一个很好的例子,他是通过二层结构来 * 实现的一个驱动,上层是一个arm common的公共层,对上提供标准的通用的RTC操作接口,下层由 * 我
[单片机]
<font color='red'>s3c2410</font> RTC驱动框架linux内核源码分析
ucos II+ucGUI+s3c2410+LCD+触摸屏整合
注意:由于编译器(ads1.2或2.2)对全局变量初始化为0的不完全支持,有时必须手动初始化为0,切记!!! 一、ucos II移植到ARM9 s3c2410 可从官网下载移植代码,基本无需改动。 在os_cpu_a.s中的函数UCOS_IRQHandler中的bl OSIntEnter和bl C_IRQHandler之间插入如下代码(见邵贝贝,第2版,第104页的说明:L3.18(4) ): ldr r0, =OSIntNesting ldrb r0, cmp r0,#1 bne XX ldr r0,=OSTCBCur ldr r1, st
[单片机]
基于S3C2410的嵌入式Linux系统构建
目前,在嵌入式系统中基于ARM微核的嵌入式处理器已经成为市场主流。随着ARM技术的广泛应用,建立面向ARM构架的嵌入式操作系统成为当前研究的热点问题。   已经涌现出许多嵌入式操作系统,如VxWork,windows-CE,PalmOS,Linux等。在众多的嵌入式操作系统中,Linux以其开源代码及免费使用倍受开发人员的喜爱。本文选用的微处理器S3C2410是基于32位ARM920T内核的微处理器,基于此处理器构造一Linux嵌入式操作系统,将其移植到基于32位的ARM920T内核的系统中,在此基础上进行应用程序开发。 l开发环境介绍 1.1 基于S3C2410 ARM920T的硬件平台 该系统
[单片机]
S3C2410启动代码详解(1)
花了好几在的时间研究S3C2410r的启动代码,终于看完!在参考了一些资料后,加上自己的理解,留下点笔记。有些地方可能不正确,有待改正: 通常,启动代码是指CPU复位后到进入C语言的main函数之前需要执行的那段汇编代码.这是由于C语言程序的运行需要具备一定的条件,比如:分配好外部数据空闿堆栈空间和中断入口等筿另外汇编代码可以更直接的对硬件进行操使效率更高. 通常启动代码是放圿410init.s汇编文件;特殊功能寄存器定义在2410addr.s;Memory Bank 配置在mencfg.s;还有系统的选项等在option.s文件;2410init.s不仅包括复位后执行的代码,还包括CPU进入掉电模式,产生中断等和处理器
[单片机]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved