The Artima Developer Community
Sponsored Link

.NET Buzz Forum
WPF: Layout-System und Performance

0 replies on 1 page.

Welcome Guest
  Sign In

Go back to the topic listing  Back to Topic List Click to reply to this topic  Reply to this Topic Click to search messages in this forum  Search Forum Click for a threaded view of the topic  Threaded View   
Previous Topic   Next Topic
Flat View: This topic has 0 replies on 1 page
-

Posts: 1524
Nickname: nitronic
Registered: Jul, 2006

Norbert Eder works as a software architect.
WPF: Layout-System und Performance Posted: Jun 18, 2008 11:39 AM
Reply to this message Reply

This post originated from an RSS feed registered with .NET Buzz by -.
Original Post: WPF: Layout-System und Performance
Feed Title: Norbert Eder - Living .NET
Feed URL: http://feeds.feedburner.com/NorbertEder-Livingnet
Feed Description: Copyright (c)2005, 2006 by Norbert Eder
Latest .NET Buzz Posts
Latest .NET Buzz Posts by -
Latest Posts From Norbert Eder - Living .NET

Advertisement
Müssen viele Elemente erstellt und dargestellt werden, kannd ie Performance schon mal sehr schnell in den Keller gehen. Dabei müssen die darzustellenden ELemente keineswegs komplex sein. Vielmehr reichen oft kleine Fallen, die vermieden werden wollen.

Oftmals führt das Verwenden eines falschen Panels zu einem Performance-Problem. Meist ist es so, dass genau das Panel verwendet wird, welches die gewünschte Aufgabe mit dem geringsten Aufwand (für uns als Entwickler) erfüllt. So wird also beispielsweise ein StackPanel verwendet, sollen Elemente untereinander platziert werden - und zwar in der Reihenfolge, wie sie hinzugefügt wurden. Werden ein paar wenige Elemente hinzugefügt, ist keine Auswirkung zu spüren. Sind es hunderte oder gar tausende, dann wird dieser Vorgang spürbar langsamer.

Hierfür verantwortlich ist die unterschiedliche Funktionalität der Panels. Während ein Canvas relativ dumm ist und Elemente basierend auf einer Positionsangabe platziert, ist diese Logik in einem StackPanel oder einem DockPanel wesentlich komplexer.

Layout System


Vom Layout-System werden pro Kindelement zwei Schritte durchgeführt:
  • Measure
  • Arrange

Jedes dieser Kindelemente besitzt seine eigene Implementierung von Measure und Arrange, damit die an das Element gestellten Anforderungen bezüglich des Layout-Verhaltens erfüllt werden können.

Ablauf Layouting
  • Ein Kindelement (UIElement) beginnt den Layoutprozess durch das Erfassen der Basiseigenschaften
  • Dann werden die Eigenschaften bezüglich Höhe, Breite, Randstärke ausgewertet
  • Ausführung von Panel-spezifischer Logik (siehe Orientation-Eigenschaft des StackPanels)
  • Der Inhalt wird ausgerichtet bzw. positioniert, nachdem die Größe etc. aller Kindelemente bemessen wurde.
  • Die Liste der Kindelemente wird am Bildschirm ausgegeben


Wann wird es haarig?

Beim Eintreten bestimmter Aktionen, wird der gesamte Layout-Prozess erneut durchlaufen. Folgende Aktionen sind dafür maßgeblich:
  • Hinzufügen eines neuen Kindelementes
  • Ausführung der Methode UpdateLayout eines Kindelementes
  • Zuweisung von LayoutTransform eines Kindelementes
  • Bei Änderung einer Dependency Property mit Auswirkung auf Measure und Arrange (gesetzt über die Metadaten)


Fazit


Durch das Wissen wie das Layout-System funktioniert und wann es erneut durchlaufen werden muss, läßt sich feststellen, in welchen Fällen worauf verzichtet werden sollte. So kann es beispielsweise effizienter sein, eine ListBox anstatt eines StackPanels zu verwenden (durch das Definieren von Templates kann das auch schön aussehen), oder vielleicht doch einen Canvas.

Ist man sich nicht sicher, ob die geplante Variante die beste Performance bietet, bietet sich auch an, vor der konkreten Implementierung dann eventuell doch eine kleine Beispielanwendung zu schreiben. Auch eingesetzte Profiler sind hilfreich.

Siehe auch: WPF: Performance messen und verbessern

Read: WPF: Layout-System und Performance

Topic: The State of the Internet Previous Topic   Next Topic Topic: SharePoint 404 Errors and Vanity URLs

Sponsored Links



Google
  Web Artima.com   

Copyright © 1996-2019 Artima, Inc. All Rights Reserved. - Privacy Policy - Terms of Use