Interaktion zwischen WPF und Windows Forms
WPF und Windows Forms bieten zwei verschiedene Architekturen zum Erstellen von Anwendungsschnittstellen. Der System.Windows.Forms.Integration-Namespace stellt Klassen bereit, die allgemeine Interoperationsszenarien unterstützen. Bei den zwei Hauptklassen, in denen die Interoperationsfunktionen implementiert sind, handelt es sich um WindowsFormsHost und ElementHost. In diesem Thema wird beschrieben, welche Interoperationsszenarien unterstützt werden und welche Szenarien nicht unterstützt werden.
Hinweis |
---|
Besondere Beachtung findet das Szenario hybrider Steuerelemente.Bei einem hybriden Steuerelement ist ein Steuerelement einer Technologie in einem Steuerelement der anderen Technologie geschachtelt.Dies wird auch als geschachtelte Interoperation bezeichnet.Ein hybrides Steuerelement mit mehreren Ebenen verfügt über mehrere Schachtelungsebenen hybrider Steuerelemente.Ein Beispiel für eine geschachtelte Interoperation mit mehreren Ebenen ist ein Windows Forms-Steuerelement, das ein WPF-Steuerelement enthält, das wiederum ein anderes Windows Forms-Steuerelement enthält.Hybride Steuerelemente mit mehreren Ebenen werden nicht unterstützt. |
Dieses Thema enthält folgende Abschnitte.
- Hosten von Windows Forms-Steuerelementen in WPF
- Hosten von WPF-Steuerelementen in Windows Forms
- Verwandte Abschnitte
Hosten von Windows Forms-Steuerelementen in WPF
Die folgenden Interoperationsszenarien werden unterstützt, wenn ein WPF-Steuerelement ein Windows Forms-Steuerelement hostet:
Das WPF-Steuerelement kann mit XAML ein oder mehrere Windows Forms-Steuerelemente hosten.
Es kann mithilfe von Code ein oder mehrere Windows Forms-Steuerelemente hosten.
Es kann Windows Forms-Containersteuerelemente hosten, die andere Windows Forms-Steuerelemente enthalten.
Es kann ein Master-/Detailformular mit einem WPF-Master und Windows Forms-Details hosten.
Es kann ein Master-/Detailformular mit einem Windows Forms-Master und WPF-Details hosten.
Es kann ein oder mehrere ActiveX-Steuerelemente hosten.
Es kann ein oder mehrere zusammengesetzte Steuerelemente hosten.
Es kann mithilfe von Extensible Application Markup Language (XAML) hybride Steuerelemente hosten.
Es kann mithilfe von Code hybride Steuerelemente hosten.
Layoutunterstützung
In der folgenden Liste werden die bekannten Beschränkungen beschrieben, die bestehen, wenn das WindowsFormsHost-Element versucht, das zugehörige gehostete Windows Forms-Steuerelement in das WPF-Layoutsystem zu integrieren.
In einigen Fällen kann die Größe von Windows Forms-Steuerelementen nicht angepasst oder nur auf bestimmte Abmessungen festgelegt werden. Ein Windows Forms ComboBox-Steuerelement unterstützt beispielsweise nur eine einzige Höhe, die durch den Schriftgrad des Steuerelements definiert wird. In einem dynamischen WPF-Layout, bei dem davon ausgegangen wird, dass Elemente vertikal gestreckt werden können, wird ein gehostetes ComboBox-Steuerelement nicht wie erwartet gestreckt.
Windows Forms-Steuerelemente können nicht gedreht oder verzerrt werden. Wenn Sie z. B. die Benutzeroberfläche um 90 Grad drehen, behalten gehostete Windows Forms-Steuerelemente ihre aufrechte Position.
In den meisten Fällen unterstützen Windows Forms-Steuerelemente keine proportionale Skalierung. Obwohl sich die Gesamtabmessungen des Steuerelements skalieren lassen, wird die Größe von untergeordneten Steuerelementen und Komponentenelementen des Steuerelements möglicherweise nicht wie erwartet angepasst. Diese Einschränkung hängt davon ab, in welchem Maße jedes Windows Forms-Steuerelement die Skalierung unterstützt.
In einer WPF-Benutzeroberfläche können Sie die z-Reihenfolge von Elementen zur Steuerung des Verhaltens beim Überlappen ändern. Ein gehostetes Windows Forms-Steuerelement wird in einem separaten HWND gezeichnet, d. h., es wird immer über WPF-Elementen gezeichnet.
Windows Forms-Steuerelemente unterstützen die automatische Skalierung auf der Grundlage des Schriftgrads. Wenn Sie in einer WPF-Benutzeroberfläche den Schriftgrad ändern, wird nicht das gesamte Layout angepasst. Möglicherweise werden jedoch einzelne Elemente dynamisch angepasst.
Ambient-Eigenschaften
Einige der Ambient-Eigenschaften von WPF-Steuerelementen verfügen über Windows Forms-Entsprechungen. Diese Ambient-Eigenschaften werden an die gehosteten Windows Forms-Steuerelemente weitergegeben und als öffentliche Eigenschaften für das WindowsFormsHost-Steuerelement verfügbar gemacht. Das WindowsFormsHost-Steuerelement übersetzt jede Ambient-Eigenschaft von WPF in die zugehörige Windows Forms-Entsprechung.
Weitere Informationen finden Sie unter Eigenschaftenzuordnung von Windows Forms und WPF.
Verhalten
In der folgenden Tabelle wird das Verhalten bei der Interoperation beschrieben.
Verhalten |
Unterstützt |
Nicht unterstützt |
---|---|---|
Transparenz |
Beim Rendern von Windows Forms-Steuerelementen wird Transparenz unterstützt. Der Hintergrund des übergeordneten WPF-Steuerelements kann zum Hintergrund gehosteter Windows Forms-Steuerelemente werden. |
Einige Windows Forms-Steuerelemente unterstützen Transparenz nicht. Das TextBox-Steuerelement und das ComboBox-Steuerelement sind zum Beispiel nicht transparent, wenn sie von WPF gehostet werden. |
Vorrücken zum nächsten Tabstopp |
Die Aktivierungsreihenfolge für gehostete Windows Forms-Steuerelemente ist identisch mit der Aktivierungsreihenfolge, die gilt, wenn diese Steuerelemente in einer Windows Forms-basierten Anwendung gehostet werden. Das Vorrücken zum nächsten Tabstopp von einem WPF-Steuerelement zu einem Windows Forms-Steuerelement mit der TAB-TASTE und den Tasten UMSCHALT+TAB funktioniert wie üblich. Windows Forms-Steuerelemente mit dem TabStop-Eigenschaftswert false erhalten nicht den Fokus, wenn der Benutzer in den Steuerelementen zum nächsten Tabstopp vorrückt.
|
Nicht zutreffend. |
Navigation mit Pfeiltasten |
|
Nicht zutreffend. |
Zugriffstasten |
Die Zugriffstasten funktionieren abgesehen von den in der Spalte "Nicht unterstützt" angegebenen Ausnahmen wie üblich. |
Technologieübergreifende doppelte Zugriffstasten funktionieren nicht wie gewöhnliche doppelte Zugriffstasten. Wenn eine Zugriffstaste technologieübergreifend dupliziert wird und dabei mindestens eine Zugriffstaste für ein Windows Forms-Steuerelement und eine andere für ein WPF-Steuerelement vorhanden ist, wird die Zugriffstaste stets dem Windows Forms-Steuerelement zugewiesen. Beim Drücken der doppelten Zugriffstaste schaltet der Fokus nicht zwischen den Steuerelementen um. |
Tastenkombination |
Die Tastenkombinationen funktionieren abgesehen von den in der Spalte "Nicht unterstützt" angegebenen Ausnahmen wie üblich. |
|
AcceptsReturn, AcceptsTab und anderes steuerelementspezifisches Verhalten |
Eigenschaften, die das standardmäßige Tastaturverhalten ändern, funktionieren wie üblich, wobei davon ausgegangen wird, dass das Windows Forms-Steuerelement die IsInputKey-Methode überschreibt, sodass true zurückgegeben wird. |
Windows Forms-Steuerelemente, die das standardmäßige Tastaturverhalten durch Behandeln des KeyDown-Ereignisses ändern, werden im WPF-Hoststeuerelement zuletzt verarbeitet. Da diese Steuerelemente zuletzt verarbeitet werden, können sie zu unerwartetem Verhalten führen. |
Enter-Ereignis und Leave-Ereignis |
Wird der Fokus nicht auf das aufnehmende ElementHost-Steuerelement verschoben, werden das Enter-Ereignis und das Leave-Ereignis wie üblich ausgelöst, wenn sich der Fokus in einem einzelnen WindowsFormsHost-Steuerelement ändert. |
Bei folgenden Fokusänderungen werden das Enter-Ereignis und das Leave-Ereignis nicht ausgelöst:
|
Multithreading |
Alle Arten von Multithreading werden unterstützt. |
Sowohl bei der Windows Forms-Technologie als auch bei der WPF-Technologie wird von einem Singlethread-Parallelitätsmodell ausgegangen. Während des Debuggens lösen von anderen Threads stammende Aufrufe von Frameworkobjekten zur Durchsetzung dieser Anforderung eine Ausnahme aus. |
Sicherheit |
Alle Interoperationsszenarien setzen volle Vertrauenswürdigkeit voraus. |
Bei teilweiser Vertrauenswürdigkeit sind keine Interoperationsszenarien zulässig. |
Barrierefreiheit |
Alle Barrierefreiheitsszenarien werden unterstützt. Hilfstechnologieprodukte funktionieren korrekt, wenn sie für Hybridanwendungen verwendet werden, die sowohl Windows Forms-Steuerelemente als auch WPF-Steuerelemente enthalten. |
Nicht zutreffend. |
Zwischenablage |
Alle Zwischenablageoperationen funktionieren wie üblich. Hierzu zählen auch das Ausschneiden und Einfügen zwischen Windows Forms-Steuerelementen und WPF-Steuerelementen. |
Nicht zutreffend. |
Drag & Drop-Feature |
Alle Drag & Drop-Operationen funktionieren wie üblich. Hierzu zählen auch Vorgänge zwischen Windows Forms- und WPF-Steuerelementen. |
Nicht zutreffend. |
Hosten von WPF-Steuerelementen in Windows Forms
Die folgenden Interoperationsszenarien werden unterstützt, wenn ein Windows Forms-Steuerelement ein WPF-Steuerelement hostet:
Hosten eines oder mehrerer WPF-Steuerelemente mit Code.
Zuordnen eines Eigenschaftenblatts zu einem oder mehreren gehosteten WPF-Steuerelementen.
Hosten einer oder mehrerer WPF-Seiten in einem Formular.
Starten eines WPF-Fensters.
Hosten eines Master-/Detailformulars mit einem Windows Forms-Master und WPF-Details.
Hosten eines Master-/Detailformulars mit einem WPF-Master und Windows Forms-Details.
Hosten von benutzerdefinierten WPF-Steuerelementen.
Hosten von hybriden Steuerelementen.
Ambient-Eigenschaften
Einige der Ambient-Eigenschaften von Windows Forms-Steuerelementen verfügen über WPF-Entsprechungen. Diese Ambient-Eigenschaften werden an die gehosteten WPF-Steuerelemente weitergegeben und als öffentliche Eigenschaften für das ElementHost-Steuerelement verfügbar gemacht. Das ElementHost-Steuerelement übersetzt jede Ambient-Eigenschaft von Windows Forms in die zugehörige WPF-Entsprechung.
Weitere Informationen finden Sie unter Eigenschaftenzuordnung von Windows Forms und WPF.
Verhalten
In der folgenden Tabelle wird das Verhalten bei der Interoperation beschrieben.
Verhalten |
Unterstützt |
Nicht unterstützt |
---|---|---|
Transparenz |
Beim Rendern von WPF-Steuerelementen wird Transparenz unterstützt. Der Hintergrund des übergeordneten Windows Forms-Steuerelements kann zum Hintergrund gehosteter WPF-Steuerelemente werden. |
Nicht zutreffend. |
Multithreading |
Alle Arten von Multithreading werden unterstützt. |
Sowohl bei der Windows Forms-Technologie als auch bei der WPF-Technologie wird von einem Singlethread-Parallelitätsmodell ausgegangen. Während des Debuggens lösen von anderen Threads stammende Aufrufe von Frameworkobjekten zur Durchsetzung dieser Anforderung eine Ausnahme aus. |
Sicherheit |
Alle Interoperationsszenarien setzen volle Vertrauenswürdigkeit voraus. |
Bei teilweiser Vertrauenswürdigkeit sind keine Interoperationsszenarien zulässig. |
Barrierefreiheit |
Alle Barrierefreiheitsszenarien werden unterstützt. Hilfstechnologieprodukte funktionieren korrekt, wenn sie für Hybridanwendungen verwendet werden, die sowohl Windows Forms-Steuerelemente als auch WPF-Steuerelemente enthalten. |
Nicht zutreffend. |
Zwischenablage |
Alle Zwischenablageoperationen funktionieren wie üblich. Hierzu zählen auch das Ausschneiden und Einfügen zwischen Windows Forms-Steuerelementen und WPF-Steuerelementen. |
Nicht zutreffend. |
Drag & Drop-Feature |
Alle Drag & Drop-Operationen funktionieren wie üblich. Hierzu zählen auch Vorgänge zwischen Windows Forms-Steuerelementen und WPF-Steuerelementen. |
Nicht zutreffend. |
Siehe auch
Aufgaben
Exemplarische Vorgehensweise: Hosten eines Windows Forms-Steuerelements in WPF
Referenz
Konzepte
Exemplarische Vorgehensweise: Hosten eines zusammengesetzten Windows Forms-Steuerelements in WPF
Exemplarische Vorgehensweise: Hosten eines zusammengesetzten WPF-Steuerelements in Windows Forms