Once you get the resources for more than one control in generic.xaml, things can get a bit messy.
What one really wants: split up your resources into separate dictionaries for each control.
I do this as part of the latest bag-o-tricks.
I should get Lauren or Ashish to fill in the details about the "source" semantics, since they are shared for all resources (images, fonts, etc) in WPF.
Open up the bag-o-tricks in VS (or the file system) and let's dig in.
First, you'll notice I've already split out the ColorPicker and DateControls into separate xaml files.
Let's do the Unload and Edit trick I showed yesterday.
You'll notice that these files, just like the other theme files (and all of the other XAML files in the solution) are defined as <Page/>. What does this mean?
Let's open our trusty Reflector to take a look.
If we build the project and drag-drop WPFSamplesLib.dll into Reflector, we can drill into the Resources. You'll notice that we have an entry for each XAML file in our project. Except instead of .xaml, we see .baml as a file extension. You'll also notice that the name for each entry in the resources maps to the full path for the xaml file we had in the project (the themes directory is included).
Rob goes into this a little bit on Channel9.
Going back to the project, let's reload the project and take a look at generic.xaml.
You'll notice this funky syntax for the Source of the ResourceDictionary. If we break it into chucks, it makes sense.
This trick also works from code, in fact, using our trusty Reflector we can see this syntax for resources is the same syntax used by the compiler in initialize components for our application. (We're looking at WPFSamplesApp.exe, this time.)
Make sense?
This post is brought to you by our friends at Paint .NET and Reflector. Paint .NET and Reflector are the first two apps I install on a clean machine. Both available freely. Both examples of .NET 2.0 WinForms hotness. (I'm being patient for the WPF versions of each.)
Have a good weekend, friends.