Skip to content

【详细分析】如何选择GUI框架?

基本上所有GUI框架都可以归类到如下三个路线中。

路线分类

(1)基于系统原生控件

这种之前比较常见,例如PC上著名的跨平台C++库wxWidgets、GTK等,Mobile上比较典型的就是React Native了。

  • 优点:体积小、内存占用小,系统原生性能。
  • 缺点:可拓展性差,跨平台表现不一致。

这类的主要特性是使用操作系统提供的原生控件,编译的最终程序体积较小。

内存占用一般也比较小,因为一般使用这个方案的需求中不会有太多动态字体变更、或者大量的图片资源。

因为是操作系统自己实现的控件,系统原生级别的,性能也没什么大问题。

(2)基于CPU/GPU自绘

这种就是对实时性要求比较高的场景需要的,典型的就是游戏中的界面UI了。因为游戏的界面需要每帧刷新,所以一般游戏内都会自己在渲染引擎上封装一套基于OpenGL/Direct3D/Metal的UI框架。还有一种典型应用场景就是类似Photoshop这种图形处理软件,对UI的美观要求比较高的设计软件,需要自己精确控制各种按钮文本样式的。

  • 基于CPU的就是所谓的软渲染,例如在SDL中,就可以却换使用CPU渲染还是GPU渲染。
  • 基于GPU的就是刚才说的游戏UI这种。

特点也显而易见

  • 优点:自绘,极高的拓展性,可以实现任何自己想要的效果。
  • 缺点:需要较好的CPU/GPU硬件,打包体积和运行时内存比较大。

(3)基于Web

基于Web的典型就非Electron莫属了,基于浏览器封装的网页渲染技术,将传统的GUI转成网页中的HTML节点来渲染,让浏览器完成跨平台渲染。本质上还是自绘,只不过自绘是浏览器内部完成的,例如Chrome/Firefox在Windows上的WebGL渲染后端ANGLE。

得益于浏览器的各种成熟技术,基于浏览器开发GUI程序的效率极高,且技术门槛也非常低。

当然,基于Web的路线之所以会火起来,在我看来,最功不可没的是React/Vue等前端框架所带来的前端技术栈的快速发展,以及相应的成熟组件库迅猛发展。

在基于系统原生控件的范畴内,开发人员比本上必须会C/C++等系统编程语言,以及各种操作系统底层API编程技能。在基于CPU/GPU自绘的范畴内,开发人员虽然不需要接触太多操作系统底层的编程知识,但是基本上也是需要C/C++等Native编程语言的,同时或多或少也会涉及计算机图形学相关的内容。这些底层技术在当下的社会发展中,应对高速的项目需求变动就显得很不灵活,所以目前很多项目都是走基于Web这条路线的。

  • 优点:
    • 开发效率高,界面非常好看
    • 近乎完美的跨平台一致性
    • 非高实时性和嵌入式应用几乎是必选。
  • 缺点:
    • 打包体积大、运行时内存占用多。
    • 与操作系统底层相关的拓展稍微不太方便

总结

  • 大部分场景下,基于Web路线几乎就是首选。
    • 语言基本上就是JavaScript了。

多说一点基于Web

在Web路线下,也不只Electron一个选项,Electron后端是基于Nodejs实现的。这部分可以换成Quickjs等mini的JavaScript引擎来实现体积优化。

也可以自己使用CEF参考Electron来封装一套类似框架,没必要绑定到Electron这一条技术栈上。

实战相关

因为对GUI编程非常感兴趣,所以今天我也自己做了个实战项目:剪切板助手。

技术路线就是(2)中的基于GPU绘制,将游戏的UI渲染框架拿来作为通用GUI框架开发非实时类App。

理论上界面的可定制性以及性能都能是T1级别的。大家可以自行体验下,看看体积和性能。

  • WeClipper官网

上次更新于: