嵌入式Linux系统中的GUI系统的研究与移植

发布者:BlossomWhisper最新更新时间:2009-01-19 来源: 单片机及嵌入式系统应用关键字:嵌入式Linux  GUI  应用与移植  中文化 手机看文章 扫描二维码
随时随地手机看文章

引 言

    嵌入式GUI为嵌入式系统提供了一种应用于特殊场合的人们交互接口。嵌入式GUI要求简单、直观、可靠、占用资源小且反应快速,以适应系统硬件资源有限的条件。另外,由于嵌入式系统硬件本身的特殊性,嵌入式GUI应具备高度可移植性与可裁减性,以适应不同的硬件条件和使用需求。总体来讲,嵌入式GUI具备以下特点:

    *体积小;

    *运行时耗用系统资源小;

    *上层接口与硬件无关,高度可移植;

    *高可靠性;

    *在某些应用场合应具备实时性。

1 基于嵌入式Linux的GUI系统底层实现基础

    一个能够移植到多种硬件平台上的嵌入式GUI系统,应用至少抽象出两类设备:基于图形显示设备(如VGA卡)的图形抽象层GAL(Graphic Abstract Layer),基于输入设备(如键盘,触摸层等)的输入抽象层IAL(Input Abstract Layer)。GAL层完成系统对具体的显示硬件设备的操作,极大程度上隐蔽各种不同硬件的技术实现细节,为诮程序开发人员提供统一的图形编程接口。IAL层则需要实现对于各类不同输入设备的控制操作,提供统一的调用接口。GAL层与IAL层的设计概念,可以极大程序地提高嵌入式GUI的可移植性,如图1所示。

 

 

 

      目前应用于嵌入式Linux系统中比较成熟,功能也比较强大的GUI系统底层支持库有SVGA lib、LibGGI、Xwindow、framebuffer等。

2 三种嵌入式GUI系统的分析与比较

2.1 MicroWindows

      MicroWindows是一个典型的基于Server/Clinent体系结构的GUI系统,基本分为三层,如图2所示。

 

    最底层是面向图形显示和键盘、鼠标或触摸屏的驱动程序;中间层提供底层硬件的抽象接口,并进行窗口管理;最高层分别提供兼容于X WindowECMA APIWWin32子集)的API。其中使用Nano-X接口的APIX接口兼容,但是该接口没有提供窗口管理,如窗口移动和窗口剪切等高级功能,系统中需要首先启动nano-XServer程序nanoxserver和窗口管理程序nanowm。用户程序连接nano-XServer获得自身的窗口绘制操作。使用ECMA APIW编写的应用程序无需nanox-servernanowm,可直接运行。

    Microwindows提供了相对完善的图形功能和一些高级的特性,如Alpha混合、三维支持和TrueType字体支持等。该系统为了提高运行速度,也改进了基于Socket套接字的X实现模式,采用了基于消息机制的Server/Client传输机制。MicroWindows也有一些通用的窗口控件,但其图形引擎存在许多问题,可以归纳如下:

    *无任何硬件加速能力;

    *图形引擎中存在许多低效算法,如在圆弧图函数的逐点判断剪切的问题。

    由于该项目缺乏一个强有力的核心代码维护人员,2003MicroWindows推出版本0.90后,该项目的发展开始陷于停滞状态。

2.2 MiniGUI

        MiniGUI是由国内自由软件开发人员设计开发的,目标是为基于Linux的实时嵌入式系统提供一个轻量级的图形用户界面支持系统。MiniGUI的体系架构如图3所示。

 

 

        MiniGUI分为最底层的GAL层和IAL层,向上为基于标准POSIX接口中pthread库的Mini-thread架构和基于Server/ClientMini-Lite架构。其中前者受限于thread模式对于整个系统的可靠性影响——进程中某个thread的意外错误可能导致整个进程的崩溃,该架构应用于系统功能较为单一的场合。Mini-Lite应用于多进程的应用场合,采用多进程运行方式设计的Server/Client架构能够较好地解决各个进程之间的窗口管理、Z序剪切等问题。MiniGUI还有一种从Mini-Lite衍生出的standalone运行模式。与Lite架构不同的是,standalone模式一次只能以窗口最大化的方式显示一个窗口。这在显示屏尺寸较小的应用场合具有一定的应用意义。MiniGUIGAL层技术SVGA libLibGGI、基于framebuffernative图形引擎以及哑图形引擎等,对于Trolltech公司的QVFBX Window下也有较好的支持。IAL层则支持Linux标准控制台下的GPM鼠标服务、触摸屏、标准键盘等。

    MiniGUI下丰富的控件资源也是MiniGUI的特点之一。当前MiniGUI的最新版本是1.3.3。该版本的控件中已经添加了窗口皮肤、工具条等桌面GUI中的高级控件支持。

23 QT/Embedded

       Qt/Embedded是著名的Qt库开发商Trolltech公司开发的面向嵌入式系统的Qt版本。因为QtKDE等项目使用的GUI支持库,许多基于QtX Window程序因此可以非常方便地移植到Qt/Embedded上。Qt/Embedded同样是Server/Client结构。

    Qt/Embedded延续了QtX上的强大功能,在底层摒弃了X lib,仅采用framebuffer作为底层图形接口。同时,将外部输入设备抽象为keyboardmouse输入事件,底层接口支持键盘、GPM鼠标、触摸屏以及用户自定义的设备等。

    Qt/Embedded类库完全采用C++封装。丰富的控件资源和较好的可移植性是Qt/Embedded最为优秀的一方面。它的类库接口完全兼容于同版本的Qt-X11,使用X下的开发工具可以直接开发基于Qt/Embedded的应用程序QUI界面。

    与前两种GUI系统不同的是,Qt/Embedded的底层图形引擎只能采用framebuffer。这就注定了它是针对高端嵌入式图形领域的应用而设计的。由于该库的代码追求面面俱到,以增加它对多种硬件设备的支持,造成了其底层代码比较凌乱,各种补丁较多的问题。Qt/Embedded的结构也过于复杂臃肿,很难进行底层的扩充、定制和移植,尤其是用来实现signal/slot机制的moc文件。

    Qt/Embedded当前的最新版本为3.3.2,能够支持Trolltech的手持应用套件QtopiaQt/Embedded最高版本为2.3.8Trolltech公司将于2004年末推出的Qt/Embedded 3为基础的Qtopia 2应用套件。

3 三种嵌入式GUI的移植与中文化

    在进行以上三种嵌入式GUI的研究和移植过程中,硬件平台采用自行设计的以Motorola MC9328 MX1为核心的开发系统。该系统采用CPU内部LCD控制器和320×240分辨率的16bpp TFT LCD作为显示设备,使用I2C总线扩展出16按键的键盘,同时配置了9A/D量化精度的电阻触摸屏作为鼠标类输入设备;同时移植了ARM Linux作为操作系统。以下分别讨论这三种嵌入式GUI的底层移植和中文化技术。

    移植以上三种嵌入式GUI系统,需要首先实现Linux内核中的framebuffer驱动。对应于开发系统为MC9328中的LCD控制器,该部分驱动程序必须以静态方式编译进内核,在系统启动时由传递进内核的启动参数激活该设备。I2C键盘的驱动程序和触摸屏的驱动程序实现后,作为Linux内核模块在使用时动态加载。

31 MicroWindows的移植

        Microwindows驱动层相应的源码目录为src/drivers/。其中以scr*开头的源码是针对显示设备的驱动接口,以mou*开头的源码文件为鼠标设备(包括触摸屏)的驱动接口,以kbd*开头的源码文件针对键盘设备的驱动接口。移植过程中需要实现自己的设备驱动接口提供给MicroWindows使用,就必须按照指定的接口格式编写相应的scrmoukbd的底层支持。这种方式实现简单,条理也很清晰。

    显示设备驱动接口:Microwindows的图形发生引擎支持framebuffer,修改src/中的config文件指定使用framebuffer作为底层图形支持引擎;但需要注意嵌入式Linuxframebuffer较少支持控制台字符模式,需要修改MicroWindows中对framebuffer的操作部分以关闭显示模式的转换

        在应用程序开发移植中需要注意的是:使用ECMAAPIW接口设计的程序无需nano-XServer程序和nanowm,如图2所示。系统中可以直接启动使用该接口编写的用户程序;但需要注意的是,一个系统中如同时存在使用两种不同的API接口编写的进程,会造成nano-XServerECMA APIW的进程对系统硬件资源的使用竞争,双方的程序将无法正常显示或响应应用户输入。

    在为Microwindows增加中文显示的支持时,主要工作包括两个部分。一部分是系统字体的中文支持。此处使用等宽光栅字体,主要负责窗口标题和内置控件的中文绘制,将字体编译进MicroWindows内核中,光栅信息作为一维数组,显示时按照字符偏移量从该数组中调出相应的光栅信息显示即可。除此之外,当程序调用CreateFont时,需要在内部实现为打开文件系统中的字体文件。通过修改src/engine/devfont.c中的GdCreateFont部分,添加相应的hzk(汉字库)支持,便可以实现在CreateFont时创建出一个支持GB2312字符集的逻辑字体,并使用外部字体进行显示。在应用程序设计时,如果没有调用SelectObjectu将外部字体选入,中文显示时将默认使用系统字体。

3.2 MiniGUI

        由于MiniGUI较好地将硬件设备抽象为GAL层和IAL层,移植时只需要针对自身的硬件特点按照GAL层调用接口和IAL层调用接口来做内部实现即可。图4MiniGUIGAL层结构示意,IAL层结构类似。

 

 

    实现了framebufferLinux驱动后,配置MiniGUI选择NativeGAL引擎,便可以使用framebuffer作为MiniGUI图形发生引擎。

    MiniGUIIAL层将输入设备的输入事件最终映射为GUI系统API层的消息事件。IAL层默认处理两种设备的输入操作:键盘设备和鼠标设备。键盘设备向上层提供不同的按键输入信息,鼠标设备提供点击、抬起和落笔坐标等的信息。在实现MiniGUI与输入设备驱动的接口时,采用Select的方式获得输入设备的动作,并转换为消息队列中的消息。消息参数按照Win32接口定义为点击键编号或鼠标当前的坐标(其中触摸屏事件与鼠标事件类似)。通过编写针对硬件开发系统的IAL支持代码,实现了IAL层的移植。

    MiniGUI中多字体和字符集支持是通过设备上下文(DC)的逻辑字体(LOGFONT)实现的,创建逻辑字体时指定相应的字符集,其内部实现为对于所需显示字符的所属字符集的识别处理,最终调用相应字符集的处理函数族。应用程序在启动时,可切换系统字符集,如GB2312BIG5EUCKRUJISMiniGUI的这种字符集支持方式不同于采用UNICODE的解决方案。在节省系统资源的意义上讲,这种实现更加适合于嵌入式系统应用,是MiniGUI的一大创新点。MiniGUI同时支持包括ttfbdftype 1VBf等多种字体格式,可以根据需要配置MiniGUI来支持相应字体的显示。

33 Qt/Embedded的移植                         

        Qt/Embedded的底层图形引擎完全依赖于framebuffer,因此在移植时需考虑目标平台的Linux内核版本和framebuffer驱动程序的实现情况,包括分辨率和颜色深度等在内的信息。当前嵌入式CPU大多内部集成LCD控制器,并支持多种配置方式。除少数CPU低色彩配置时的endian问题外,Qt/Embedded能够较好地根据系统已有的framebuffer驱动接口构建上层的图形引擎。

    Qt/Embedded图形发生引擎中的图形绘制操作函数都是由源泉码目录src/kernel/中的src/kernel/qgfxreaster_qws.cpp中所定义的QgfxRasterBase类发起声明的。对于设备更加底层的抽象描述,则在src/kernel目录中的qgfx_qws.cpp中的Qscreen类中给予相应定义。这些是对framebuffer设备直接操作的基础,包括点、线、区域填充、alpha混合、屏幕绘制等函数均在其中定义实现。在framebuffer驱动程序调试通过后,配置Qt/Embedded的编译选项,可以保证Qt/Embedded图形引擎正常工作。

    Qt/Embedded中的输入设备,同样分为鼠标类与键盘类。其中鼠标设备在源泉码目录中的src/kernel/qwsmouse_qws.cpp中实现,从该类又重新派生出一些特殊鼠标类设备的实现类,其派生结构如图5所示。

 

 

    根据具体的硬件驱动程序实现的接口,可以实现类似的接口函数。

        Qt/Embedded中对于键盘响应的实际函数位于src/kernel/qkeyboard_qws.cpp中,在qkeyboard_qws.h中,定义了键盘类设备接口的基类QWSKeyboardHandler。具体的键盘硬件接口依然要建立在键盘驱动程序基础上,移植时需要根据键盘驱动程序从该类派生出实现类,实现键盘事件处理函数processKeyEvent()即可。

    Qt/Embedded内部对于字符集的处理采用了UNICODE编码标准。Qt/Embedded内部对于字符集的处理采用了UNICODE编码标准。Qt/Embedded同时支持两种对于其它编码标准(如GB2312GBK)的支持方式:静态编译和动态插件装载。通过配置config.h文件添加相应的编码支持宏定义,可以获得其它编码标准向UNICODE的转换支持,从而在Qfont类中得以转换与显示。由于UNICODE涵盖了中文部分,Qt/Embedded对中文支持也非常好。

    Qt/Embedded能够支持TTFPFA/PFBBDF QPF字体格式。由于自身采用UNICODE编码方式对字符进行处理,在一定程序上导致了能够使用的字体文件体积的增大。为了解决这一问题,Qt/Embedded采用了QPF格式,使用makeqpf等工具可以将TTF等格式的字体转换至QPF格式。图6为笔者在自行设计的MC9328系统上移植Qt/EmbeddedQtopia套件后,增加中文支持后的显示截图。Qt/Embedded版本为2.3.7Qtopia版本为1.7.0

 

4 结论

   综上所述,一个具备良好移植性的嵌入式GUI系统,其底层接口应该在很大程度上隐藏具体硬件的实现细节,抽象出GALIAL层。对于字符集的支持,也可以从MiniGUI的字符集支持方式和Qt/EmbeddedUNICODE支持方式上获得启发。

关键字:嵌入式Linux  GUI  应用与移植  中文化 引用地址:嵌入式Linux系统中的GUI系统的研究与移植

上一篇:Enea 5.4版OSE实时操作系统增加多核SMP
下一篇:Windows CE下基于TSC2101的音频系统设计

推荐阅读最新更新时间:2024-05-02 20:45

基于嵌入式Linux的视频循环录制系统解析
引言 视频采集系统以其直观的视频影像数据,对现场场景进行记录,目前已经在各行各业得到广泛应用。对于特定运用场合,如汽车行进过程,由于其环境的不确定性和多样性,以及事故的突发性和偶然性,要求采集系统能够稳定、连续地实时记录事发过程。行车过程事故发生时,需要掌握的事故原因往往在事故发生前短短的一段时间内。因此,分清事故责任和分析事故原因所需要的视频信息,往往是在事故时间点之前的一小段时间内。 日常生活中常见的交通纠纷,往往是因为没有直接证据造成取证困难。基于此,结合嵌入式系统低功耗、低成本等优点,本文利用嵌入式Linux系统实现行车视频存储,存储的视频可以为交通纠纷的调解以及交通事故认定,提供现场录像证据。 1 系统概述 1.
[单片机]
基于<font color='red'>嵌入式Linux</font>的视频循环录制系统解析
嵌入式Linux之我行——深入理解DM9000在mini2440上的驱动
首先看一下DM9000的引脚和MINI2440的引脚连接 DM9000 MINI2440 功能描述 SD0 DATA0 数据信号 | | SD15 DATA15 数据信号 CMD ADDR2 识别为地址还是数据 INT EINT7 中断 IOR# nOE 读命令使能 IOW# nWE 写命令使能 AEN nGCS4 片选使能 可以看出连接了16条数据线,1条地址线,而这唯一的一条地址线用于判断数据线传输的是地址还是数据,所以这16条数据线为数据和地址复用 而片选信号使用的BANK4,则访问0x2000 0000 0x27FF FFFF这个范围的地址时会激活片选使能信
[单片机]
<font color='red'>嵌入式Linux</font>之我行——深入理解DM9000在mini2440上的驱动
ARM嵌入式linux的入门建议
由于很多人总问这个问题,所以这里做一个总结文档供大家参考。这里必须先说明,以下的步骤都是针对Linux系统的,并不面向WinCE。也许你会注意到,现在做嵌入式的人中,做linux研究的人远比做WinCE的人多,很多产家提供的资料也是以linux为主。我一直很难理解,其实WinCE的界面比linux的界面好看多了,使用起来也很方便,更为重要的是,WinCE的开发和Windows下的开发基本一样,学起来简单得多,但是学linux或者使用linux做嵌入式的人就是远比WinCE多。在和很多工作的人交流时我了解到,他们公司从没考虑使用WinCE,因为成本高,都是使用linux进行开发。我读研究生的的实验室中也没有使用WinCE的,大都
[单片机]
嵌入式Linux系统的设计应用
摘要:随着嵌入式Linux系统的迅速发展,嵌入式Linux已发展成为嵌入式操作系统的一个重要分支。本文介绍了嵌入式Linux的设计和几种流行的嵌入式Linux系统。 关键词:嵌入式Linux 一、引言 嵌入式系统(Embedded Systems)是根据应用的要求,将操作系统和功能软件集成于计算机硬件系统之中,从而实现软件与硬件一体化的计算机系统。嵌入式系统出现于60年代晚期,它最初被用于控制机电电话交换机,如今已被广泛的应用于工业制造、过程控制、通讯、仪器、仪表、汽车、船舶、航空、航天、军事装备、消费类产品等众多领域。嵌入式系统在数量上远远超过了各种通用计算机系统:计算机系统核心CPU,每年在全球范围内的产量大概在二十亿
[应用]
基于ARM的嵌入式Linux移植真实体验(4)――设备驱动
设备驱动程序是操作系统内核和机器硬件之间的接口,它为应用程序屏蔽硬件的细节,一般来说,Linux的设备驱动程序需要完成如下功能: 设备初始化、释放; 提供各类设备服务; 负责内核和设备之间的数据交换; 检测和处理设备工作过程中出现的错误。 Linux下的设备驱动程序被组织为一组完成不同任务的函数的集合,通过这些函数使得Linux的设备操作犹如文件一般。在应用程序看来,硬件设备只是一个设备文件,应用程序可以象操作普通文件一样对硬件设备进行操作,如open ()、close ()、read ()、write () 等。 Linux主要将设备分为二类:字符设备和块设备。字符设备是指设备发送和接收数据以字符的形式进行;而
[单片机]
基于ARM的<font color='red'>嵌入式Linux</font><font color='red'>移植</font>真实体验(4)――设备驱动
at91sam9x5ek linux 4,嵌入式Linux移植相关经验积累
一:相关源码 (1)arm-2010q1-202-arm-none-linux-gnueabi.tar.bz2 交叉编译工具 gcc version 4.4.1 (Sourcery G++ Lite 2010q1-202) (2)Bootstrap-V3.5.tar.bz2 ATmel提供的一级Boot (3)u-boot-2014.04.tar.bz2 Uboot (4)linux-2.6.39_OK.tar.bz2 Linux Kernel (5)busybox-1.13.0.tar.bz2 制作根文件系统的工具包一 (6)e2f
[单片机]
【Renesas GUI挑战】变电站巡检机器人控制系统开发
一,项目研发背景: 1,21世纪是互联网及的时代,使用智能机器人来替代巡逻保安来完成单调且不可或缺的巡检是未来的趋势。 2,变电站大都在野外,人工巡检的弊端:错综复杂的道路,位于各处的矮灌木、花坛和雕塑,都容易形成一个个治安死角。普通的人工巡检很容易漏检、错检,特别是在夜间巡检时,又困又累,由于人为因素而错过重要的例行检查也是常有的事; 3,对于电力设备巡检,人工不易发现设备异常或者感受温度异常,人员对火灾探测不敏感。 4,巡检的优点:由于机器人不易疲劳、不易疏忽、不易犯错的缺点,可以预先设定巡检时间、巡检路线、报警方案,便可做到按时寻检,路径全覆盖,死角地带加强扫描的功能,运用,技术AI 通过图像分析,实时发现异常情况。 二,
[机器人]
基于嵌入式Linux的智能手机系统设计
  随着手持通信设备市场的快速发展,手机的功能逐渐增多。现在手机已经不只是用于语音通信的手持设备,而成为集成了短信、彩信、上网以及移动办公等附加功能的嵌入式通信平台。集成了这些功能的手机被称为智能手机。近年,嵌入式处理器的运行速度和功能都有了很大的提高,使得许多以前只能在PC上实现的应用,现在都可以在手持设备上实现。目前,市面上的智能手机主要采用Microsoft公司的ocket PC、Palm OS等商用操作系统,但这些操作系统开放的程序不够高,限制了许多第三方应用软件的移植。为使智能手机能够为第三方应用软件提供一个更为开放的嵌入式平台,笔者对智能手机系统做了比较深入的研究,提出一种以Linux作为嵌入式操作系统、Motorol
[应用]
小广播
最新嵌入式文章
何立民专栏 单片机及嵌入式宝典

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

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