接上一篇 WPF多进程UI探索(Like Chrome) 找到了相对较靠谱的跨进程传递WPFUI的方法,本篇将对WPF多进程UI框架进行设计。
功能性需求
- 一个主进程作为宿主,承载多个子进程的UI
- 每个子进程相互独立,互不影响
- 主进程和子进程可以灵活拆卸和装配
- ...
非功能性需求
- 对现有的开发模式影响小
- 对潜在的插件扩展提供支持
- 单元测试覆盖率>60%
- ...
设计方案一
image41.png思路是宿主程序启动新的空进程作为
子进程,在子进程中通过AppLoader加载真正子进程的内容,这样的好处是不限制真正子进程的形式,可以是exe,也可以是dll,这样对于后续带UI的第三方插件的支持很友好;缺点则是子进程的情况可能较为复杂,AppLoader的实现会比较麻烦。
设计方案二
image42.png此方案相对方案一更简单,直接在宿主程序中启动子进程程序,省掉了AppLoader的环节。但是,此方案要求子进程是exe程序。
Logical View
image40.pngProcess View
image43.png image44.png说明
需要强调的点是
- 主进程管理各子进程的UI
- 子进程互不影响
- MAF的使用
网友评论