War diese Seite hilfreich?
Ihr Feedback ist uns wichtig. Teilen Sie uns Ihre Meinung mit.
Weiteres Feedback?
1500 verbleibende Zeichen
Exportieren (0) Drucken
Alle erweitern
Dieser Artikel wurde maschinell übersetzt. Bewegen Sie den Mauszeiger über die Sätze im Artikel, um den Originaltext anzuzeigen. Weitere Informationen
Übersetzung
Original

Neues in WPF Version 4.5

WPF 4.5 wird mit einem Ribbon - Steuerelement ausgeliefert, welches eine Schnellstartleiste, ein Applikationsmenü und Register beinhaltet. Weitere Informationen finden Sie unter Übersicht über die Multifunktionsleiste.

UI-Virtualisierung liegt vor, wenn eine Teilmenge von UI-Elementen aus einer größeren Anzahl von Datenelementen generiert wird, wobei berücksichtigt wird, welche Elemente auf dem Bildschirm angezeigt werden. Das VirtualizingPanel definiert die angefügte IsVirtualizingWhenGrouping-Eigenschaft, welche die UI-Virtualisierung für gruppierte Daten ermöglicht. Weitere Informationen zum Gruppieren von Daten finden Sie in der Anleitung zum Sortieren und Gruppieren von Daten mit Hilfe einer Ansicht in XAML. Weitere Informationen zum Virtualisieren von gruppierten Daten finden Sie in der angefügten Eigenschaft IsVirtualizingWhenGrouping.

  1. Sie können angeben, ob ein VirtualizingPanel wie z. B. das VirtualizingStackPanel abgeschnittene Elemente anzeigt; dazu dient die angefügte ScrollUnit-Eigenschaft. Wenn ScrollUnit auf Item festgelegt ist, zeigt das VirtualizingPanel nur Elemente an, die vollständig sichtbar sind. Wenn ScrollUnit auf Pixel festgelegt ist, kann das VirtualizingPanel teilweise sichtbare Elemente anzeigen.

  2. Sie können die Größe des Cache vor und nach dem Viewport während der Virtualisierung durch das VirtualizingPanel angeben; dazu dient die angefügte CacheLength-Eigenschaft. Der Cache ist der Platz über bzw. unter dem Viewport, in dem keine Elemente virtualisiert werden. Wenn Sie mit einem Cache die Erstellung von UI-Elementen unterdrücken, während sie in die Ansicht rücken, kann dadurch die Leistung verbessert werden. Der Cache hat beim Auffüllen geringere Priorität; dadurch wird vermieden, dass die Anwendung während des Vorgangs nicht mehr reagiert. Die VirtualizingPanel.CacheLengthUnit-Eigenschaft legt die von VirtualizingPanel.CacheLength verwendete Maßeinheit fest.

Sie können statische Eigenschaften als Quelle einer Datenbindung verwenden. Das Datenbindungsmodul erkennt, wenn sich der Eigenschaftswert durch ein ausgelöstes statisches Ereignis ändert. Wenn beispielsweise die SomeClass-Klasse eine statische Eigenschaft namens MyProperty definiert, kann SomeClass ein statisches Ereignis definieren, das ausgelöst wird, wenn sich der Wert von MyProperty ändert. Das statische Ereignis kann eine der folgenden Signaturen verwenden.

  • public static event EventHandler MyPropertyChanged;

  • public static event EventHandler<PropertyChangedEventArgs> StaticPropertyChanged;

Note that in the first case, the class exposes a static event named PropertyNameChanged that passes EventArgs to the event handler. Im zweiten Fall macht die Klasse ein statisches Ereignis namens StaticPropertyChanged verfügbar, das den PropertyChangedEventArgs-Ereignishandler übergibt. Eine Klasse, die die statische Eigenschaft implementiert, kann Benachrichtigungen über Eigenschaftsänderungen nach Wahl mit einer der beiden Methode auslösen.

Mit der WPF können Sie auf Datenkollektionen in anderen Threads als dem, der die Auflistung erstellt hat, zugreifen und diese ändern. Dadurch können Sie mit einem Hintergrundthread Daten aus einer externen Quelle, z. B. aus einer Datenbank, empfangen und die Daten im UI-Thread anzeigen. Wenn Sie die Auflistung mit einem anderen Thread modifizieren, reagiert die Benutzeroberfläche weiterhin auf die Benutzerinteraktion.

Die INotifyDataErrorInfo-Schnittstelle ermöglicht es Datenentitätsklassen, benutzerdefinierte Validierungsregeln zu implementieren und Validierungsergebnisse asynchron verfügbar zu machen. Diese Schnittstelle unterstützt auch benutzerdefinierte Fehlerobjekte, mehrere Fehler pro Eigenschaft, eigenschaftenübergreifende Fehler und Fehler auf Entitätsebene. Weitere Informationen finden Sie unter INotifyDataErrorInfo.

Wenn Sie eine Datenquelle mit einer Datenbindung aktualisieren, können Sie mit der Eigenschaft Delay angeben, wie viel Zeit nach der Änderung der Eigenschaft am Ziel vergehen soll, bevor die Quelle aktualisiert wird. Angenommen, Sie haben ein Slider, das seine Value-Eigenschaftendaten in beide Richtungen an eine Eigenschaft eines Datenobjekts gebunden hat, und die UpdateSourceTrigger-Eigenschaft ist auf PropertyChanged festgelegt. In diesem Beispiel wird, wenn der Benutzer den Slider verschiebt, die Quelle für jedes Pixel aktualisiert, den der Slider verschoben wird. Das Quellobjekt benötigt in der Regel den Wert des Schiebereglers nur, wenn sich der Value des Schiebereglers nicht mehr ändert. Um zu verhindern, dass sich die Quelle zu oft aktualisiert, geben Sie mit Delay an, dass die Quelle nicht aktualisiert werden soll, bis nach abgeschlossener Bewegung ein bestimmter Zeitraum vergangen ist.

Die WPF unterstützt die Datenbindung an Objekte, die ICustomTypeProvider implementieren, auch als benutzerdefinierte Typen bezeichnet. Sie können benutzerdefinierte Typen in den folgenden Fällen verwenden.

  1. Als PropertyPath in einer Datenbindung. Beispielsweise kann die Path-Eigenschaft von Binding auf eine Eigenschaft eines benutzerdefinierten Typs verweisen.

  2. Als Wert der DataType-Eigenschaft.

  3. Als Typ, der die automatisch generierten Spalten in einem DataGrid festlegt.

In bestimmten Situationen benötigen Sie eventuell Informationen zu den Quell- und Zielobjekten der Bindung und rufen dafür die BindingExpression von Binding ab. Es wurden neue APIs hinzugefügt, damit Sie das Quell- oder Zielobjekt oder die zugeordnete Eigenschaft abrufen können. Wenn Sie über die BindingExpression verfügen, verwenden Sie folgende APIs, um Informationen über das Ziel und die Quelle abzurufen.

Um diesen Wert der Bindung zu suchen

Verwenden Sie dieses API

Das Zielobjekt

BindingExpressionBase.Target

Die Zieleigenschaft

BindingExpressionBase.TargetProperty

Das Quellobjekt

BindingExpression.ResolvedSource

Die Quelleigenschaft

BindingExpression.ResolvedSourcePropertyName

Ob die BindingExpression zu einer BindingGroup gehört

BindingExpressionBase.BindingGroup

Der Besitzer einer BindingGroup

Owner

Es gibt Situationen, in denen der DataContext eines Elementcontainers in einem ItemsControl getrennt wird. Ein Elementcontainer ist das Benutzeroberflächenelement, das ein Element in einem ItemsControl anzeigt. Wenn ein ItemsControl an eine Auflistung datengebunden ist, wird ein Elementcontainer für jedes Element generiert. In einigen Fällen werden Elementcontainer aus der visuellen Struktur entfernt. Zwei typische Situationen, in denen ein Elementcontainer entfernt wird, sind folgende: Wenn ein Element aus der zugrunde liegenden Auflistung entfernt wird, und wenn Virtualisierung auf ItemsControl aktiviert wird. In diesen Fällen wird die DataContext-Eigenschaft des Elementcontainers auf das Sentinelobjekt festgelegt, das von der statischen BindingOperations.DisconnectedSource-Eigenschaft zurückgegeben wird. Sie sollten überprüfen, ob DataContext gleich dem DisconnectedSource-Objekt ist, bevor Sie auf den DataContext eines Elementcontainers zugreifen.

Eine Datenauflistung kann gruppiert, gefiltert oder sortiert werden. Die WPF 4.5 ermöglicht die Neuanordnung wenn die Daten geändert werden. Angenommen, eine Anwendung listet mit DataGrid die Aktien an einer Börse auf, und die Aktien werden nach Aktienwert sortiert. Wenn die Livesortierung in der CollectionView der Aktien aktiviert ist, ändert sich die Position einer Aktie im DataGrid, wenn der Wert der Aktie über oder unter den Wert einer anderen Aktie steigt oder sinkt. Weitere Informationen finden Sie unter der ICollectionViewLiveShaping-Schnittstelle.

Die Implementierung des schwachen Ereignismusters ist jetzt einfacher, da Abonnenten der Ereignisse daran beteiligt sein können, ohne eine zusätzliche Schnittstelle implementieren zu müssen. Die generische WeakEventManager-Klasse ermöglicht es Abonnenten außerdem, am schwachen Ereignismuster teilzunehmen, wenn für ein bestimmtes Ereignis kein dedizierter WeakEventManager vorhanden ist. Weitere Informationen finden Sie unter Schwache Ereignismuster.

Die Verteilerklasse definiert neue Methoden für synchrone und asynchrone Vorgänge. Die synchrone Invoke-Methode definiert Überladungen, die einen Action- oder Func<TResult>-Parameter entgegennehmen. Die neue asynchrone Methode InvokeAsync nimmt ebenfalls Action oder Func<TResult> als Rückrufparameter entgegen und gibt DispatcherOperation oder DispatcherOperation<TResult> zurück. Die DispatcherOperation- und DispatcherOperation<TResult>-Klassen definieren eine Task-Eigenschaft. Wenn Sie InvokeAsync aufrufen, können Sie das Schlüsselwort await entweder mit DispatcherOperation oder mit dem zugehörigen Task verwenden. Wenn Sie synchron auf die Task warten müssen, die von DispatcherOperation oder DispatcherOperation<TResult> zurückgegeben wird, rufen Sie die DispatcherOperationWait-Erweiterungsmethode auf. Wenn Sie Task.Wait aufrufen, führt das zu einem Deadlock, wenn der Vorgang auf einem aufrufenden Thread in die Warteschlange gestellt wird. Weitere Informationen zur Durchführung asynchroner Operationen mit Task finden Sie unter Aufgabenparallelität (Task Parallel Library).

Die WPF 4.5 unterstützt Markuperweiterungen für Ereignisse. Die WPF definiert zwar keine Markuperweiterung zur Verwendung für Ereignisse, diese können aber von Drittanbietern erstellt werden.

Community-Beiträge

HINZUFÜGEN
Anzeigen:
© 2015 Microsoft