Compartir a través de


Tutorial: Hospedar un control ActiveX en WPF

Para habilitar la interacción mejorada con los exploradores, puede usar los controles ActiveX de Microsoft en la aplicación basada en WPF. En este tutorial se muestra cómo puede hospedar el Reproductor de Windows Media de Microsoft como control en una página de WPF.

Las tareas ilustradas en este tutorial incluyen:

  • Crear el proyecto.

  • Crear el control ActiveX.

  • Hospedar el control ActiveX en una página de WPF.

Cuando haya completado este tutorial, comprenderá cómo usar los controles ActiveX de Microsoft en la aplicación basada en WPF.

Requisitos previos

Necesitará los componentes siguientes para completar este tutorial:

  • Reproductor de Windows Media de Microsoft instalado en el equipo donde está instalado Visual Studio.

  • Visual Studio 2010.

Crear el proyecto

Para crear y configurar el proyecto

  1. Cree un proyecto de aplicación WPF denominado HostingAxInWpf.

  2. Agregue un proyecto de biblioteca de controles de Windows Forms a la solución y asigne al proyecto el nombre WmpAxLib.

  3. En el proyecto WmpAxLib, agregue una referencia al ensamblado Reproductor de Windows Media, que se denomina wmp.dll.

  4. Abra el Cuadro de herramientas.

  5. Haga clic con el botón secundario en el Cuadro de herramientas y, a continuación, haga clic en Elegir elementos.

  6. Haga clic en la pestaña Componentes COM, seleccione el control Reproductor de Windows Media y, a continuación, haga clic en Aceptar.

    El control Reproductor de Windows Media se agrega al Cuadro de herramientas.

  7. En el Explorador de soluciones, haga clic con el botón derecho en el archivo UserControl1 y haga clic en Cambiar nombre.

  8. Cambie el nombre a WmpAxControl.vb o WmpAxControl.cs, según el idioma.

  9. Si se le pide que cambie el nombre de todas las referencias, haga clic en .

Creación del control ActiveX

Visual Studio genera automáticamente una clase contenedora AxHost para un control ActiveX de Microsoft cuando el control se agrega a una superficie de diseño. El procedimiento siguiente crea un ensamblado administrado denominado AxInterop.WMPLib.dll.

Para crear el control ActiveX

  1. Abra WmpAxControl.vb o WmpAxControl.cs en el Diseñador de Windows Forms.

  2. En el Cuadro de herramientas, agregue el control Reproductor de Windows Media a la superficie de diseño.

  3. En el ventana Propiedades, establezca el valor de la propiedad Dock del control Reproductor de Windows Media en Fill.

  4. Compile el proyecto de biblioteca de controles WmpAxLib.

Hospedamiento del control ActiveX en una página de WPF

Para hospedar el control ActiveX

  1. En el proyecto HostingAxInWpf, agregue una referencia al ensamblado de interoperabilidad ActiveX que se ha generado.

    Este ensamblado se denomina AxInterop.WMPLib.dll y se agregó a la carpeta Depuración del proyecto WmpAxLib al importar el control Reproductor de Windows Media.

  2. Agregue una referencia al ensamblado WindowsFormsIntegration, denominado WindowsFormsIntegration.dll.

  3. Agregue una referencia al ensamblado de Windows Forms, que se denomina System.Windows.Forms.dll.

  4. Abra MainWindow.xaml en WPF Designer.

  5. Asígnele al elemento Grid el nombre grid1.

    <Grid Name="grid1">
        
    </Grid>
    
  6. En la vista de diseño o en la vista XAML, seleccione el elemento Window.

  7. En la ventana Propiedades, haga clic en la pestaña Eventos.

  8. Haga doble clic en el evento Loaded.

  9. Inserte el código siguiente para controlar el evento Loaded.

    Este código crea una instancia del control WindowsFormsHost y agrega una instancia del control AxWindowsMediaPlayer como su elemento secundario.

    private void Window_Loaded(object sender, RoutedEventArgs e)
    {
        // Create the interop host control.
        System.Windows.Forms.Integration.WindowsFormsHost host =
            new System.Windows.Forms.Integration.WindowsFormsHost();
    
        // Create the ActiveX control.
        WmpAxLib.AxWindowsMediaPlayer axWmp = new WmpAxLib.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.
        this.grid1.Children.Add(host);
    
        // Play a .wav file with the ActiveX control.
        axWmp.URL = @"C:\Windows\Media\tada.wav";
    }
    
    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
    
  10. Presione F5 para compilar y ejecutar la aplicación.

Vea también