C# 使用WPF应用程序使用MEF运行多个不同的应用程序

C# 使用WPF应用程序使用MEF运行多个不同的应用程序,c#,wpf,mef,C#,Wpf,Mef,我正在尝试创建一个WPF应用程序,它将成为其他应用程序的中心点。主应用程序应该能够根据用户需求动态加载其他应用程序。在做了一些研究之后,MEF似乎可以解决这个问题 我对MEF非常陌生,所以我编写了一个测试应用程序,并试图让MEF工作。测试应用程序定义了一个非常基本的ITool接口。我能够毫不费力地从类库导入多个类,但是我无法导入另一个WPF应用程序。这在MEF中是可能的吗 我的主WPF应用程序创建了ToolContainer的一个实例,该实例创建并组合部件 class ToolContainer

我正在尝试创建一个WPF应用程序,它将成为其他应用程序的中心点。主应用程序应该能够根据用户需求动态加载其他应用程序。在做了一些研究之后,MEF似乎可以解决这个问题

我对MEF非常陌生,所以我编写了一个测试应用程序,并试图让MEF工作。测试应用程序定义了一个非常基本的ITool接口。我能够毫不费力地从类库导入多个类,但是我无法导入另一个WPF应用程序。这在MEF中是可能的吗

我的主WPF应用程序创建了ToolContainer的一个实例,该实例创建并组合部件

class ToolContainer
{
    [ImportMany(typeof(ITool))]
    IEnumerable<Lazy<ITool>> _tools;

    private CompositionContainer _container;

    public ToolContainer()
    {
        AggregateCatalog catalog = new AggregateCatalog();
        catalog.Catalogs.Add(new DirectoryCatalog(
            "C:\\Application Development\\Tool Center\\Tool Extensions"));

        _container = new CompositionContainer(catalog);

        try
        {
            _container.ComposeParts(this);
        }
        catch (CompositionException compositionException)
        {
            //TODO: show error dialog
        }
    }

}
我已经创建了多个从ITool继承的类,并且导出的效果很好。这里就是一个例子

[Export(typeof(ITool))]
public class Class1 : ITool
{
    public String ToolName
    {
        get { return "....."; }
    }

    public void OpenTool()
    {
        //open the tool
    }
}
现在我想导入一个完整的WPF应用程序,它继承了ITool接口。这里的想法是,外部用户可以创建自己的WPF应用程序,这些应用程序可以从主WPF应用程序运行。在未来,ITool界面将更加先进,但我现在正在努力完成基本的工作。我创建了一个新的测试WPF项目,并将App.xaml.cs修改为以下内容:

[Export(typeof(ITool))]
public partial class App : Application, ITool
{
    public String ToolName
    {
        get { return "Tool Sample"; }
    }

    public void OpenTool()
    {
       //open the tool
    }
}
当我这样做时,工具不包含我的新WPF应用程序,但包含Class1。知道我做错了什么吗?有更好的方法吗?任何帮助都将不胜感激

默认情况下,仅搜索目录中
*.dll
文件中的类型。您可以通过添加第二个目录来查找.NET可执行文件中的类型来实现此“工作”,如下所示:

AggregateCatalog catalog = new AggregateCatalog();
catalog.Catalogs.Add(new DirectoryCatalog(
        "C:\\Application Development\\Tool Center\\Tool Extensions"));
catalog.Catalogs.Add(new DirectoryCatalog(
        "C:\\Application Development\\Tool Center\\Tool Extensions", "*.exe")); 
尽管如此,我还是建议不要这样做。与其让您的用户导出应用程序,我建议让他们导出实现
ITool
UserControl
。这将以一种更符合预期的方式运行,因为“应用程序”实际上是作为自己的进程来设计和运行的,而不是在单个父进程中组合

AggregateCatalog catalog = new AggregateCatalog();
catalog.Catalogs.Add(new DirectoryCatalog(
        "C:\\Application Development\\Tool Center\\Tool Extensions"));
catalog.Catalogs.Add(new DirectoryCatalog(
        "C:\\Application Development\\Tool Center\\Tool Extensions", "*.exe"));