作者: 时间:2007-08-21 来源: | |
摘要:分析嵌入式操作系统下典型的图形用户界面minigui的结构和特点,并提出将其移植到sunplus的dvd720上的方案。 关键词:图形用户界面(gui)嵌入式系统framebuffer 引言 1嵌入式linux下的gui概况 1.1gui在嵌入式系统中的地位 随着嵌入式系统的广泛应用,pda、机顶盒、dvd/vcd播放机及wap手机已经迅速普及。图形用户界面(gui)的广泛流行,是当今计算机技术的重大成就之一。它极大地方便了非专业用户的使用,因此实时嵌入式系统对gui的需求越来越明显,而这一切均要求有一个高性能、高可靠的gui的支持。 由于嵌入式系统实时性要求非常高,对gui的要求也更高。这些系统一般不希望建立在庞大累赘的、非常消耗系统资源的操作系统和gui之上,比如windows或xwindow,太过庞大和臃肿。这样,这些系统对轻型gui的需求更加突出。另外嵌入式系统往往是一种定制设备,它们对gui的需求也各不相同。有些系统只要求一些图形功能,而有些系统要求完备的gui支持,因此,gui也必须是可定制的。嵌入式系统对gui的基本要求包括轻型、占用资源少、高性能、高可靠性及可配置[1]。 1.2目前嵌入式系统中gui的实现 尽管实时嵌入式系统对gui的需求越来越明显,但目前gui的实现方法各有不同[1]: ①某些大型厂商有能力自己开发满足自身需要的gui系统。 ②某些厂商没有将gui作为一个软件层从应用程序中剥离,gui的支持逻辑由应用程序自己来负责。③采用某些比较成熟的gui系统,比如minigui、microwindows或者其它gui系统。 比较常用的有如下几种gui系统:紧缩的xwindow系统、minigui、microwindows、opengui及qt/embedded等。下面简单介绍这些系统。 (1)minigui minigui[2]由原清华大学教师魏永明先生开发,是一种面向嵌入式系统或者实时系统的图形用户界面支持系统。它主要运行于linux控制台,实际可以运行在任何一种具有posix线程支持的posix兼容系统上。minigui同时也是国内最早出现的几个自由软件项目之一。稍后将对它作详细的介绍。 (2)microwindows microwindows[3]是一个著名的开放源码的嵌入式gui软件。microwindows提供了现代图形窗口系统的一些特性。microwindowsapi接口支持类win32api,接口试图和win32完全兼容。它还实现了一些win32用户模块功能。microwindows采用分层设计方法,以便不同的层面能够在需要的时候改写,基本上用c语言实现。microwindows已经支持intel16位和32位cpu、mipsr4000以及arm芯片;但作为一个窗口系统,该项目提供的窗口处理功能还需要进一步完善,比如控件或构件的实现还很不完备,键盘和鼠标等的驱动还很不完善。 (3)opengui opengui[4]在linux系统上存在已经很长时间了。这个库是用c++编写的,只提供c++接口。opengui基于一个用汇编实现的x86图形内核,提供了一个高层的c/c++图形/窗口接口。opengui提供了二维绘图原语、消息驱动的api及bmp文件格式支持。opengui功能强大,使用方便。opengui支持鼠标和键盘的事件,在linux上基于framebuffer或者svgalib实现绘图。由于其基于汇编实现的内核并利用mmx指令进行了优化,opengui运行速度非常快。正由于其内核用汇编实现,可移植性受到了影响。通常在驱动程序一级,性能和可移植性是矛盾的,必须找到一个折衷。 (4)qt/embedded qt/embedded[5]是著名的qt库开发商trolltech的面向嵌入式系统的qt版本。这个版本的主要特点是可移植性较好,许多基于qt的xwindow程序可以非常方便地移植到嵌入式系统;但是该系统不是开放源码的,如果使用这个库,可能需要支付昂贵的授权费用。 2minigui的特点和体系结构 2.1minigui的特点 minigui的主要特点有[1]: 2.2minigui的体系结构 从整体结构上看,minigui是分层设计的,层次结构如图1所示。在最底层,gal和ial提供底层图形接口以及鼠标和键盘的驱动;中间层是minigui的核心层,包括窗口系统必不可少的各个模块;最顶层是api,即编程接口。gal和ial为minigui提供了底层的linux控制台或者xwindow上的图形接口以及输入接口,而pthread用于提供内核级线程支持的c函数库。 3.2图形驱动程序 hal提供的接口函数大多与图形相关,主要就是通过调用图形驱动程序来完成任务的。图形驱动程序屏蔽了底层驱动的细节,实现底层驱动相关的功能,而不是硬件相关的一些功能,如一些画圆和画线的gdi函数、普通的剪切,可直接在hal接口层实现。 dvd720的显示驱动是基于framebuffer的驱动程序的。通过对sdram中的framebuffer和videobitstreambuffer写入,就可以实现对tv和显示器的刷新。像素的写入方式和顺序如图3所示[6]。 open,close 基本的初始化和关闭函数。在open函数里要选择子图形驱动程序,将其实现的函数赋给本psd结构的函数指针。这里只考虑基于framebuffer的图形引擎的初始化。 当使用8位或以下的图形模式时,要使用系统调色板。这里是调色板处理函数,它们和windowsapi中的概念类似。linux系统利用ioctl提供了处理调色板的接口。 allocatememgc,mapmemgc,freememgc 内存屏幕是一个伪屏幕。在对屏幕图形操作过程中,比如移动窗口,先生成一个内存屏幕,将物理屏幕的一个区域拷贝到内存屏幕,再拷贝到物理屏幕的新位置,这样就减少了屏幕直接拷贝的延时。allocatememgc用于给内存屏幕分配空间,mapmemgc做一些初始化工作,而freememgc则释放内存屏幕。 drawpixel、readpixel、drawhline、drawvline及fillrect 这些是底层图形函数。分别是画点、读点、画水平线、画竖直线及画一个实心矩形。之所以在底层实现这么多函数,是为了提高效率。图形函数支持多种画图模式,常用的有直接设置或alpha混合模式,从而可以支持各种图形效果。 puthline、gethline、putvline、getvline、putbox、getbox及putboxmask get*函数用于从屏幕拷贝像素到一块内存区,而put*函数用于将存放于内存区的像素画到屏幕上。putboxmask与putbox的唯一区别是,如果要画的像素是白色,就不会被画到屏幕上,从而达到一种透明的效果。 4总结与展望 到目前为止,我们的移植工作已经顺利完成。minigui已经能成功运行在我们的dvd720平台上。作为底层支持的gui系统,minigui也应该像操作系统一样是开放源码的自由软件,并应该得到开发商的共同推动。到目前为止,已经有多家嵌入式系统开发商采用minigui开发嵌入式系统,并且已经开发出了许多重要的应用程序。我们期望能够有更多的人加入minigui的开发,共同促成minigui成为嵌入式linux系统上的标准gui。尽管minigui目前的功能已经非常强大,并且已经成功应用于许多嵌入式系统,但还需要在如下领域进行开发: 建立一个c++类库来封装minigui的api; 建立基于传统进程级客户/服务器体系结构的minigui,以便能够让minigui适合于一些较大的嵌入式系统,比如支持全功能浏览器的机顶盒。 |
文章评论(0条评论)
登录后参与讨论