Procedura dettagliata: mapping delle proprietà tramite il controllo ElementHost
Questa procedura dettagliata illustra come usare la proprietà per eseguire il PropertyMap mapping delle proprietà Windows Form alle proprietà corrispondenti in un elemento WPF ospitato.
Le attività illustrate nella procedura dettagliata sono le seguenti:
Creazione del progetto.
Definizione di un nuovo mapping delle proprietà.
Definizione di un mapping delle proprietà predefinito.
Estensione di un mapping delle proprietà predefinito.
Al termine, sarà possibile eseguire il mapping delle proprietà Windows Form alle proprietà WPF corrispondenti in un elemento ospitato.
Prerequisiti
Per completare questa procedura dettagliata, è necessario disporre dei componenti seguenti:
- Visual Studio 2017
Creazione del progetto
Per creare il progetto
Creare un progetto app Windows Form denominato
PropertyMappingWithElementHost
.In Esplora soluzioni aggiungere riferimenti agli assembly WPF seguenti.
PresentationCore
PresentationFramework
WindowsBase
WindowsFormsIntegration
Copiare il codice seguente nella parte superiore del file di
Form1
codice.using System.Windows; using System.Windows.Media; using System.Windows.Media.Imaging; using System.Windows.Forms.Integration;
Imports System.Windows Imports System.Windows.Media Imports System.Windows.Media.Imaging Imports System.Windows.Forms.Integration
Aprire
Form1
in Progettazione Windows Form. Fare doppio clic sul modulo per aggiungere un gestore eventi per l'evento Load .Tornare alla finestra di progettazione Windows Form e aggiungere un gestore eventi per l'evento del Resize modulo. Per altre informazioni, vedere Procedura: Creare gestori eventi tramite la finestra di progettazione.
Dichiarare un ElementHost campo nella
Form1
classe .ElementHost elemHost = null;
Private elemHost As ElementHost = Nothing
Definizione di nuovi mapping di proprietà
Il ElementHost controllo fornisce diversi mapping di proprietà predefiniti. Per aggiungere un nuovo mapping di proprietà, chiamare il Add metodo sul ElementHost controllo PropertyMap.
Per definire nuovi mapping di proprietà
Copiare il codice seguente nella definizione della
Form1
classe .// The AddMarginMapping method adds a new property mapping // for the Margin property. private void AddMarginMapping() { elemHost.PropertyMap.Add( "Margin", new PropertyTranslator(OnMarginChange)); } // The OnMarginChange method implements the mapping // from the Windows Forms Margin property to the // Windows Presentation Foundation Margin property. // // The provided Padding value is used to construct // a Thickness value for the hosted element's Margin // property. private void OnMarginChange(object h, String propertyName, object value) { ElementHost host = h as ElementHost; Padding p = (Padding)value; System.Windows.Controls.Button wpfButton = host.Child as System.Windows.Controls.Button; Thickness t = new Thickness(p.Left, p.Top, p.Right, p.Bottom ); wpfButton.Margin = t; }
' The AddMarginMapping method adds a new property mapping ' for the Margin property. Private Sub AddMarginMapping() elemHost.PropertyMap.Add( _ "Margin", _ New PropertyTranslator(AddressOf OnMarginChange)) End Sub ' The OnMarginChange method implements the mapping ' from the Windows Forms Margin property to the ' Windows Presentation Foundation Margin property. ' ' The provided Padding value is used to construct ' a Thickness value for the hosted element's Margin ' property. Private Sub OnMarginChange( _ ByVal h As Object, _ ByVal propertyName As String, _ ByVal value As Object) Dim host As ElementHost = h Dim p As Padding = CType(value, Padding) Dim wpfButton As System.Windows.Controls.Button = host.Child Dim t As New Thickness(p.Left, p.Top, p.Right, p.Bottom) wpfButton.Margin = t End Sub
Il
AddMarginMapping
metodo aggiunge un nuovo mapping per la Margin proprietà .Il
OnMarginChange
metodo converte la Margin proprietà nella proprietà WPF Margin .Copiare il codice seguente nella definizione della
Form1
classe .// The AddRegionMapping method assigns a custom // mapping for the Region property. private void AddRegionMapping() { elemHost.PropertyMap.Add( "Region", new PropertyTranslator(OnRegionChange)); } // The OnRegionChange method assigns an EllipseGeometry to // the hosted element's Clip property. private void OnRegionChange( object h, String propertyName, object value) { ElementHost host = h as ElementHost; System.Windows.Controls.Button wpfButton = host.Child as System.Windows.Controls.Button; wpfButton.Clip = new EllipseGeometry(new Rect( 0, 0, wpfButton.ActualWidth, wpfButton.ActualHeight)); } // The Form1_Resize method handles the form's Resize event. // It calls the OnRegionChange method explicitly to // assign a new clipping geometry to the hosted element. private void Form1_Resize(object sender, EventArgs e) { this.OnRegionChange(elemHost, "Region", null); }
' The AddRegionMapping method assigns a custom ' mapping for the Region property. Private Sub AddRegionMapping() elemHost.PropertyMap.Add( _ "Region", _ New PropertyTranslator(AddressOf OnRegionChange)) End Sub ' The OnRegionChange method assigns an EllipseGeometry to ' the hosted element's Clip property. Private Sub OnRegionChange( _ ByVal h As Object, _ ByVal propertyName As String, _ ByVal value As Object) Dim host As ElementHost = h Dim wpfButton As System.Windows.Controls.Button = host.Child wpfButton.Clip = New EllipseGeometry(New Rect( _ 0, _ 0, _ wpfButton.ActualWidth, _ wpfButton.ActualHeight)) End Sub ' The Form1_Resize method handles the form's Resize event. ' It calls the OnRegionChange method explicitly to ' assign a new clipping geometry to the hosted element. Private Sub Form1_Resize( _ ByVal sender As Object, _ ByVal e As EventArgs) Handles MyBase.Resize If elemHost IsNot Nothing Then Me.OnRegionChange(elemHost, "Region", Nothing) End If End Sub
Il
AddRegionMapping
metodo aggiunge un nuovo mapping per la Region proprietà .Il
OnRegionChange
metodo converte la Region proprietà nella proprietà WPF Clip .Il
Form1_Resize
metodo gestisce l'evento del modulo e ridimensiona l'area di Resize ritaglio in base all'elemento ospitato.
Rimozione di un mapping delle proprietà predefinito
Rimuovere un mapping di proprietà predefinito chiamando il Remove metodo sul ElementHost controllo PropertyMap.
Per rimuovere un mapping delle proprietà predefinito
Copiare il codice seguente nella definizione della
Form1
classe .// The RemoveCursorMapping method deletes the default // mapping for the Cursor property. private void RemoveCursorMapping() { elemHost.PropertyMap.Remove("Cursor"); }
' The RemoveCursorMapping method deletes the default ' mapping for the Cursor property. Private Sub RemoveCursorMapping() elemHost.PropertyMap.Remove("Cursor") End Sub
Il
RemoveCursorMapping
metodo elimina il mapping predefinito per la Cursor proprietà .
Estensione di un mapping delle proprietà predefinito
È possibile usare un mapping delle proprietà predefinito ed estenderlo con un mapping personalizzato.
Per estendere un mapping delle proprietà predefinito
Copiare il codice seguente nella definizione della
Form1
classe .// The ExtendBackColorMapping method adds a property // translator if a mapping already exists. private void ExtendBackColorMapping() { if (elemHost.PropertyMap["BackColor"] != null) { elemHost.PropertyMap["BackColor"] += new PropertyTranslator(OnBackColorChange); } } // The OnBackColorChange method assigns a specific image // to the hosted element's Background property. private void OnBackColorChange(object h, String propertyName, object value) { ElementHost host = h as ElementHost; System.Windows.Controls.Button wpfButton = host.Child as System.Windows.Controls.Button; ImageBrush b = new ImageBrush(new BitmapImage( new Uri(@"file:///C:\WINDOWS\Santa Fe Stucco.bmp"))); wpfButton.Background = b; }
' The ExtendBackColorMapping method adds a property ' translator if a mapping already exists. Private Sub ExtendBackColorMapping() If elemHost.PropertyMap("BackColor") IsNot Nothing Then elemHost.PropertyMap("BackColor") = PropertyTranslator.Combine( _ elemHost.PropertyMap("BackColor"), _ PropertyTranslator.CreateDelegate( _ GetType(PropertyTranslator), _ Me, _ "OnBackColorChange")) End If End Sub ' The OnBackColorChange method assigns a specific image ' to the hosted element's Background property. Private Sub OnBackColorChange( _ ByVal h As Object, _ ByVal propertyName As String, _ ByVal value As Object) Dim host As ElementHost = h Dim wpfButton As System.Windows.Controls.Button = host.Child Dim b As New ImageBrush(New BitmapImage( _ New Uri("file:///C:\WINDOWS\Santa Fe Stucco.bmp"))) wpfButton.Background = b End Sub
Il
ExtendBackColorMapping
metodo aggiunge un traduttore di proprietà personalizzato al mapping delle proprietà esistente BackColor .Il
OnBackColorChange
metodo assegna un'immagine specifica alla proprietà del Background controllo ospitato. IlOnBackColorChange
metodo viene chiamato dopo l'applicazione del mapping delle proprietà predefinito.
Inizializzare i mapping delle proprietà
Copiare il codice seguente nella definizione della
Form1
classe .private void Form1_Load(object sender, EventArgs e) { // Create the ElementHost control. elemHost = new ElementHost(); elemHost.Dock = DockStyle.Fill; this.Controls.Add(elemHost); // Create a Windows Presentation Foundation Button element // and assign it as the ElementHost control's child. System.Windows.Controls.Button wpfButton = new System.Windows.Controls.Button(); wpfButton.Content = "Windows Presentation Foundation Button"; elemHost.Child = wpfButton; // Map the Margin property. this.AddMarginMapping(); // Remove the mapping for the Cursor property. this.RemoveCursorMapping(); // Add a mapping for the Region property. this.AddRegionMapping(); // Add another mapping for the BackColor property. this.ExtendBackColorMapping(); // Cause the OnMarginChange delegate to be called. elemHost.Margin = new Padding(23, 23, 23, 23); // Cause the OnRegionChange delegate to be called. elemHost.Region = new Region(); // Cause the OnBackColorChange delegate to be called. elemHost.BackColor = System.Drawing.Color.AliceBlue; }
Private Sub Form1_Load( _ ByVal sender As Object, _ ByVal e As EventArgs) Handles MyBase.Load ' Create the ElementHost control. elemHost = New ElementHost() elemHost.Dock = DockStyle.Fill Me.Controls.Add(elemHost) ' Create a Windows Presentation Foundation Button element ' and assign it as the ElementHost control's child. Dim wpfButton As New System.Windows.Controls.Button() wpfButton.Content = "Windows Presentation Foundation Button" elemHost.Child = wpfButton ' Map the Margin property. Me.AddMarginMapping() ' Remove the mapping for the Cursor property. Me.RemoveCursorMapping() ' Add a mapping for the Region property. Me.AddRegionMapping() ' Add another mapping for the BackColor property. Me.ExtendBackColorMapping() ' Cause the OnMarginChange delegate to be called. elemHost.Margin = New Padding(23, 23, 23, 23) ' Cause the OnRegionChange delegate to be called. elemHost.Region = New [Region]() ' Cause the OnBackColorChange delegate to be called. elemHost.BackColor = System.Drawing.Color.AliceBlue End Sub
Il
Form1_Load
metodo gestisce l'evento ed esegue l'inizializzazione Load seguente.Crea un elemento WPF Button .
Chiama i metodi definiti in precedenza nella procedura dettagliata per impostare i mapping delle proprietà.
Assegna i valori iniziali alle proprietà mappate.
Premere F5 per compilare ed eseguire l'applicazione.
Vedi anche
.NET Desktop feedback