如何使 UI 像 iPhone 一样流畅炫酷?

时间:2018-12-19 14:58来源:ZLG致远电子

摘要:随着手机、智能手表等便携式设备的普及,用户对GUI的要求越来越高,嵌入式系统对GUI的需求也越来越迫切,本文将为大家介绍一个轻型、占用资源少、高性能、高可靠、便于移植、可配置及美观的GUI编程框架。

随着手机、智能手表等便携式设备的普及,用户对GUI的要求越来越高,嵌入式系统对GUI的需求也越来越迫切,本文将为大家介绍一个轻型、占用资源少、高性能、高可靠、便于移植、可配置及美观的GUI编程框架。

一、什么是嵌入式GUI?
图形用户界面(Graphical User Interface,简称 GUI,又称图形用户接口)是指采用图形方式显示的计算机操作用户界面。嵌入式GUI即在嵌入式设备上使用显示屏去显示操作界面,主要用来与用户互动。


 
 
二、市面上常见的GUI
当前市面上主流的嵌入式 GUI 主要有:emWin(uCGUI),TouchGFX,Embedded Wizard GUI,以及QT。

TouchGFX 是这两年才发布的嵌入式 GUI,以界面华丽,流畅以及强劲的 TouchGFX Designer著称。美中不足的是 TouchGFX 是要收费的。

Embeded Wizard GUI 也是这两年才发布的嵌入式 GUI,同样以华丽,流畅的界面和强劲的GUIBuilder 著称。独创 Chora 界面编程语言,让大家的界面编程极其简单,GUIBuilder 上面含有非常多的控件,皮肤和主题供用户选择,且支持调试。 美中不足的是 Embeded Wizard GUI 也是要收费的。

emWin 属于老牌的嵌入式 GUI 了,有着十几年的历史,软件架构和功能比较成熟了。但是做出来比较炫的效果非常麻烦,且不支持较为复杂的控件。


 
 
QT是是一个1991年由Qt Company开发的跨平台C++图形用户界面应用程序开发框架。目前使用Linux操作系统的GUI设计大多数是基于QT开发的。

以下是各种GUI对比表:


 
 
三、AWTK使UI像iPhone一样
AWTK是ZLG集团旗下致远电子开源的GUI引擎,其寓意有两方面:


 AWorks Toolkit:AWorks平台内置GUI
 Toolkit AnyWhere:为嵌入式、手机和PC打造的通用GUI

AWUI-js为用户提供分离界面设计和逻辑的框架,AWStudio提供嵌入式组态软件和云组态开发环境。美工可以直接在AWStudio组态软件中进行精美的界面设计,让研发工程师专注于控制逻辑的应用程序。


 
 
AWTK的主要特点:
1. 具有Qt的跨平台

 支持AWorks嵌入式低端、中端和高端各个平台开发;
 支持Linux桌面软件开发;
 支持MacOS桌面软件开发;
 支持Windows桌面软件开发
 支持Web App开发;

2. 具有emWin的小巧高效
AWTK的小并非真的小,而是它可以很小。这主要得益于:


 灵活的架构
通常鱼和熊掌不兼得,功能强大和代码体积相互矛盾,AWTK要在嵌入式的低端,中端和高端平台上运行,要在Android/iOS上运行,要在PC甚至Web上运行,光靠小是不行的,灵活的架构才能 让它可小可大。


 高效的数据格式
AWTK的主题数据和界面描述数据,在开 发时使用XML格式,运行时则编译成二进制的常量,故无需解析和内存分配。图片和字体也可以预先解码并编译成常量,运行时直接从FLASH读取,无需解码和内存分配。所以 AWTK在内存很小的平台仍然可以正常运行。


 保守的设计。
由俭到奢易,由奢到俭难。在设计控件时尽量保守,降低对底层硬件的要求。AWTK可以在低端嵌入式平台上运行。 这些平台典型的配置是32K RAM,512K Flash和低于100M主频。

3. 快
AWTK的快主要得益于:


 硬件加速
AWTK抽象了硬件加速接口,目前支持 STM32的G2D、NXP的PXP和GPU(OpenGL/OpenGLES),充分挖掘硬件的性能。


 缓存绘制
播窗口动画前,预先绘制窗口到缓存,播放动画(平移/弹出动画)时只是纯粹内存拷贝,运行效率到达极致。


 高效的数据格式
主题数据和UI数据以高效的二进制格式存储,使用时无需解析和内存分配,创建窗口可在瞬间完成。


 脏矩形算法
启用脏矩形算法,每次只绘制变化的部分,提高运行效率并降低功耗。
在IM287A的Linux系统上,Qt打开一个窗口需要3秒以上,AWTK则瞬间以超过40FPS的动画打开窗口(如果使用3FB,可以轻松达到60FPS)。

4. 具有TouchGfx/Embedded Wizard的酷炫

支持现代GUI常见特性:

 窗口动画
支持平移、弹出、缩放和淡入淡出等动画。


 控件动画
支持移动、缩放、翻转、值变化和淡入淡出等动画。


 动画支持缓动作效果
支持加速、减速和弹跳等数十种效果,亦可以自定义想要的效果。


 支持滑动
ListView/SlideView/Selector/Switch等控件支持滑动效果。


 支持游戏引擎常见功能
帧动画、骨骼动画(TODO)和粒子效果(TODO)。


 主题支持全局和窗口两种方式
轻松定制控件的外观效果,而无需要改变系统的主题。


 分离界面描述文件
开发时采用XML格式描述,运行时编译成二进制格式。分离界面方便了开 发,而又无运行时的开销。

5. 稳定
通过良好的架构设计和编程风格、单元测试、动态(valgrind)检查和Code Review保证其运行的稳定性。

6. 完全开源,商用免费

 开放全部源码;
 商业应用免费;
 没有阴谋,放心使用,不要想多了。但我们会为ZLG集团的客户提供更好的服务和支持。

开源项目网址:https://github.com/zlgopen/awtk
效果视频链接:https://v.qq.com/txp/iframe/player.html?vid=n07811pocfx

AWTK,使UI像iPhone一样!


 
 
M1052跨界核心板板载Cortex-M7的RT1050处理器,既具备MPU的强劲处理性能,又兼顾MCU微控制器的简单易用与实时性优势!

最高支持1366*768分辨率LCD,集成电容触摸驱动,并预装AWorks 实时操作系统,让触控更稳定顺畅。


 
免责声明:本文若是转载新闻稿,转载此文目的是在于传递更多的信息,版权归原作者所有。文章所用文字、图片、视频等素材如涉及作品版权问题,请联系本网编辑予以删除。
我要投稿
近期活动
帖子推荐更多

Copyright 2008-2024 21dianyuan.com All Rights Reserved 备案许可证号为:津ICP备10002348号-2