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