MiniGUI 的新里程碑:5.0.0 版发布了!
飞漫软件于 2020 年 3 月 30 日宣布,正式发布 MiniGUI 5.0.0/4.0.7 版本,并同时更新 HybridOS 图形栈。
对国内开源软件的发展稍有了解的人都知道,MiniGUI 是国人发起的最早几个开源项目之一,经历了开源软件在国内萌芽、发展、消沉,而后在近几年随国内自主可控的春风重装上阵的整个过程。
作为 MiniGUI 的项目发起人及主要开发者,笔者认为 MiniGUI 5.0 不仅仅是 MiniGUI 自身发展的一个重要里程碑,也代表着国产开源基础软件的质量提升到了一个全新的水平。
我们先来了解一下 MiniGUI 5.0 带来的三个全新特性。
1. 合成图式
自 MiniGUI 5.0.0 起,MiniGUI 的多进程模式开始支持合成图式(compositing schema)。合成图式是现代桌面操作系统和智能手机操作系统的图形及窗口系统使用的技术,其基本原理很简单:系统中所有进程创建的每一个窗口都使用独立的缓冲区来各自渲染其内容,而系统中有一个扮演合成器(compositor)角色的进程,负责将这些内容根据窗口的 Z 序以及叠加效果(如半透明、模糊等)合成在一起并最终显示在屏幕上。
合成图式为窗口系统提供各种视觉效果和新奇交互效果带来了可能。在合成图式之前,大部分窗口系统使用共享缓冲区图式,通过管理和维护窗口的层叠关系以及相互之间的剪切来实现多窗口的管理。传统的共享缓冲区图式很难在多进程环境下实现不规则窗口、半透明或模糊叠加效果,而合成图式则可以轻松解决这些问题,而且还可以方便实现窗口切换时的动画效果。
合成图式是 MiniGUI 5.0 最为重要的一项新特性。尽管这一特性的实现需要调整 MiniGUI 最为核心的窗口管理部分,但我们仍然保证了 API 的基本稳定性:任何一个针对 MiniGUI 5.0 之前版本开发的应用,都可以不用做任何修改,重新编译即可运行在合成图式下。要使用合成图式带来的激动人心的功能,也只需要做一些不多的改动。
合成图式的支持让 MiniGUI 的应用领域得到了进一步扩展。以前,MiniGUI 被主要用于不安装第三方应用的电子产品中,如功能手机、视频监控、工业控制、医疗仪器等。而有了合成图式,MiniGUI 还可以应用在桌面电脑、智能手机等可能支持第三方应用的设备中。因为合成图式不仅仅便于实现各种图形及交互效果,还可以充分利用多进程环境的安全性:除了服务器进程之外,没有任何一个进程可以访问其他进程创建的窗口内容。
合成图式的实现涉及到进程间通讯技术、共享缓冲区技术、图形加速技术等多项技术,而笔者只花了三个月就实现了这个功能(还包括其他增强)。这得益于飞漫软件在长达二十年的开发周期中对操作系统、图形以及交互技术的深厚理解。这也从侧面反应了一个事实,基础软件的发展需要时间和积淀;或者说,长期的技术积累是基础软件可以快速迭代和发展的基础。
如果只是实现了合成图式,还不算什么,MiniGUI 5.0 同时提供了如下能力:
-
客户可定制自己的合成器(compositor),并通过加载动态库的形式装载自定义合成器或者第三方合成器。
-
MiniGUI 作为飞漫软件发起的另外一个开源项目 HybridOS 的窗口系统,随着 5.0.0 版本的正式发布,飞漫软件还同时更新了 HybridOS 的图形栈,提供了开发加速图形引擎的接口以及支持 OpenGL/ES 等 3D 图形的完整软件栈。
2. 八种主窗口 Z 序级别
在 MiniGUI 5.0 版本中,我们还增强了MiniGUI 的窗口管理器以支持某些特殊的主窗口类型。
在 MiniGUI 5.0 之前,我们可以创建一些特殊主窗口,以便在所有普通主窗口的上方显示这些主窗口,如果使用 MiniGUI 的多进程运行模式,则服务器(mginit)将始终创建全局主窗口,这些窗口显示在所有客户创建的主窗口之上。而从 5.0.0 开始,我们引入了主窗口 Z 序级别的概念,从上到下共有八个级别:
-
工具提示级别。
-
系统/全局级别。
-
屏幕锁定级别。
-
泊坞窗级别。
-
更高级别。
-
普通级别。
-
启动器级别。
-
桌面或墙纸。
这项增强功能使我们可以创建一些特殊的应用,该应用可以作为锁屏、通知栏、程序坞或者启动器使用。
3. 虚拟窗口
MiniGUI 为基于消息的通讯机制提供了完整的支持。在 MiniGUI 的多线程运行模式下,我们可以在一个线程中向运行在其他线程中的窗口邮寄或发送消息。MiniGUI 消息传递函数,如 PostMessage、SendMessage、SendNotifyMessage 以及窗口回调过程,为多线程应用程序提供了灵活、高效、安全的数据传输和同步机制。使用这些接口,多线程应用可避免自行维护复杂的线程锁、信号量等东西,从而简化编程模型。
但在 MiniGUI 5.0 之前,以独立进程模式或者多进程模式下运行的 MiniGUI 不支持线程间的消息传递能力。在 MiniGUI 5.0 中,我们取消了这一限制,并引入了虚拟窗口的概念。
虚拟窗口是一个特殊的窗口对象,没有可见的窗口区域。但是,在其他线程中创建虚拟窗口之后,可以使用 MiniGUI 的消息传递机制在可见的窗口线程和虚拟窗口所在的线程之间邮寄或发送消息。
此增强功能为基于 MiniGUI 的应用开发提供了非常有用的基础设施,以开发设计良好的多线程应用程序。
除了以上三个主要的增强之外,MiniGUI 5.0 还调整了一些底层架构,重构了一些底层模块。有兴趣的读者可以阅读完整的发布说明文档:
https://gitlab.fmsoft.cn/VincentWei/minigui/blob/rel-5-0/RELEASE-NOTES.md
作为 MinGUI 的主要开发者,笔者自信地认为,随着 MiniGUI 5.0 的发布,MiniGUI 以及 HybridOS 已经有了完整替代 Linux 操作系统上围绕传统 X Window 图形软件栈的能力。根据初步测试结果,MiniGUI 上 3D 应用渲染性能要比 X Window 高一个数量级。笔者可以自豪地说,MiniGUI 5.0 看起来是只是飞漫软件的重要一步,但未来一定是中国自主系统软件的一个重大突破。
最后,附上 MiniGUI 5.0 的入口仓库:
https://gitlab.fmsoft.cn/VincentWei/build-minigui-5.0
或者
https://github.com/VincentWei/build-minigui-5.0
MiniGUI 4.0.7 发布
MiniGUI 4.0.7 中的新功能
在这个版本中,我们主要增强 DRM 引擎以支持 MiniGUI-Processes。
- 增强
- 我们优化了 DRM 引擎的外部驱动接口,并增强了 DRM 引擎以支持 MiniGUI-Processes。
- 兼容性:
- 函数
drmCreateDCFromName
,drmCreateDCFromHandle
和drmCreateDCFromPrimeFd
被扩展为具有 offset 参数。请使用带有Ex
后缀的版本。 - DRM 引擎的外部驱动程序的接口已更改。这些变化来自 MiniGUI 5.0.0。
- 函数
- 修复
- 修复了在开发 MiniGUI 5.0.0 时发现的一些 bug。
关于 DRM 引擎外部驱动的更多信息,请参考以下文档的修订版:
构建 MiniGUI 4.0.x
如果你急于看到 MiniGUI Core 和 MiniGUI 组件的全面演示,请从 GitHub 获取以下存储库之一,并按照说明构建 MiniGUI Core、MiniGUI 组件、示例和演示程序:
https://github.com/VincentWei/build-minigui-4.0
或
https://gitlab.fmsoft.cn/VincentWei/build-minigui-4-0