AWTK-MVVM - C 语言 MVVM 框架


LGPL
跨平台
C/C++

软件简介

AWTK-
MVVM是一套为AWTK用C语言开发,并支持各种脚本语言的MVVM框架,实现了数据绑定、命令绑定和窗口导航等基本功能,使用AWTK-
MVVM开发应用程序,无需学习AWTK本身的API,只需学习绑定规则和Model的实现方式即可。

一、MVVM

MVVM(Model-View-ViewModel)是分离用户界面和业务逻辑的经典模式。

分离用户界面和业务逻辑的好处:

  • 让用户界面可以独立变化。
  • 方便为业务逻辑编写单元测试程序。
  • 方便UI设计师和程序员的分工和合作。

MVVM相比MVP和MVC的优势:

  • 使用更简单。
  • 分离更彻底。
  • 声明式的编程更容易维护。

MVVM的核心思想有两个:

  • 通过数据绑定实现View与Model之间的数据交换。
  • 通过命令绑定实现View事件与Model行为之间的关联。

二、AWTK-MVVM

AWTK-
MVVM是一套为AWTK用C语言开发,并支持各种脚本语言的MVVM框架,实现了数据绑定、命令绑定和窗口导航等基本功能,使用AWTK-
MVVM开发应用程序,无需学习AWTK本身的API,只需学习绑定规则和Model的实现方式即可。与其它MVVM框架相比,其特点有:

  • 代码小。
  • 性能高。
  • 内存开销小。
  • 隔离更彻底。
  • 可移植到其它GUI。
  • 支持多种编程语言(目前支持C/JS)。

三、使用方法

编译linux-fb版本,请修改SConstruct

#for pc
#sys.path.insert(0, '../awtk/')

#for linux-fb
sys.path.insert(0, '../awtk-linux-fb/')
  • 运行demos

    ./bin/demo1

本文以Linux/MacOS为例,Windows可能会微妙差异,请酌情处理。

四、文档

五、示例

C DEMO JS DEMO 说明
demo1 jsdemo1 数据绑定基本用法
demo2 jsdemo2 trigger参数的用法
demo3 jsdemo3 converter参数的用法
demo4 jsdemo4 显式更新(Trigger=Explicit)的用法
demo5 jsdemo5 validator参数的用法
demo6 jsdemo6 命令绑定的基本用法
demo7 jsdemo7 以计算器为例的综合用法
demo8 jsdemo8 以shape编辑为例的综合用法
demo9 jsdemo9 多窗口的基本用法
demo10 jsdemo10 定时器的基本用法
demo11 jsdemo11 一个视图多个ViewModel的用法
demo12 jsdemo12 多窗口之间参数传递
demo13 jsdemo13 列表视图的基本用法
demo14 jsdemo14 快捷键的基本用法
demo15 (no) 自定义导航器处理插件,以及MVVM窗口和非MVVM窗口的交互
(no) jsdemo15 combox 数据联动
(no) jsdemo16 动态界面
demo16 (no) 集成硬件外设
demo17 (no) 无GUI情况集成硬件外设
(no) jsdemo17 控制控件的可见性
(no) jsdemo18 复杂属性值的表示方法
demo19 (no) 控制动画启停

完整示例及模板项目:awtk-mvvm-c-hello