【问题标题】:Use WPF application to run multiple various applications using MEF使用 WPF 应用程序使用 MEF 运行多个不同的应用程序
【发布时间】:2011-02-01 18:01:06
【问题描述】:

我正在尝试创建一个 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
        }
    }

}

界面如下

public interface ITool
{
    String ToolName { get; }
    void OpenTool();
}

我创建了多个继承自 ITool 的类,并且导出工作正常。一个例子在这里。

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

    public void OpenTool()
    {
        //open the tool
    }
}

现在我想导入一个继承 ITool 接口的整个 WPF 应用程序。这里的想法是外部用户可以创建自己的 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
    }
}

当我这样做时,_tools 不包含我的新 WPF 应用程序,但包含 Class1。任何想法我做错了什么?有更好的方法吗?任何帮助将不胜感激。

【问题讨论】:

    标签: c# wpf mef


    【解决方案1】:

    默认情况下,DirectoryCatalog's constructor 仅搜索目录内*.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")); 
    

    话虽如此,我建议不要这样做。我建议不要让您的用户导出应用程序,而是让他们导出实现IToolUserControl。这将以更符合预期的方式表现,因为“应用程序”实际上是设计并期望作为其自己的进程运行,而不是在单个父进程中组合。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2023-03-22
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-09-29
      • 1970-01-01
      • 2020-12-13
      相关资源
      最近更新 更多