Silverli“.NET研究”ght开发廋身攻略(二)

简介:   继上一篇《Silverlight开发廋身攻略(一)》,在上一节中我主要介绍了在实际开发中怎么动态加载图片资源的方法,并附有实例。在这一节中主要给大家介绍MEF(Managed Extensibility Framework)的知识来实现Xap包的动态加载。

  继上一篇《Silverlight开发廋身攻略(一)》,在上一节中我主要介绍了在实际开发中怎么动态加载图片资源的方法,并附有实例。在这一节中主要给大家介绍MEF(Managed Extensibility Framework)的知识来实现Xap包的动态加载。

  Managed Extensibility Framework(MEF)是.NET平台下的一个扩展性管理框架,它是一系列特性的集合,包括依赖注入(DI)以及Duck Typing等。MEF为开发人员提供了一个工具,让我们可以轻松的对应用程序进行扩展并且对已有的代码产生最小的影响,开发人员在开发过程中根据功能要求定义一些扩展点,之后扩展人员就可以使用这些扩展点与应用程序交互;同时MEF让应用程序与扩展程序之间不产生直接的依赖,这样也允许在多个具有同样的扩展需求之间共享扩展程序。简单的说:MEF程序设计主要Export (输出)、Import (输入)、Compose (组合)三个动作来完成。MEF的核心包括一个catalog和一个CompositionContainer。category用于发现扩展,而container用于协调创建和梳理依赖性。每个可组合的Part提供了一个或多个Export,并且通常依赖于一个或多个外部提供的服务或Import。每个Part管理一个实例为应用程序运行。
  关于MEF的基础知识在这里不是重点,大家可以在网上搜一下,有很多介绍这方面的文章。下面直截以实例转入正题。在实例中我们创建三个Silverlight Application项目,它们分别是:MEFLoadXap、FristXap、SecondXap。MEFLoadXap是主项目,它是一个容器,通过它来动态加载FristXap、SecondXap包。本实例环境是VS.net 2010 net4.0,在Net4.0中集成了MEF的功能。

  一、新建MEFLoadXap项目

      1、用VS.net 2010新建名为MEFLoadXap的Silverlight Application项目,添加System.ComponentModel.Composition、System.ComponentModel.Composition.Initialization引用,如下图所示:    

  2、在MEFLoadXap项目下添加DeploymentCatalogService.cs文件,在文件中添加IDeploymentCatalogService接口,并编写继承此接口的DeploymentCatalogService的类,此类主要封装了下载指定Xap包,自动导入带有Export属性标签类型为UserControl控件对象。

  IDeploymentCatalogService代码:

 
 
上海网站建设tyle="color: #808080;">/// <summary>
/// 加载Xap服务接口
/// </summary>
public interface IDeploymentCatalogService
{
/// <summary>
/// 加载Xap包的方法
/// </summary>
/// <param name="uri"> Xap包路径 </param>
/// <param name="completedAction"> 加载完成后的事件 </param>
void AddXap( string uri, Action < AsyncCompletedEventArgs > completedAction = null );
/// <summary>
/// 移除Xap包的方法
/// </summary>
/// <param name="uri"> Xap包路径 </param>
void RemoveXap( string uri);
}

  DeploymentCatalogService类的代码:

 
  
/// <summary>
/// 加载Xap服务类
/// </summary>
[Export( typeof (IDeploymentCatalogService))]
public class DeploymentCatalogService : IDeploymentCatalogService
{
private static AggregateCatalog _aggregateCatalog;
Dictionary
< string , DeploymentCatalog > _catalogs;

public DeploymentCatalogService()
{
_catalogs
= new Dictionary < string , DeploymentCatalog > ();
}
/// <summary>
/// 初始化对象的静态方法
/// </summary>


public static void Initialize()
{
_aggregateCatalog
= new AggregateCatalog();
_aggregateCatalog.Catalogs.Add(
new DeploymentCatalog());
CompositionHost.Initialize(_aggregateCatalog);
}
/// <summary>
/// 加载Xap包的方法
/// </summary>
/// <param name="uri"> Xap包路径 </param>
/// <param name="completedAction"> 加载完成后的事件 </param>

public void AddXap( string uri, Action < AsyncCompletedEventArgs >上海闵行企业网站制作an> completedAction = null)
{
DeploymentCatalog catalog;
if (!_catalogs.TryGetValue(uri, out catalog))
{
catalog
= new DeploymentCatalog(uri);

if (completedAction != null)
{
catalog.DownloadCompleted
+= (s, e) => completedAction(e);
}
else
{
catalog.DownloadCompleted
+= catalog_DownloadCompleted;
}

catalog.DownloadAsync();
_catalogs[uri]
= catalog;
_aggregateCatalog.Catalogs.Add(catalog);
}
}

上海徐汇企业网站设计与制作
void catalog_DownloadCompleted(object sender, AsyncCompletedEventArgs e)
{
if (e.Error != 上海徐汇企业网站制作>null)
{
throw e.Error;
}
}
/// <summary>
/// 移除Xap包的方法
/// </summary>
/// <param name="uri">Xap包路径</param>

public void RemoveXap(string uri)
{
DeploymentCatalog catalog;
if (_catalogs.TryGetValue(uri, out catalog))
{
_aggregateCatalog.Catalogs.Remove(catalog);
_catalogs.Remove(uri);
}
}
}
3、修改设计MainPage,在MainPage界面设计中我们把整个界面分为左、右两部分,左边放两个按钮,右边放一个容器控件用于承载显示动态下载Xap包中的控件,其Xaml代码如下:
 
 
< Grid x:Name ="LayoutRoot" Background ="#FFD8D8D8" >
< Grid.ColumnDefinitions >
< ColumnDefinition Width ="200" ></ ColumnDefinition >
< ColumnDefinition Width ="*" ></ ColumnDefinition >
</ Grid.ColumnDefinitions >
< Button Height ="36" Width ="160" Margin ="20,106,20,158" Content ="加载一" Click ="Button_Click" ></ Button >
< Button Height ="36" Width ="160" Margin ="20,189,20,75" Content ="加载二" Click ="Button_Click_1" ></ Button >
< Border x:Name ="parentContent" Grid.Column ="1" ></ Border >
</ Grid >

  MainPage类的CS代码:

 
 
public partial class MainPage : UserControl, IPartImportsSatisfiedNotification
{
public MainPage()
{
InitializeComponent();
// 通过此方法调用DeploymentCatalogService对象
// 自动将此对象与CatalogService属性邦定在一起
CompositionInitializer.SatisfyImports( this );
this .Loaded += new RoutedEventHandler(MainPage_Loaded);
}

void MainPage_Loaded( object sender, RoutedEventArgs e)
{
LoadSelectedModule();
}
private string m_xapName = " FristXap.xap " ;

#region IPartImportsSatisfiedNotification Members

public void OnImportsSatisfied()
{
LoadSelectedModule();
}

#endregion
/// <summary>
/// 导入类型是IDeploymentCatalogService并带有Export属性标签对象
/// </summary>
[Import]
public IDeploymentCatalogService CatalogService { get ; set ; }
/// <summary>
/// 导入类型是UserContronl并带有Export属性标签的所有控件
/// </summary>
[ImportMany(AllowRecomposition = true )]
public Lazy < UserControl > [] mefModules { get ; set ; }


/// <summary>
/// 加载XAP包的方法
/// </summary>
private void LoadSelectedModule()
{
string selectXapName = m_xapName.Replace( " .xap " , " . " );

CatalogService.AddXap(m_xapName);
var ctrs
= (from m in mefModules.ToList()
where m.Value.ToString().Contains(selectXapName)
select m).FirstOrDefault();
if (ctrs != null )
{
parentContent.Child
= ctrs.Value;
}

}

private void Button_Click( object sender, RoutedEventArgs e)
{
m_xapName
= " FristXap.xap " ;
LoadSelectedModule();
}

private void Button_Click_1( object sender, RoutedEventArgs e)
{
m_xapName
= " SecondXap.xap " ;
LoadSelectedModule();
}
}

  二、新建FristXap项目

  1、用VS.net 2010新建名为FristXap的Silverlight Application项目,添加System.ComponentModel.Composition、System.ComponentModel.Composition.Initialization引用

  2、删除FristXap项目下的App.xaml、MainPage.xaml文件,因它是被加载项目基本没有什么用处

  3、添加名为Ellipse.xaml用户控件,此控件主要作用是画一个椭圆。此控件效果图如下:    

    控件Xaml代码如下:

 
 
< Grid x:Name ="LayoutRoot" >
< Ellipse Height ="300" Width ="400" Fill ="#FF3BC73B" ></ Ellipse >
< TextBlock Text ="第一个XAP包中的椭圆控件" VerticalAlignment ="Center" HorizontalAlignment ="Center" FontSize ="14" ></ TextBlock >
</ Grid >

  三、新建SecondXap项目

  1、用VS.net 2010新建名为SecondXap的Silverlight Application项目,添加System.ComponentModel.Composition、System.ComponentModel.Composition.Initialization引用

  2、删除SecondXap项目下的App.xaml、MainPage.xaml文件 

  3、添加名为Rectangle.xaml用户控件,此控件主要作用是画一个矩形。此控件效果图如下:    

  四、编译运行项目,点击如下图所示的按钮动态加载FristXap.xap、SecondXap.xap包中的控件对象,加载过程是首先判断指定的包是否已下载到本地,如果在本地则直接加载;如果不在本地,则先到远程服务器上下载Xap包,后加载控件对象。运行效果图如下:   

  本实例源代码:下载

目录
相关文章
|
16天前
|
存储 开发工具 Android开发
使用.NET MAUI开发第一个安卓APP
【9月更文挑战第24天】使用.NET MAUI开发首个安卓APP需完成以下步骤:首先,安装Visual Studio 2022并勾选“.NET Multi-platform App UI development”工作负载;接着,安装Android SDK。然后,创建新项目时选择“.NET Multi-platform App (MAUI)”模板,并仅针对Android平台进行配置。了解项目结构,包括`.csproj`配置文件、`Properties`配置文件夹、平台特定代码及共享代码等。
|
18天前
|
开发框架 .NET C#
VSCode开发.net项目时调试无效
【9月更文挑战第22天】在使用 VSCode 开发 .NET 项目时遇到调试问题,可从项目配置、调试配置、调试器安装、运行环境、日志和错误信息等方面排查。确认项目类型及文件配置,检查 `launch.json` 文件及配置项,确保调试器扩展已安装并启用,验证 .NET 运行时版本和环境变量,查看 VSCode 输出窗口和项目日志文件,检查权限及代码错误。若问题仍未解决,可查阅官方文档或社区论坛。
|
24天前
|
人工智能 前端开发 开发工具
解读.NET 技术的开发潜力
本文全面介绍了.NET技术在软件开发领域的核心优势、创新应用及面临的挑战。.NET以其统一的开发平台、强大的工具和跨平台能力,成为企业级应用、Web应用乃至游戏开发的理想选择。然而,在性能优化、容器化及AI集成等方面仍需不断突破。通过积极拥抱开源和社区驱动模式,.NET将持续推动软件开发的进步。
41 1
|
1月前
|
存储 运维
.NET开发必备技巧:使用Visual Studio分析.NET Dump,快速查找程序内存泄漏问题!
.NET开发必备技巧:使用Visual Studio分析.NET Dump,快速查找程序内存泄漏问题!
|
1月前
|
SQL 关系型数据库 数据库
七天.NET 8操作SQLite入门到实战详细教程(选型、开发、发布、部署)
七天.NET 8操作SQLite入门到实战详细教程(选型、开发、发布、部署)
|
1月前
|
消息中间件 开发框架 前端开发
YuebonCore:基于.NET8开源、免费的权限管理及快速开发框架
YuebonCore:基于.NET8开源、免费的权限管理及快速开发框架
|
1月前
|
开发框架 JavaScript 前端开发
|
2月前
|
C# Windows 开发者
超越选择焦虑:深入解析WinForms、WPF与UWP——谁才是打造顶级.NET桌面应用的终极利器?从开发效率到视觉享受,全面解读三大框架优劣,助你精准匹配项目需求,构建完美桌面应用生态系统
【8月更文挑战第31天】.NET框架为开发者提供了多种桌面应用开发选项,包括WinForms、WPF和UWP。WinForms简单易用,适合快速开发基本应用;WPF提供强大的UI设计工具和丰富的视觉体验,支持XAML,易于实现复杂布局;UWP专为Windows 10设计,支持多设备,充分利用现代硬件特性。本文通过示例代码详细介绍这三种框架的特点,帮助读者根据项目需求做出明智选择。以下是各框架的简单示例代码,便于理解其基本用法。
80 0
|
2月前
|
开发者 Apache 程序员
揭秘Apache Wicket:页面生命周期背后的神秘力量!
【8月更文挑战第31天】李工是一位热爱Web开发的程序员,近日在技术博客上分享了他对Apache Wicket框架的学习心得,特别是页面生命周期的理解。他认为掌握Wicket页面生命周期对于开发富交互式Web应用至关重要。他通过一个简单的计数器应用示例,详细解释了Wicket的组件化设计理念以及页面和组件在生命周期中的变化。
33 0
|
2月前
|
微服务 API Java
微服务架构大揭秘!Play Framework如何助力构建松耦合系统?一场技术革命即将上演!
【8月更文挑战第31天】互联网技术飞速发展,微服务架构成为企业级应用主流。微服务将单一应用拆分成多个小服务,通过轻量级通信机制交互。高性能Java Web框架Play Framework具备轻量级、易扩展特性,适合构建微服务。本文探讨使用Play Framework构建松耦合微服务系统的方法。Play采用响应式编程模型,支持模块化开发,提供丰富生态系统,便于快速构建功能完善的微服务。
40 0