I am working on an application that uses a plug-in architecture to expand it's functionality. What is the best way to load WPF UIs from a plug-in?
I will have a listbox listing all of the available plug-ins. When a plug-in is selected, a WPF UI defined in the plug-in should be displayed in a ContentControl
. The options I have thought of include:
- Require a
UserControl
to be created that implements a specific interface. I am thinking this would make it easy for plug-in creation. Implement an interface and you are good to go. My question with this method is how to dynamically load theUserControl
into aContentControl
. Also, since I am using the MVVM design pattern it seems that aDataTemplate
would be preferred over aUserControl
. - Allow a
DataTemplate
to be loaded from the plug-in. I believe this would require the plug-in to contain a XAML file named a certain way. My application would read theDataTemplate
into my resource dictionary like shown in this question. I have seen quite a few questions similar to this, except they usually only need to load one additional, predefined assembly to getDataTemplates
from. This problem would require any number of unknown assemblies to be searched forDataTemplates
.
If I choose the second option, I think I could select the DataTemplate
similarly to how this answer describes.
Which method do you think is better? Or do you have a better way to accomplish this?