MiniGUI 是一款面向 嵌入式系统的高级窗口系统(Windowing System)和 图形用户界面(Graphical User Interface,GUI)支持系统,由魏永明先生于 1998 年底开始开发。2002 年,魏永明先生创建北京飞漫 软件技术有限公司,为 MiniGUI 提供商业技术支持,同时也继续提供开源版本,飞漫软件是 中国地区为开源社区贡献代码最多的 软件企业。最后一个采用 GPL 授权的 MiniGUI 版本是 1.6.10,从 MiniGUI 2.0.4 开始 MiniGUI 被重写并使用商业授权。
历经十余年时间, MiniGUI 已经成为性能优良、功能丰富的跨 操作系统 嵌入式 图形用户界面支持系统,支持Linux/uClinux、eCos、 uC/OS-II、VxWorks、ThreadX、Nucleus 、pSOS、OSE 等操作系统和数十种 SoC芯片,已验证的硬件平台包括 ARM-based SoCs、MIPS based SoCs、IA-based SoCs、PowerPC、M68K(DragonBall /ColdFire)、Intel x86 等等,广泛应用于通讯、医疗、工控、电力、机顶盒、多媒体终端等领域。使用 MiniGUI 成功开发产品的企业有华为、中兴通讯、大唐移动、长虹、TCL、联想、迈瑞、南瑞、炬力、D2 等。这些用户广泛分部在 中国大陆、 台湾、新加坡、 韩国、美国、 德国、意大利、 印度、以色列等国家和地区。
值得一提的是,在 中国自主开发的 3G 通讯标准 TD-SCDMA中,约有 60% 获得入网许可证的 TD-SCDMA 手机使用 MiniGUI 作为其 嵌入式图形平台,以支撑 浏览器、可视电话等 3G 应用软件的运行,其中有 联想TD30t、海信 T68、中兴通讯 U85 等大家熟悉的 TD 手机型号。
在 MiniGUI 的基础上,飞漫 软件研发了 mDolphin (基于开源的 浏览器核心 WebKit 的 嵌入式浏览器,满分通过 Acid3 的 基准测试)、mPeer (为使用 Java 技术的 嵌入式设备提供高效的 J2SE AWT/Swing 实现支持),并且开发了基于 Eclipse CDT 的可视化 集成开发环境,为开发人员提供所见即所得(WYSIWYG)的 界面设计环境。
2010年,飞漫 软件把最新版的 MiniGUI、mDolphin、mPeer、mStudio 等 系统整合在一起,推出了合璧 操作系统(HybridOS)解决方案,是一整套专为 嵌入式设备打造的 快速开发平台,集成了飞漫软件10年的嵌入式行业研发经验和众多成熟的产品,使众多的希望在嵌入式设备上做开发的中小型企业,摆脱了“不稳定的内核以及驱动程序”、“交叉编译工具链、基础函数库存在大量缺陷”、“不恰当的 开源软件”、“高水平嵌入式开发工程师缺乏”等这些问题的困扰,从而能够在一个运行稳定、功能强大的小巧系统内核基础上,专注开发产品。合璧操作系统(HybridOS)采用新的商业授权模式,性价比颇高。
截止2010年9月,MiniGUI 的最新版本是3.0.10, MiniGUI 将作为合璧 操作系统(HybridOS)的一个组成部分而不断演进,推荐新老用户使用合璧操作系统(Hybridos)作为 嵌入式开发平台,必将节省大量的开发成本和时间。
(概述内容来源: [1]

2特点优势

MiniGUI 为 嵌入式 Linux 系统提供了完整的图形系统支持,是全球针对嵌入式 Linux仅有的两个商用嵌入式GUI系统之一。MiniGUI为 嵌入式Linux 系统提供了完整的 多进程支持;可以 MiniGUI-Processes、MiniGUI-Threads或者MiniGUI-Standalone 三种运行模式运行。

技术特性

硬件适配性
可运行于各种含有 MMU( 内存管理单元)的 32 位处理器架构之上,如 ix386、ARM、MIPS、PowerPC 等。
支持低端显示设备(比如单色 LCD)和高端显示设备(8 位色及以上显示设备)。通过 MiniGUI 的图形抽象层及图形引擎技术,还可以支持特殊的显示设备,比如 YUV 显示设备。对显示设备分辨率无最大和最小限制。
副屏支持。当系统中有多个视频设备时,可将一个作为 MiniGUI 的主屏,实现完整的多窗口系统;而其它设备作为副屏,在其上通过 MiniGUI 的图形接口来实现文字渲染、图形显示等功能。
可支持各种 输入设备,如 PC 键盘、PC 鼠标、 小键盘(Keypad)、触摸屏、遥控器等等。
多种键盘布局的支持。MiniGUI 除支持常见的美式 PC 键盘布局之外,还支持法语、德语等 西欧语种的键 盘布局。
资源消耗:
MiniGUI 的静态存储随配置选项的不同而不同,最少需占用 1MB 静态 存储空间
MiniGUI 启动后,初始占用 1MB 动态存储空间。建议 系统内存为 8MB 以上。
操作系统适配性:
支持 Linux 操作系统(非 uClinux 操作系统),可以 MiniGUI-Processes、MiniGUI-Threads 或者 MiniGUI-Standalone 三种运行模式运行。
内建资源支持。可以将 MiniGUI 所使用的资源,诸如位图、图标和 字体等编译到函数库中,该特性可提高 MiniGUI 的初始化速度,并且非常适合无文件系统支持的实时 嵌入式操作系统
针对 嵌入式系统的特殊支持,包括一般性的 I/O 流操作, 字节序相关函数等。
窗口子系统特性
完备的多窗口机制和消息传递机制。使用 MiniGUI-Threads 运行模式时,可在不同 线程中创建主窗口,并支持线程间的消息传递;使用 MiniGUI-Processes 运行模式时,支持完整的 多进程窗口系统。
对话框和 消息框支持。
提供常用的控件类,包括静态 文本框、按钮、单行和多行编辑框、列表框、 组合框、菜单按钮、进度条、滑块、 属性页工具栏、树型控件、月历控件、旋钮控件、酷工具栏、 网格控件、动画控件等。
其它 GUI 元素,包括菜单、 加速键、插入符、 定时器等。
图形子系统特性
提供有增强 GDI 函数,包括光栅操作、复杂区域处理、 椭圆、圆弧、多边形以及区域填充等函数。在提供有兼容于 C99 规范的数学库平台上,还提供有高级二维绘图函数,可设置线宽、线型以及填充模式等。通过 MiniGUI 的图形抽象层及图形引擎技术,也可以让上述高级 GDI 接口在低端显示屏上实现。
各种流行 图像文件的支持,包括 Windows BMP、GIF、JPEG、PNG等(JPEG 及 PNG的支持通过 libjpeg 及 libpng 函数库提供)。
Windows 的 资源文件支持,如位图、图标、光标等。
字符集和多 字体支持,目前支持 ISO8859-1~ISO8859-15、GB2312、GBK、GB18030、BIG5、 EUC-JP、Shift-JIS、 EUC-KR、UNICODE(UTF-8、 UTF-16编码)等字符集,支持等宽 点阵字体、变宽点阵字体、Qt/Embedded 使用的 嵌入式字体 QPF、TrueType 矢量字体(对 TrueType 的支持通过 freetype 1.3 函数库提供)。
输入法支持,用于提供各种可能的输入形式;内建有适合 PC 平台的汉字(GB2312)输入法支持,包括 内码全拼、智能拼音、 五笔自然码等。

MiniGUI 的技术优势

和其它针对 嵌入式产品图形系统相比,MiniGUI 在对系统的需求上具有如下几大优势:
可伸缩性强。MiniGUI 丰富的功能和可配置特性,使得它既可运行于 CPU 主频只有 60MHz 的低端产品中,亦可运行于高端 嵌入式设备中,并使用 MiniGUI 的高级控件风格及皮肤界面等技术,创建华丽的用户界面。MiniGUI 的跨 操作系统特性,使得 MiniGUI 可运行在最简单的 嵌入式操作系统之上,如 uC/OS-II,也可以运行在具有 现代操作系统特性的嵌入式操作系统之上,如 Linux,而且 MiniGUI 为嵌入式 Linux 系统提供了完整的多窗口图形环境。这些特性,使得 MiniGUI 具有非常强的可伸缩性。可伸缩性是 MiniGUI 从设计之初就考虑且不断完善而来的。这个特性使得 MiniGUI 可应用于简单的行业终端,也可应用于复杂的 消费类电子产品
轻型、占用资源少。MiniGUI 是一个定位于轻量级的 嵌入式图形库,对 系统资源的需求完全考虑到了 嵌入式设备的硬件情况,如 MiniGUI 库所占的空间最小可以裁剪到 500K 左右,对目前的嵌入式设备来说,满足这一条件是绰绰有余的。此外,测试结果表明,MiniGUI 能够在 CPU 主频为 30 MHz,仅有 4M RAM 的系统上正常运行(使用 uClinux 操作系统),这是其它针对嵌入式产品的 图形系统所无法达到的。
高性能、高可靠性。MiniGUI 良好的 体系结构及优化的图形接口,可确保最快的图形绘制速度。在设计之初,就充分考虑到了实时 嵌入式系统的特点,针对多窗口环境下的图形绘制开展了大量的研究及开发,优化了 MiniGUI 的图形绘制性能及资源占用。MiniGUI 在大量实际系统中的应用,尤其在 工业控制系统的应用,证明 MiniGUI 具有非常好的性能。从 1999 年 MiniGUI 的第一个版本发布以来,就有许多产品和项目使用 MiniGUI,MiniGUI 也不断从这些产品或者项目当中获得发展动力和新的技术需求,逐渐提高了自身的可靠性和健壮性。有关 MiniGUI 的最新成功案例,您可以访问飞漫公司网站的典型案例部分。
可配置性。为满足 嵌入式系统各种各样的需求,必须要求 GUI 系统是可配置的。和 Linux 内核类似,MiniGUI 也实现了大量的编译配置选项,通过这些选项可指定 MiniGUI 库中包括哪些功能而同时不包括哪些功能。大体说来,可以在如下几个方面对 MiniGUI 进行定制配置:
指定 MiniGUI 要运行的硬件平台。
指定 MiniGUI 要运行的 操作系统
指定生成基于 线程的 MiniGUI-Threads 运行模式还是基于进程的 MiniGUI-Processes 运行模式,或者只是最简单的 MiniGUI-Standalone 运行模式。
指定需要支持的 GAL 引擎和 IAL 引擎,以及引擎相关选项。
指定需要支持的 字体类型。
指定需要支持的 字符集
指定需要支持的 图像文件格式
指定需要支持的控件类。
指定控件和窗口的整体风格,可以通过指定不同的渲染器完成。这些配置选项大大增强了 MiniGUI 的灵活性,对用户来讲,可针对具体的应用需求量体裁衣,开发最适合产品需求的 应用软件
总之,将现代窗口和 图形技术带入到 嵌入式设备的MiniGUI,是一个非常适合于实时嵌入式设备的高效、可靠、可定制、小巧灵活的 图形用户界面支持系统,其主要优点可以总结如下:
支持多种 嵌入式操作系统,具备优秀的可移植性;
可伸缩的系统架构,易于扩展;
功能丰富,可灵活剪裁;
小体积高性能间的最佳平衡;
广泛的应用领域。

MiniGUI V3.0

在以前版本的基础上新增了如下新特性:
主窗口双缓冲区(Double Buffering Main Window) 当 MiniGUI 3.0 的主窗口具有双缓冲区时,可以在自定义缓冲区中获得整个主窗口的渲染结果。在此基础上,可以利用高级 2D 图形接口或者 3D 图形接口获得主窗口的各种特殊显示效果,如推拉切换、 翻页切换、卷曲效果等等。
外观渲染器(Look and Feel Renderer)支持。MiniGUI V3.0 改变了以往只支持三种控件风格的方式,引入了渲染器(Look and Feel)这一全新的模式。渲染器是定义如何绘制窗口元素的渲染器,是在MiniGUI V2.0.X的基础上继续完善的。窗口元素包括边框、 标题栏、标题栏按钮、滚动条、选定项目、无效项目、高亮项目、突出项目、三维对象等;窗口元素的外观属性,包括窗口元素的颜色、尺寸、 字体等信息;窗口元素渲染器是对窗口元素进行定制大小、颜色、图形、字体,便于用户设计个性化的外观显示风格。用户可以指定某个主窗口或某个控件使用特定的渲染器,也可定制非客户区渲染器、窗口元素的尺寸、颜色、 字体、图标,同时增强资源管理功能,从而获得更加华丽的图形界面。MiniGUI实现了几种默认整体显示风格:Classic 、Flat、Fashion 和Skin。用户可以在配置 MiniGUI 时指定相应的选项来将 MiniGUI 编译成特定的一种显示风格。
Classic: 这种风格的界面是标准的Window 95风格界面,也是最广泛使用的风格了。
Fashion: 此种风格的界面,采用 MiniGUI 3.0 组件 mGPlus 提供的颜色渐变填充技术,因此,可获得非常炫丽的界面效果;
Flat: 此种风格的窗口界面,线条清晰,简洁,因此适用于单色或者灰度显示屏。因为绘制简单,因此该渲染器占用资源最少,运行速度最快;
Skin: 上面三种外观渲染器基本上都是由代码绘制出来的,具有小巧灵活的特点。但是,在 嵌入式应用领域,设备的差别非常大。有些设备,已经具备了非常高的运算性能。在这种情况下,可以考虑使用皮肤外观渲染器来美化界面。皮肤外观渲染器需要一整套和界面相关的图片,因此需要占用一些存储资源。皮肤外观渲染器的最大的特点是允许用户定制界面,用户可以使用自己设计的图片替换系统原有的图片,展现在用户面前的就将是你自己设计的界面效果。
双向文本(BIDI Text)的显示与输入。大家知道,除了大家熟知的从左向右书写的文字(如英语、汉语等)之外,还有许多语言采用从右向左的书写习惯,如 阿拉伯文和希伯来文等。为了支持这些语言,MiniGUI 3.0中增加了对这两种语言所属 字符集的处理,并增加了阿拉伯和希伯来键盘布局的支持,从而实现了对双向文本的输入输出处理。阿拉伯文以及希伯来文的显示。
不规则窗口。MiniGUI V3.0实现了不规则窗口与控件,可满足用户对窗口外观各种不同的需求。不规则窗口通过一个Region 数据结构来表示可见区域,或者通过8位MYBITMAP中的透明值形成不可见区域。
字体。在 MiniGUI 3.0 中,飞漫 软件发明了一种新的 UNICODE 字体 文件格式,称为“UPF”字体。这种 字体的最大特点,是便于在 多进程环境下使用,从而极大地节约了内存的使用。同时,飞漫 软件增强了VBF 字体格式,将VBF 字体升级到了3.0,扩大了其能适用的 字符集范围,以便支持阿拉伯文等语言文字的显示。
其他增强。MiniGUI 3.0实现了 桌面的可定制。通过桌面的外部编程接口,用户可以在桌面放置图标并响应桌面事件,实现类似Windows桌面的界面效果。除此之外,MiniGUI 3.0 还增强了透明控件的实现,使之效率更高,且不依赖于控件的内部实现代码。MiniGUI 3.0 还提供独立的滚动条控件,提供统一的虚拟帧缓冲区程序支持等等。另外最新的MiniGUI V3.0新增加了两个新的组件:mGUtils和mGPlus,把 字体、位图、图标、光标等资源进行统一管理,资源的内嵌和非内嵌方式并不影响模块的组成,由此抽象出系统资源管理模块。

3运行模式

和 Linux 这样的类 UNIX 操作系统相比,一般意义上的传统 嵌入式操作系统具有一些特殊性。举例而言,诸如 uClinux、uC/OS-II、eCos 等 操作系统,通常运行在没有 MMU( 内存管理单元,用于提供 虚拟内存支持)的 CPU 上;这时,往往就没有进程的概念,而只有线程或者任务的概念,这样,MiniGUI 的运行环境也就大相径庭。因此,为了适合不同的 操作系统环境,可将 MiniGUI 配置成三种不同的运行模式:

MiniGUI-Threads

运行在 MiniGUI-Threads 上的程序可以在不同的线程中建立多个窗口,但所有的窗口在一个进程或者 地址空间中运行。这种运行模式主要用来支持大多数传统意义上的 嵌入式操作系统,比如 VxWorks 、ThreadX、Nucleus、OSE、pSOS、uC/OS-II、eCos等等。当然,在 Linux 和 uClinux 上,MiniGUI 也能以 MiniGUI-Threads 的模式运行。

MiniGUI-Processes

和 MiniGUI-Threads相反,MiniGUI-Processes 上的每个程序是单独的进程,每个进程也可以建立多个窗口,并且实现了 多进程窗口系统。MiniGUI-Processes 适合于具有完整 UNIX 特性的 嵌入式操作系统,比如嵌入式 Linux。该运行模式在 MiniGUI V2.0 中提供。

MiniGUI-Standalone

这种运行模式下,MiniGUI 可以以独立任务的方式运行,既不需要 多线程也不需要 多进程的支持,这种运行模式适合功能单一的应用场合。比如在一些使用 uClinux 的 嵌入式产品中,因为各种原因而缺少 线程支持,这时,就可以使用 MiniGUI-Standalone 来开发 应用软件
一般而言,MiniGUI-Standalone 模式的适应面最广,可以支持几乎所有的 操作系统(目前只用来提供对 Linux/uClinux 操作系统的支持);MiniGUI-Threads 模式的适用面次之,可运行在支持多任务的实时 嵌入式操作系统,或者具备完整 UNIX 特性的普通操作系统;MiniGUI-Processes 模式的适用面较小,它仅适合于具备完整 UNIX 特性的嵌入式操作系统,比如 Linux。但不论采用哪种运行模式,MiniGUI 为上层 应用软件提供了最大程度上的一致性;只有少数几个涉及初始化的接口在不同运行模式上有所不同。

4软件架构

MiniGUI 由如下几个模块组成:
minigui软件架构图

minigui软件架构图[2]

MiniGUI 软件架构

图形抽象层

(Graphics Abstraction Layer,GAL)。图形抽象层将来自不同 操作系统或设备的图形接口进行抽象,为 MiniGUI 上层提供统一的图形接口。在图形抽象层内,包含有针对 Linux FB 设备、eCos LCD 设备等的 软件组成部分。这些 软件组成部分通过调用底层设备的接口来实现具体的图形抽象层操作,如打开设备、设置分辨率及显示模式、关闭设备等。将这些用于适配图形抽象层接口的 软件组成部分称为“引擎(engine)”,其概念和操作系统中的 设备驱动程序类似。

输入抽象层

(Input Abstraction Layer,IAL)。和 GAL 类似,输入抽象层将 MiniGUI 涉及的所有输入设备,如键盘(keyboard)、小键盘(keypad)、鼠标(mouse)、触摸屏(touch screen)等抽象了出来,为上层提供一致的接口。要支持不同的键盘、触摸屏或者 鼠标接口,则通过为 IAL 编写不同的输入引擎实现。MiniGUI 通过 IAL 及其输入引擎,提供对 Linux 控制台(键盘及鼠标)、触摸屏、遥控器、小键盘等输入设备的支持。

图形设备接口

(Graphics Device Interfaces,GDI)。该模块基于图形抽象层为上层 应用程序提供图形相关的接口,如绘制 曲线、输出文本、填充矩形等等。 图形设备接口中含包含其他比较独立的子模块,如 字体 字符集(font and charset)支持、图像(p_w_picpath)支持等。

消息处理模块

(Messaging Module)。该模块在输入抽象层基础上,实现了 MiniGUI 的消息处理机制,为上层提供了完备的消息管理接口。众所周知,几乎所有的GUI 系统本质上都是 事件驱动的,系统自身的运行,以及GUI 应用程序的运行,都依赖于消息处理模块。

多窗口处理模块和控件

(Windowing Module)和(Control 或 Widget)。基于图形设备接口和消息处理模块,MiniGUI 实现了多窗口处理模块。该模块为上层应用程序提供了创建主窗口和控件的基本接口,并负责维护控件类。控件类是用来实现控件代码重用的重要概念,利用控件类(control class),可以创建属于某个控件类的多个控件实例(instance),从而让这些控件实例使用同一个控件类的代码,这样,就实现了类似 C++ 那样的类和实例概念,从而可以最大程度上重复利用已有代码,并提高 软件的可维护性。MiniGUI 的控件模块实现了常见的 GUI 控件,如静态框、按钮、编辑框、列表框、下拉框等等。

外观支持

(Look and Feel)。这个模块是 MiniGUI V3.0 提供给上层应用程序的接口,可用来定制 MiniGUI 窗口、控件的绘制。在 MiniGUI V3.0 之前的版本中,对主窗口和控件的定制能力,还没有被抽离出来形成独立的模块,但仍然可以通过配置选项让 MiniGUI 的主窗口、控件具有三种显示风格,分别是:类似 PC 的三维风格(PC3D )、平板风格(FLAT)、流行风格(FASHION)。在 MiniGUI 3.0 中,主窗口和控件的外观可完全由应用程序自行定制,在创建主窗口或者控件时,指定外观渲染器(renderer)的名称,就可以让主窗口或者控件具有各自不同的外观。
在 MiniGUI 核心(Core)接口之上,还为应用程序提供若干组件,这些组件分别为应用程序提供某些特殊的功能特性:
mGi是 MiniGUI 的输入法组件,该组件目前提供了 软键盘输入法和 手写输入法框架,并提供给用户管理输入法的容器,通过这个容器,用户还可以添加自定义的输入法。
mGp 是针对 MiniGUI 应用程序的一个打印组件,该组件使用户的 MiniGUI 程序具有打印输出功能,可以将 MiniGUI 程序中的位图或文字输出到打印机。
mG3d 是一个为 MiniGUI 的应用程序提供 3D 接口的组件,通过这些接口,用户可以给自己的应用程序添加三维图像、文字渲染、 场景渲染等效果,从而可以具有三维效果的人机界面。
mGUtils 组件为用户提供了一些常用的对话框模板,有了这些模板,用户就不用为一些常用的功能编写重复代码了。本组件提供的功能模板有:普通文件对话框、颜色设置对话框、 字体设置对话框、信息设置对话框等。
mGPlus 组件是对 MiniGUI 图形绘制接口的一个扩充和增强,主要提供对二维矢量图形和高级图形算法的支持,如路径、渐变填充和颜色组合等。
mGEff 组件提供常规的页面特效支持。