Einfaches WPF-Popup-Menu, das sich mit einem Button öffnen lässt
Ein typische WPF-Benutzeroberfläche benötigt oft mit Button öffenbare Menüs. Obwohl sich viele Lösungen im Internet befinden, sind sie kompliziert und erfordern, dass man ein neues Steuerelement erstellt. Das ist aber unnötig. WPF enthält schon ein Menü Bedienelement, das hierarchische Daten perfekt darstellen kann. Es muss nur richtig konfiguriert werden, damit das Wurzelelement des Menüs als Button dargestellt wird.
Erstens muss man die ViewModel-Klasse erstellen. TestMenuItemViewModel enthält nicht nur die Title, IconSource und Command Eigenschaften, sondern auch eine Liste von Kindelementen des Menüpunktes.
Die ViewModel-Klasse enthält ein einziges Wurzelelement, das Hauptmenü, das unter dem Namen TestMenu zum DataContext eingefügt wird.
Der Xaml-Code des Menüs basiert auf der Modifizierung vom ItemContatinerStyle. Der Hauptmenüpunkt ist ein MenuItem mit einer eigenen Anlage von Steuerelementen, die einen Button ausmachen. Die Untermenüpunkte sind auch MenuItems, deren Style innerhalb vom Hauptmenü gesetzt wird und deshalb bleibt der Style des Hauptmenüs unberührt. Wenn ein TestMenuItem null ist, ein Separator, statt eines Menüpunktes wird eingeführt. Der Separator wird durch einen DataTrigger erstellt, der das ganze Styletemplate überschreibt.
Wenn man verschiedene TestMenuItem-Type unterstützen, und je nach Typ die Darstellung ändern will, geben die DataTriggers auch dafür eine Lösung. Den Trigger muss man mit dem Datentyp verbinden und der Styletemplate dem Typ entsprechend gestalten.