完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
大多数的嵌入式GUI系统都只能简单地支持单任务。单任务GUI的效率较低,无法满足未来GUI的发展需求,故多任务GUI是嵌入式GUI的发展方向。
目前,在嵌入式应用领域比较成功的嵌入式多任务GUI系统主要有:MiniGUI、MicroWindows和Qt/Em-bedded。它们主要是针对嵌入式Linux而设计的,通过PThrred库来实现对多线程的支持;而PThred本身就比较复杂,很难将这些GUI系统移植到平台接口不符合POSIX标准的目标平台上。所以,上述几种GUI系统有一个共同的缺点,就是过分地依赖于某种特定的平台,导致可移植性差。 为了有效地兼容嵌入式领域的各种环境,下面提出一种通用、有效并且可移植性好的嵌入式GUI体系结构,并对多任务GUI设汁中的关键技术进行研究。 1 体系结构 针对GUI需要非常强的灵活性,可移植性和可伸缩性的特点,在其体系结构的设计中,采用层次化、模块化和面向对象的设计思想。层次式的体系结构在许多软件系统中被采用,被公认为是一种合理的结构,但最重要的是如何来划分这些层次,使系统的结构最合理、最清晰。 在设计中采用如下划分策略:力求层次之间相对独立,对任一层的改动保证它对上层的接口不变,上层不受下层变化的影响。在这样的层次结构中,最底层和最高层都可能根据具体需要发生改变,因此应该为这两层提供充分的变动空间,而中间的层次则应是独立不变的。 GUI在嵌入式应用环境中,硬件环境、操作系统和用户应用程序之间的层次如图1所示。图1中,通过驱动程序,GUI组件部分与硬件隔离;通过操作系统抽象层,使核心与具体操作系统隔离。这种层次体系结构使得GUI具有良好的平台无关性,在不同的操作系统和硬件平台之间的移植非常方便。按上述设计思想,GUI层次模型划分如图2所示。图中,GUI被划分为3层,每一层义根据具体功能的不同被划分为几个模块。 1.1 输入输出层 这一层的功能是将系统中设备和操作系统平台的具体细节屏蔽起来。该设备层被定义在BSP中,向上提供GUI对没备的显示特性操作。该层分为设备逻辑和硬件抽象两个子层。设备逻辑子层使用同一类设备的概念来描述GUI支持的外部设备及对该设备的逻辑操作,向上层提供了统一的设备操作接口;而硬件抽象子层则利用实际的设备控制器操作,根据硬件在不同平台上的驱动来实现硬件抽象子层中定义的接口。 1.2 窗口核心层 窗口核心层实现GUI的关键功能,根据功能可划分为消息管理、缓冲池管理、作图管理、定时器、资源管理、对象管理、子屏管理和内存堆管理等几部分。 由于GUI采取消息驱动的通信方式,因此消息管理构成GUI的灵魂,通过它把系统的各个部分联系起来。在应用程序的运行过程中,消息承载了系统各部分间的交换信息。 内存堆管理:目的是避免在系统运行过程中动态分配和释放内存时引起存储碎片。两个比较频繁的动态内存分配操作是消息空间的申请/释放和屏幕对象剪切域的刷新。 作图管理:完成画点、画线、画圆等作图操作。为了提高GUI的移植性,这层主要完成与硬件无关的作图过程。对具有特殊显示功能的应用平台来说,此层也可以大量调用硬件提供的功能函数(经输出硬件无关层包装后的接口),从而实现特殊的作图效果。GUI在结构上提供了这种灵活性。作图管理层向上以作图原语集的形式为应用提供调用接口。 定时器:根据系统时钟来为应用提供计数信息。 资源管理:主要对字体、图片和调色板等进行管理,需要实现资源的存储以及为应用提供适当的接口两大功能。 对象管理:采取合理的机制来组织在屏幕上显示的对象。GUI把所有能在屏幕上显示的GUI元素称为“对象”,并通过对象树、Z序和剪切域等机制来实现对象的管理。窗口核心层还为应用提供了添加、删除、隐藏对象等操作接口函数。 1.3 应用接口层 应用接口层封装了GUI为用户提供的一切接口,应用程序看到的GUI就是此层提供的所有接口函数,包括工具箱、作图原语集和对象操作集等3部分。 工具箱:GUI为用户提供的控件集。这部分的大小是可根据应用的需要调整的,从而也在较大程度上影响了GUI库的大小。常用的控件有按钮、滚动条、窗口和编辑框等。 作图原语集:作图管理层提供的绘图函数接口。工具箱也是在它的基础上实现的。 对象操作集:主要实现GUI对象的添加和删除等操作功能。 |
|
|
|
2 多任务GUI关键技术分析
本文中提到的“任务”,在同一个地址空间执行并且可以无约束地直接访问所有的共享资源。下面对多任务GUI设计中的关键技术进行分析。 2.1 多任务调度策略及管理 多任务系统需要一个合理的任务调度策略来管理所有的任务。启动GUI后,会默认产牛一个系统任务、一个事件任务和一个定时器任务;而应用任务的产生则要根据具体的用户需求。 (1)系统任务 桌面对象运行的任务称为“系统任务”。系统任务是整个图形用户系统运转的核心。它不断地从系统的主消息队列中取消息,并按消息的目的和用途将其派发到对应的目的任务;同时负责所有应用任务的管理和维护以及桌面管理等事务。一个系统中仅有一个系统任务。 (2)事件任务 事件任务负责收集外部事件,并将事件解释为与之对应的GUI消息,并放入系统的主消息队列中。用户的输入正是从这里传人GUI核心进行处理。一般情况下,一个系统中仅有一个事件任务。 (3)定时器任务 定时器任务是通过操作系统的系统调用产生GUI定时器的。 (4)应用任务 除系统任务之外,窗口所运行的其他任务称为“应用任务”。应用任务是用户程序运行的基本单位。应用逻辑都在此任务中运行,拥有自己的消息队列,接收来自GUI核心的消息,按一定规则独立进行消息循环。应用任务通过消息与系统任务交互,受系统任务的管理;通过应用接口层使用系统的软硬件资源。应用任务的上限数目仅受平台的资源数目限制。 在嵌入式GUI中,系统任务被赋予最高的优先权,其他任务可使用低于系统任务优先级的不同优先级;相同优先级应采用时间片轮转方式运行。总之,如果有必要,则嵌入式GUI系统会同时采取时间片轮转和优先级抢占的任务调度策略,如图3所示。 在没有消息到达或者在等待某个事件时,任务需要将自己挂起。一旦有消息进入消息队列,任务将会被唤醒以处理消息。这样,有限的CPU资源就能够被充分地利用。 此外,系统任务维护一个用于跟踪及管理应用任务的列表。每一个应用任务对应一个包含其属性信息的任务信息块。任务属性包括消息队列指针、任务句柄和任务入口等,对指定任务进行了详细的描述。一个信息块的创建与销毁必须与应用任务的创建与销毁保持同步。系统任务必须维护该列表,以保证这些信息块的正确性。多任务管理机制如图4所示。 对用户来说,只需要简单地指定任务的入口和优先级(如果有必要的话),其他所有的工作都由系统任务自动完成。采用这种调度和管理方法,能使系统变得更加易用和高效。 2.2 消息驱动机制 消息机制的提出,最初是为了解决早期程序设计中基于硬件中断的事件处理问题。中断事件的发生足不可预期的、突发性的,因此当有多个应用等待并处理中断事件时,就会出现问题。消息机制可以很好地解决事件驱动的多应用设计问题,并且可以形成一种处理多个系统之间、系统内部件和部件之问关系的简洁而且可靠的方法。 在只支持单任务的GUI系统中只有一个串行化的消息队列,消息严格地按照顺序处理,导致响应慢、效率低,故有必要采用并行化的消息队列。当一个队列中的消息忙于处理一个冗长工作时,输入焦点能够切换到另外一个队列。 系统维护一个系统消息队列和多个指定任务信息队列,每个指定任务信息队列对应一个应用任务,如图5所示。事件任务将输入转化成消息并将其放入系统消息队列中,系统任务检索到输入消息后首先会对该消息进行检查,然后将消息邮寄给目标应用任务或直接对消息进行处理。每个应用任务从它的消息队列中移出消息,并将其发送到适当的窗口程序中进行处理。一个应用任务可以将消息邮寄到它自己的消息队列,也可以邮寄到其他应用任务的消息队列中。 此外,为了达到不同的目的,系统提供了同步和异步两种基本类型的消息。 2.3 桌面及窗口管理 屏幕中的窗口通常是相互覆盖,而且它们的相对位置也在不断地变动。这些窗口有可能分别属于不同的任务,但共享一个相同的屏幕。所以,如何方便并有效地计算和维护窗口便显得很重要。 首先介绍2个概念:全局剪切域和窗口剪切域。它们都与应用任务相关,前者指出哪些区域占据屏幕,后者给出在相同的应用任务中所有对象的剪切关系。 系统任务除了要维护它自己的剪切域外,还要负责管理所有应用任务的全局剪切域,如图6所示。一旦窗口位置发生变化,系统任务必须更新信息并且通知应用任务作出相应的变动。另一方面,在计算窗口剪切域时,应用任务只须关心它本身而不受其他任务的影响,好像整个屏幕只有它一个任务在运行。至于最后实际的剪切结果,只需将全局剪切和窗口剪切结果进行“与”运算。 2.4 Z序和对象树 Z序实际定义了屏幕中对象集(可显窗口)之间的层次关系。GUI用户可以通过选择要被置于前端的窗口来改变Z序。很多GUI系统将Z序当作一个带有指定运算集的显式列表来实现。然而,在嵌入式GUI系统中不用这种方式,而是通过对象树来说明这些GUI对象之间的层次关系和Z序。理论上,每一个GUI对象都有父亲、孩子和兄弟。因此,所有显示在屏幕上的对象便构成一棵以桌面为根节点的倒置树。对树进行“后根遍历”就能够容易地得到Z序。 图7描述了对象树的建立过程。对象树的采用极大地简化了桌面管理,能够在不增加额外工作的情况下方便地组合对象和实现Z序管理。 3 小 结 将来的GUI系统将越来越复杂,要求GUI系统实现的功能也越来越丰富,这就需要一个更加开放且伸缩性好的体系结构。本文提出的嵌入式GUI体系结构具有很强的灵活性,且可移植性好,能够很好地应用于嵌入式领域的各种环境。 |
|
|
|
只有小组成员才能发言,加入小组>>
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-1-13 16:41 , Processed in 0.829023 second(s), Total 77, Slave 59 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (威廉希尔官方网站 图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号