5 | I am using Prism 4 with MEF Extensions and the MVVM pattern. During initialization in a module I call RegisterViewWithRegion(RegionNames.MyRegion, typeof(MyView)) which works perfectly when the view is constructed like this: [Export][PartCreationPolicy(CreationPolicy.NonShared)]public partial class MyView : UserControl{ public MyView() { .... The view gets registered and everything is fine. As soon as I change the Export to a Custom Export Attribute the view can't be found anymore, although it is still in the container. This Custom Export Attribute is taken from the Stock Trader RI: [AttributeUsage(AttributeTargets.Class, AllowMultiple = false)][MetadataAttribute]public class ViewExportAttribute : ExportAttribute, IViewRegionRegistration{ public ViewExportAttribute() : base(typeof(object)) { } public ViewExportAttribute(string viewName) : base(viewName, typeof(object)) { ViewName = viewName; } public string RegionName { get; set; } public string ViewName { get; set; }} and the interface is public interface IViewRegionRegistration{ string RegionName { get; } string ViewName { get; }} By changing the Export Attribute to [ViewExport(ViewName = "MyView", RegionName = RegionNames.MyRegion)][PartCreationPolicy(CreationPolicy.NonShared)]public partial class MyView : UserControl{ public MyView() { .... when calling RegisterViewWithRegion it throws an error: Activation error occured while trying to get instance of type MyView, key "" Any advice? I was looking at this part of code the whole day without finding a solution. | ||||
|
4 Answers
4 | Another day, another way... I will try to answer my question even though I have only limited knowledge about PRISM. In other words: I'm still learning. The Custom Export Attribute taken from the Stock Trade RI is used by the MyView view;var myList = container.GetExports But I think when using ViewInjection and Prism Navigation it is better to just use the default [Export] attribute, then everything works smoothly. | ||
|
3 | Are you configuring the aggregate catalog in your MEF bootstrapper? If so, are you adding the assembly that contains your ViewExportAttribute and AutoPopulateExportedViewsBehavior classes? I believe this happens in the StockTraderRI's bootstrapper with this line: this.AggregateCatalog.Catalogs.Add(new AssemblyCatalog(typeof(StockTraderRICommands).Assembly)); The StockTraderRICommands class is in the same assembly as the ViewExportAttribute and AutoPopulateExportedViewsBehavior classes. | ||||
|
0 | The custom export attribute passes As far as the activation error you'll need to look at the exception in more detail. The root cause is probably there somewhere, perhaps buried under an InnerException. | ||
|
0 | I encountered exactly the same problem and it was a hard one for a MEF/PRISM beginner. okieh describes the problem very well, I just want to post an alternative solution, coming from theStocktraderUI sample application: The solution works (/seems to work) if you want View discovery without any form of config file, etc. where you have to register your views. 1. Modify the [Export][AttributeUsage(AttributeTargets.Class, AllowMultiple = false)][MetadataAttribute]public sealed class ViewExportAttribute : ExportAttribute, IViewRegionRegistration{ public ViewExportAttribute() : base(typeof(UserControl)) { } public string ViewName { get { return base.ContractName; } } public string RegionName { get; set; }} The [Export] attribute is added and the base constructor is now called with 2. Modify [ImportMany(typeof(UserControl))]public Lazy The That's basically it. You can use the This way, you don't need additional interfaces for your views and can still discover everything without hardcoded registration. I hope it helps and let me know, if I missed any drawbacks of my solution.
|