Walkthrough: Hosting an ActiveX Control in WPF
To enable improved interaction with browsers, you can use Microsoft ActiveX controls in your WPF-based application. This walkthrough demonstrates how you can host the Microsoft Windows Media Player as a control on a WPF page.
Tasks illustrated in this walkthrough include:
Creating the project.
Creating the ActiveX control.
Hosting the ActiveX control on a WPF Page.
When you have completed this walkthrough, you will understand how to use Microsoft ActiveX controls in your WPF-based application.
You need the following components to complete this walkthrough:
Microsoft Windows Media Player installed on the computer where Visual Studio is installed.
Visual Studio 2010.
To create and set up the project
Create a WPF Application project named HostingAxInWpf.
Add a Windows Forms Control Library project to the solution, and name the project WmpAxLib.
In the WmpAxLib project, add a reference to the Windows Media Player assembly, which is named wmp.dll.
Open the Toolbox.
Right-click in the Toolbox, and then click Choose Items.
Click the COM Components tab, select the Windows Media Player control, and then click OK.
The Windows Media Player control is added to the Toolbox.
In Solution Explorer, right-click the UserControl1 file, and then click Rename.
Change the name to WmpAxControl.vb or WmpAxControl.cs, depending on the language.
If you are prompted to rename all references, click Yes.
Microsoft Visual Studio automatically generates an AxHost wrapper class for a Microsoft ActiveX control when the control is added to a design surface. The following procedure creates a managed assembly named AxInterop.WMPLib.dll.
To create the ActiveX control
Open WmpAxControl.vb or WmpAxControl.cs in the Windows Forms Designer.
From the Toolbox, add the Windows Media Player control to the design surface.
Build the WmpAxLib control library project.
To host the ActiveX control
In the HostingAxInWpf project, add a reference to the generated ActiveX interoperability assembly.
This assembly is named AxInterop.WMPLib.dll and was added to the Debug folder of the WmpAxLib project when you imported the Windows Media Player control.
Add a reference to the WindowsFormsIntegration assembly, which is named WindowsFormsIntegration.dll.
Add a reference to the Windows Forms assembly, which is named System.Windows.Forms.dll.
Open MainWindow.xaml in the WPF Designer.
In Design view or XAML view, select the Window element.
In the Properties window, click the Events tab.
Double-click the Loaded event.
Insert the following code to handle the Loaded event.
This code creates an instance of the WindowsFormsHost control and adds an instance of the AxWindowsMediaPlayer control as its child.
Private Sub Window_Loaded(ByVal sender As Object, ByVal e As RoutedEventArgs) ' Create the interop host control. Dim host As New System.Windows.Forms.Integration.WindowsFormsHost() ' Create the ActiveX control. Dim axWmp As New AxWMPLib.AxWindowsMediaPlayer() ' Assign the ActiveX control as the host control's child. host.Child = axWmp ' Add the interop host control to the Grid ' control's collection of child controls. Me.grid1.Children.Add(host) ' Play a .wav file with the ActiveX control. axWmp.URL = "C:\Windows\Media\tada.wav" End Sub
Press F5 to build and run the application.