RadioTerminal设计逻辑

虽然基于Web API的本地UI设计逐渐开始流行,但是大多数传统的桌面设计和数据驱动的Web设计略有不同。

在RadioTerminal中,参考了wxPython的许多Demo/Sample代码。总体设计思路是:

  1. 由wxPython/wxWidget完成前端用户界面的设计布局,采用异步事件触发模式,运行在主线程中;
  2. pyserial负责虚拟串口、设备配置、网络配置功能,并运行在单独一个线程中;
  3. 主线程与串口线程之间采用wx.CallAfter()交互,用wx.lib.pubsub进行消息分发;
  4. 其他小的耗时任务可以使用单独的工作线程,比如自动检测COM口等。
  5. 采用config文件保存基础配置;
  6. 采用log.txt保存日志文件;
  7. 采用SQLite保存应用相关的消息或传感器数据。

目前,我正在整合RadioTerminal主线程与串口线程。这个设计可以适用于大多数与USB虚拟串口相关的桌面应用。

更新

目前的代码已经解决了几个问题:

  1. 因为ShowModal()调用了两次,自定义对话框ComboDialog 返回要点击两次OK/CANEL 。所以这是一个Bug,已经改正。
  2. 工具栏中 New 图标很难点击,采用大图标可以解决。
  3. 自定义对话框ComboDialog 返回值无法获取,将对话框中的选项改写为self私有对象,单独编写方法来获取,同时通过OK/CANCEL来判断是否获取对象是否需要利用。
  4. config文件,目前暂时采用ConfigParser来简化配置方法,没有使用wx.ConfigBase之类的手段。
  5. 通过running标志位来使得后台线程与主程序一同退出。
  6. 使用pubsub模块实现了主界面与串口服务线程间的解耦,两者(线程)都是pubsub

看来出版订阅模式不仅仅在物联网MQTT协议中,Redis数据库,多服务器RPC通讯,运维中得到使用,在单一桌面程序中只要是多线程或者多界面模型中都可以使用。却别在于底层是否采用socket而已。

你可能感兴趣的:(RadioTerminal设计逻辑)