Theming

Visual Studio Extensibility Cookbook

Whenever you are building any custom UI using WPF, you need to make sure it matches the theming of Visual Studio. That way your UI will look native and feel more like a natural part of Visual Studio. If not, your tool windows and dialogs might end up looking like this in the Light theme:

Un-themed UI in the Light theme

Notice how the padding around text boxes and buttons doesn’t look right? It gets even worse in the Dark theme:

Un-themed UI in the Dark theme

Now the text and the background colors make it almost impossible to read. Not good.

There’s an easy way to make sure that our UI’s background colors, button styling, etc. matches that of Visual Studio’s with a simple little trick. That way the same UI can look like this in the Light theme:

Correctly themed UI in the Light theme

Or in the Dark theme:

Correctly themed UI in the Dark theme

That looks much better. Let’s look at how we can theme our UI.

WPF UserControl

Here’s an example of a WPF <UserControl> that can be used directly inside a tool window.

<UserControl x:Class="TestExtension.RunnerWindowControl"
             xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
             xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
             xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
             xmlns:toolkit="clr-namespace:Community.VisualStudio.Toolkit;assembly=Community.VisualStudio.Toolkit"
             toolkit:Themes.UseVsTheme="True">

Notice the xmlns:toolkit imported namespace and the toolkit:Themes.UseVsTheme="True" attribute. They will automatically apply the official styling for WPF controls that Visual Studio uses itself. We don’t have to do anything else to get the styling applied to the entire <UserControl>. Easy!

An added benefit is that when the user changes the color theme from e.g. Light to Dark, then our UI will switch immediately as well without the need to reload.

DialogWindow control

Visual Studio ships with a control we can use for custom windows, which is the DialogWindow control. It is recommended you use that for any dialog windows, but it can also be used inside tool windows.

It’s very similar to other XAML window types.

<platform:DialogWindow 
    x:Class="TestExtension.ThemeWindowDialog"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:platform="clr-namespace:Microsoft.VisualStudio.PlatformUI;assembly=Microsoft.VisualStudio.Shell.15.0"
    xmlns:toolkit="clr-namespace:Community.VisualStudio.Toolkit;assembly=Community.VisualStudio.Toolkit"
    toolkit:Themes.UseVsTheme="True">

Notice the imported namespaces for both the toolkit and the platform and the attribute toolkit:Themes.UseVsTheme="True".

That’s all there is to it. Your dialog window is now themed using Visual Studio colors and styling.

Get the source code

You can find the source code for this extension in the Community Toolkit test project.

Additional resources

Learn more about Visual Studio colors from these resources.

Last updated: