Hosting a Windows Form Control in WPF

On top of this core functionality of the HwndHost class, deriving classes handle details germane to their specific framework. As of this writing, WPF exposes only one such specialization: the WindowsFormsHost class from the System.Windows.Forms.Integration namespace and the WindowsFormsIntegration assembly. The WindowsFormsHost class has properties for background, font, and tab index properties to provide integration at those points with WPF. Example B-1 shows how to declaratively add a WindowsFormsHost element to a Window.

Example B-1. Adding an HWND host to a WPF tree

<!-- Window1.xaml -->
<Window ...>
  <Grid>
    <WindowsFormsHost />
  </Grid>
</Window>

Example B-1 creates an instance of the WindowsFormsHost control, which introduces an HWND into WPF's tree, as shown in Figure B-3.

Adding an HWND to a WPF application using the WindowsFormsHost

Figure B-3. Adding an HWND to a WPF application using the WindowsFormsHost

With an HWND injected into the WPF tree, we can now host a control from the HWND-based UI framework with which WPF integrates best: Windows Forms. For example, after adding a reference to the System.Windows.Forms assembly to the project, we can host a DataGridView control, as shown in Example B-2.

Example B-2. Hosting a Windows Forms DataGridView in WPF

<!-- Window1.xaml -->
<Window ...
  xmlns:wf="clr-namespace:System.Windows.Forms;assembly=System.Windows.Forms">
  <Grid>
    <WindowsFormsHost>
 <wf:DataGridView ...

Get Programming WPF, 2nd Edition now with the O’Reilly learning platform.

O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.