本文大纲

1、Prism框架下载和说明

2、Prism项目预览及简单介绍。

3、Prism框架如何在项目中使用。

Prism框架下载和说明

Prism框架是针对WPF和Silverlight的MVVM框架,这个大家应该之前,都有所耳闻,关于该框架的具体说明,可以参考如下地址:

Prism框架下载

Prism框架通过功能模块化的思想,来讲复杂的业务功能和UI耦合性进行分离,通过模块化,来最大限度的降低耦合性,很适合我们

进行类似插件话的思想来组织系统功能。并且模块之间,通过发布和订阅事件来完成信息的通信。而且其开放性支持多种框架集成。

Prism项目预览及简单介绍

框架下载完毕后,解压后的文件的组织模式如下:

我们先打开Hello World QuickStart.bat看看

上面是项目的组织结构,关于该项目内部的代码结构和写法,我们来一一分析和解释。

A、先看看HelloworldModule的代码和内容。

Views文件夹中包含了UI视图界面内容。

其中只是包含了一个Textbox文本控件,其他没有太多的内容。

接着看看该设计文件对应的后台cs文件中的代码。

也是没有什么特别的内容。接着我们看看Module中的内容代码:

上面对于Module中的代码,我们就简单的分析完毕了,当然这个模块没有办法独立的运行,我们肯定要将模块加载到宿主或某个控制的主界面中,把它显示出来即可,下面我们就来看看Prism最关键的部分。

B、宿主或主界面。

先看看APP文件

设计视图中未指定,那么肯定是在cs文件中的某处直接或简介指定。

果然,这里采用了BootStrapper来完成Run方法,实现应用的启动,我们可以来深挖,看看该文件中都包含什么内容。

接着,我们来看看Shell中的内容:

我们在来看看shell里面有没有什么特殊的代码,打开后台cs文件

并无任何特殊的内容。所以我们可以大概的了解到了Prism的运行机制和流程,那么运行后的效果如下:

符合预期的目标,下面我们将继续深入的挖掘Prism的强大之处。

Prism框架如何在项目中使用

Prism是一个强大的Mvvm框架,下面我们将重点讲解如何在项目使用Prism提供的基础功能,完成基于MVVM的WPF项目的框架设计和开发,包括应用程序的架构。

项目的解决方案结构,项目采用Prism作为UI框架,NHiberia+Unity作为ORM和IOC框架。

下面我们就来一步步解析项目中的每个部分的细节和最终项目如何把这些细节组织起来的做一个整体结构上的说明。关于其他的分层设计结构我就不多说了,只关注Prism部分的内容。

1、关于对Prism的基础封装

为什么不直接使用Prism,我们希望开发人员的学习成本更低,所以,我们队Prism的一些方法进行了封装,更符合开发人员之前熟悉的MVVM模式。

关于封装的具体内容,我们后续会看到代码。

2、关于Infrastructure基础设施层定义

3、具体的模块定义

4、看看程序应用宿主的定义:

通过上面,我们介绍了基础的项目和具体的模块和宿主模块的定义,下面我们就来详细的分析下Prism如何加载模块的并且模块间如何通信,如何完成业务功能的完整流程:

在之前介绍HelloWorld的时候,我们有简单的介绍了Prism的基本流程是宿主会在Bootstrappter中对模块进行装载并初始化,下面我们来看看我们在我给出的例子中的具体过程。

a、Shell的定义:

与之前的区别就是在于,我们原来是手写的字符串,这里通过单独的类定义成静态的常量成员,我们能够防止名称出错的可能。同时我们也可以避免因为某处界面上Region符号的变化,因为某处没有修改,而造成不同步,运行出错的情况的发生,更容易统一的管理。具体的基础设施层中关于RegionType的定义如下:

接着查看Shell的后台cs代码:

 1     /// <summary>
 2     /// MainWindow.xaml 的交互逻辑
 3     /// </summary>
 4     [Export]
 5     public partial class Shell : Window
 6     {
 7         public Shell()
 8         {
 9             InitializeComponent();
10         }
11
12         /// <summary>
13         /// 设置ViewModel
14         /// </summary>
15         /// <remarks>
16         /// This set-only property is annotated with the <see cref="ImportAttribute"/> so it is injected by MEF with
17         /// the appropriate view model.
18         /// </remarks>
19         [Import]
20         [SuppressMessage("Microsoft.Design", "CA1044:PropertiesShouldNotBeWriteOnly", Justification = "Needs to be a property to be composed by MEF")]
21         ShellViewModel ViewModel
22         {
23             set
24             {
25                 this.DataContext = value;
26                 if (this.DataContext != null)
27                 {
28                     ((ShellViewModel)this.DataContext).OnStatusChanged += new Action<string>(SystemStatusManagementEventHandler);
29                 }
30             }
31         }
32
33         public void SystemStatusManagementEventHandler(string parameter)
34         {
35             if (parameter.IsNullOrEmpty())
36             {
37                 throw new ArgumentNullException("无法完成操作");
38             }
39
40             switch (parameter)
41             {
42                 case HM_EMSTS.WorkStation.Infrastructure.MenuParams.Max:
43                     this.WindowState = System.Windows.WindowState.Maximized;
44                     break;
45                 case HM_EMSTS.WorkStation.Infrastructure.MenuParams.Min:
46                     this.WindowState = System.Windows.WindowState.Minimized;
47                     break;
48                 case HM_EMSTS.WorkStation.Infrastructure.MenuParams.Close:
49                     if (MessageBox.Show("是否退出系统?", "退出系统?", MessageBoxButton.OKCancel, MessageBoxImage.Question) == MessageBoxResult.OK)
50                     {
51                         this.Close();
52                     }
53                     break;
54             }
55         }
56     }

上面的代码中采用了MEF中的Export特性和Import特性。 关于MEF的内容,我这里就不多介绍了,不是很了解的可以谷歌或百度下。

继续,我们查看Shell的ViewModel定义,因为上面的后台的cs代码中有订阅相关的事件。

 1    [Export(typeof(ShellViewModel))]
 2    public class ShellViewModel : HM_EMSTS.WorkStation.UICommon.NotifyBaseObject
 3    {
 4        public Action<string> OnStatusChanged;
 5
 6        [ImportingConstructor]
 7        public ShellViewModel(IEventAggregator eventAggregator)
 8        {
 9            //注册事件
10            if (eventAggregator == null)
11            {
12                throw new ArgumentNullException("eventAggregator");
13            }
14
15            eventAggregator.GetEvent<HM_EMSTS.WorkStation.Infrastructure.Events.SystemStatusManagementEvent>().Subscribe(this.SystemStatusManagementEventHandler);
16        }
17
18        public void SystemStatusManagementEventHandler(string parameter)
19        {
20            if (parameter.IsNullOrEmpty())
21            {
22                throw new ArgumentNullException("无法完成操作");
23            }
24
25            if (OnStatusChanged != null)
26                OnStatusChanged(parameter);
27        }
28    }

上面的代码,主要是为了完成对事件的订阅,并且当收到订阅的事件时,通知出去。这里特别注意,可以参考下图:

关于Event的定义我们可以看看上述Event的定义:

如果想按照,我们之前写的那样的形式来绑定和触发事件操作的话,必须这么写。

那么下面我们来看看ShellModule的定义吧,我们这里的代码如下:

我们使用了某个Module项目中的页面来替换shell中的Region。这样保证了Shell运行起来后能够正确的显示界面。

下面来看看项目中最重要的WorkStationBootstrapper的定义

前面介绍的helloWorld里面是采用的Unity容器,这里是MEF,所以要注意的部分,有所不同。这里需要制定MEF可导入导出部件所在的目录或程序集

我们知道shell后台cs的代码定义前面也说过了,有带有export标记。那么当执行上述的代码后,将会出现在MEFbootstrappter的Container中。这里的container是CompositionContainer是MEF中定义的。

接着查看如下方法:

通过上面的几个方法,此时,我们的主程序,就完成了对Region的解析,显示出来即可。

B、模块定义:

Module主要是为了,替换Region符合和标记为具体的界面而是用的。

我们下面挑选一个页面来展示完整的定义和操作。

1、Model定义:

当我们的Model具有自动通知机制时,特别对于列表中的某个单元格的属性发生改变后,不需要刷新整个列表,这时候就会自动完成更新,WPF会自动完成。

2、IView接口定义。

因为我们这里采用MVP的设计模式,所以要求所有的View必须继承自IView接口。

我们这里都是直接定义View对应的唯一接口即可,主要是为了MEF的Export和Import时有用。

3、View的定义。

设计视图:

后台代码:

4、ViewModel的定义。

这里由于我们采用MVP模式,所有对于不同View之间的交互,我们这里放到了Presenter中,ViewModel充当的是对IView界面的完全控制抽象。

所以我们看到这里,没有任何的业务代码。但是对已IView界面所有的绑定信息,都需要定义到该类中。

5、Presenter定义。

上面讲Presenter标记了Export。主要是在Module中对Region进行映射时使用。

然后我们来看看PresenterBase的定义,一看便明白

这样在构造展示器时,我们便可以将IView和ViewModel之间的关系完成绑定。

6、Module的定义

这样我们就完成了,一个模块的功能开发,该功能模块尽量功能独立。

最终,我们通过一个主界面,将这样功能模块组装起来即可。

最终

将上面构建的模块运行下,看看效果,也许效果不是很好看,没有设置样式。

程序运行的框架还是非常的清晰,上面是工具栏,菜单栏,内容区。通过Prism我们可以讲菜单栏或者工具栏中的功能都设计成独立的模块,分别进行装载和控制,这样能够具有非常好的扩展性和可维护性。

Prism详解【转】相关推荐

  1. WPF开发之Prism详解【内附源码】

    在实际应用开发中,随着项目业务逐渐复杂,耦合度会越来越高,维护成本也会直线上升,所以解耦也变得越来越重要.Prism框架为WPF开发中解耦提供了非常便捷的应用.今天主要以一个简单的小例子,简述WPF开 ...

  2. 机器视觉:工业镜头专业词汇中英文详解

    机器视觉:工业镜头专业词汇中英文详解 镜头:Lens 焦距:Focal Length  25 光圈(F数):Iris 1.8~16(F-number/F no.) 有效透镜孔径:Effective L ...

  3. 图注意力网络GAT - 《Graph Attention Networks》论文详解

    目录 前言 正文 图注意力机制层(Graph Attentional Layer) 层的输入 注意力系数 归一化注意力系数 通过邻居节点更新自身节点 层的输出 GAT相比于先前研究的优势 附作者简介 ...

  4. 从命令行到IDE,版本管理工具Git详解(远程仓库创建+命令行讲解+IDEA集成使用)

    首先,Git已经并不只是GitHub,而是所有基于Git的平台,只要在你的电脑上面下载了Git,你就可以通过Git去管理"基于Git的平台"上的代码,常用的平台有GitHub.Gi ...

  5. JVM年轻代,老年代,永久代详解​​​​​​​

    秉承不重复造轮子的原则,查看印象笔记分享连接↓↓↓↓ 传送门:JVM年轻代,老年代,永久代详解 速读摘要 最近被问到了这个问题,解释的不是很清晰,有一些概念略微模糊,在此进行整理和记录,分享给大家.在 ...

  6. docker常用命令详解

    docker常用命令详解 本文只记录docker命令在大部分情境下的使用,如果想了解每一个选项的细节,请参考官方文档,这里只作为自己以后的备忘记录下来. 根据自己的理解,总的来说分为以下几种: Doc ...

  7. 通俗易懂word2vec详解词嵌入-深度学习

    https://blog.csdn.net/just_so_so_fnc/article/details/103304995 skip-gram 原理没看完 https://blog.csdn.net ...

  8. 深度学习优化函数详解(5)-- Nesterov accelerated gradient (NAG) 优化算法

    深度学习优化函数详解系列目录 深度学习优化函数详解(0)– 线性回归问题 深度学习优化函数详解(1)– Gradient Descent 梯度下降法 深度学习优化函数详解(2)– SGD 随机梯度下降 ...

  9. CUDA之nvidia-smi命令详解---gpu

    nvidia-smi是用来查看GPU使用情况的.我常用这个命令判断哪几块GPU空闲,但是最近的GPU使用状态让我很困惑,于是把nvidia-smi命令显示的GPU使用表中各个内容的具体含义解释一下. ...

最新文章

  1. python opencv 拼接 连接 显示 图片
  2. java中的abstract和interface差异
  3. jquery--- 属性和样式的操作 设置和获取HTML、文本和值、焦点事件
  4. C++ STL容器vector篇(三) vector容器大小和数组大小, 插入和删除元素, 存储和读取元素
  5. C++ const用法
  6. 如何从论文中挖掘和研究思路的办法
  7. Java并发指南12:深度解读 java 线程池设计思想及源码实现
  8. docker 运维shipyard 构建以及操作
  9. python合并word表格_python合并word
  10. Linux系统命令(网络通信)
  11. JavaScript execCommand函数
  12. markdown的简单使用,基础的一些用法讲解
  13. 【Java面试题】有三个线程 t1,t2,t3,怎么确保它们按顺序执行?
  14. win下禁用光标闪烁 记录
  15. Android Studio的项目太难配置?来看看,手把jio教你~
  16. 蓝色的建站网站页脚布局代码
  17. 威威猫系列故事——打地鼠
  18. xorg linux终端,Ubuntu使用cvt命令生成xorg.conf下的屏幕分辨率和刷新率
  19. 结构力学常用公式表,早晚用得到!
  20. 游戏本天梯_降维打击,打败对手也伤了自家兄弟(笔记本CPU天梯V5.20)

热门文章

  1. mysql 脏数据查询_MySQL数据库02
  2. 信息学奥赛一本通 1193:吃糖果 | OpenJudge NOI 2.6 1944:吃糖果
  3. OpenJudge NOI 1.8 24:蛇形填充数组
  4. 信息学奥赛一本通(1211:判断元素是否存在)
  5. 理论基础 —— 二叉树 —— 三叉链表
  6. ftp响应码以及解释说明是服务器返回,FTP命令字和响应码解释
  7. 域服务器批量修改用户密码,Windows域控制器批量创建用户
  8. VSCode+Win10安装
  9. 回调破前高意味着什么_4连阳后是回调还是突破呢?
  10. 损失层SoftmaxWithLossLayer