Immediate Mode GUI
Immediate Mode GUI (wörtlich übersetzt: „Unmittelbar-Modus GUI“) ist eine Art der Implementierung von grafischen Benutzeroberflächen (GUIs), die das Immediate-Mode-Entwurfsmuster für die Gestaltung der Programmierschnittstelle (API) in Grafikbibliotheken verwendet – wobei unmittelbar bedeutet, dass
- der Client alle Steuerelemente (visueller Baum/logischer Baum von Steuerelementen) selbst verwaltet und die Grafikobjekte zusammensetzt, um die Steuerelemente der kompletten GUI zu rendern, oder
- der Client die grafischen Primitive Bild für Bild direkt in eine Grafikpipeline zum Rendern einfügt
ohne Nutzung – also unmittelbar - umfangreicher Umleitungen auf gespeicherte Ressourcen und wo
- die Ereignisverarbeitung direkt durch den Client gesteuert und vollständig von ihm implementiert wird (im Gegensatz zu einer gebrauchsfertigen Basis-Ereignisverarbeitung durch ein GUI-System/eine GUI-Bibliothek unter Verwendung vordefinierter Ereignisse/Rückruffunktionen oder Signale/Slots) und
- die Listen der zu rendernden grafischen Objekte vom Client verwaltet werden und alle Zeichenbefehle, die zur Beschreibung der gesamten GUI benötigt werden, jedes Mal, wenn ein neues Bild benötigt wird, erneut an die Grafikpipeline übergeben werden müssen.
Dies impliziert, dass der Client-Code in einem Immediate Mode GUI seine eigenen grafischen Primitive verwaltet und dieses API-Design auch die Implementierung der Grafikpipeline beeinflusst.
Es gibt ein weiteres bedeutendes Entwurfsmuster der Programmierschnittstelle in Grafikbibliotheken – den Retained Mode.[1] Im Retained Mode werden die grafischen Primitive durch das GUI-System/die GUI-Bibliothek verwaltet, oft vor dem Client-Code versteckt.
GUI-Toolkit
BearbeitenDie meisten GUI-Toolkits für den Immediate Mode sind Weiterentwicklungen aus der Videospielentwicklung und besonders geeignet, wenn
- ein GUI synchron mit der Spielszene oder einer komplexen Grafik aktualisiert werden muss,
- ein GUI auf eine Spielszene oder eine komplexe Grafik überlagert werden muss (was in beiden Fällen besonders einfach ist, wenn sowohl das GUI als auch die Spielszene durch die Spielschleife gesteuert werden), oder
- ein GUI ein ungewöhnliches Aussehen haben oder mit komplexer Grafik aufgepeppt sein soll.
Typisch für ein GUI-Toolkit für den Immediate Mode ist, dass es
- direkter in dem Sinne ist, dass der Baum von Steuerelementen (Widgets) oft ein Baum aus Funktionsaufrufen ist, der wunderbar zusammensetzbar und flexibel ist – aber mit dem schwer zu interagieren ist,
- weniger komplex strukturiert und leichter zu verstehen ist (im Sinne von weniger impliziten Annahmen pro GUI-Toolkit-API-Aufruf) – dies führt in der Regel aber auch zu weniger Funktionalität,
- für mehr als einen einfachen Baum von Steuerelementen einschließlich Layout (absolute und/oder relative Positionierung in Bezug auf Eltern oder Geschwister) aufwendiger (benötigt typischerweise mehr GUI-Toolkit-API-Aufrufe) zu erstellen und zu verwalten ist,
- eine weniger ausgefeilte Entfernung verdeckter Objekte (Z-Buffering), Trefferprüfung, Behandlung von Zustandsänderungen, Bildlauffunktion und Animation für den Fokus/das aktives Steuerelement hat – dies impliziert auch die Notwendigkeit, selbst einen logischen Baum/visuellen Baum von Steuerelementen zu verwalten,
- die Vertexpuffer für jedes neue Bild komplett von Grund auf neu aufbauen muss, und folglich
- eine ständige Arbeitsbelastung für den Prozessor (CPU) erzeugt.
Deshalb sind Immediate-Mode-GUI-Toolkits eine gute Wahl für alle, die ein einfaches, aber leicht veränderbares und erweiterbares GUI-Toolkit wünschen. Sie sind in der Regel generisch, quelloffen und plattformübergreifend. Eine Möglichkeit, die Flexibilität und Kombinierbarkeit eines Immediate Mode GUI ohne die Nachteile der Verwaltung des Steuerelement-Baumes nur in Funktionsaufrufen mit dem Mangel an direkter Kontrolle, wie die grafische Benutzeroberfläche in der Render Engine gezeichnet wird, zu haben, wäre die Verwendung eines virtuellen Steuerelement-Baumes – so wie React einen virtuellen DOM verwendet.
Implementierungen
BearbeitenDas ursprüngliche Immediate Mode GUI Toolkit ist imgui by Adrien Herubel[2], das auf OpenGL basiert. Die Idee wurde von Casey Muratori verbreitet. Es existieren weitere Toolkits wie
- nuklear[3], das auf verschiedenen Grafikbibliotheken (Direct3D, GLFW, OpenGL, SDL, SFML, Wayland, Windows GDI, Windows GDI+ und X11) aufsetzen kann,
- kiss_sdl[4] für SDL (Simple DirectMedia Layer),
- Gio[5] für Go oder
- Dear ImGui[6], das in C++ geschrieben ist, auf verschiedenen Grafikbibliotheken (Allegro 5, DirectX, GLFW, iOS, Marmalade, Metal, OpenGL, SDL 2 und Vulkan) aufsetzen kann und für das es
Siehe auch
BearbeitenEinzelnachweise
Bearbeiten- ↑ Quinn Radich: Retained Mode Versus Immediate Mode. In: Win32 apps. Microsoft, 30. Mai 2018, abgerufen am 21. Dezember 2019.
- ↑ Adrien Herubel: AdrienHerubel/imgui: A small multiplatform immediate mode graphical user interface with OpenGL3.2 backend. 18. Dezember 2019 .
- ↑ Micha Mettke: vurtun/nuklear: A single-header ANSI C gui library. 22. Dezember 2019 .
- ↑ Tarvo Korrovits: actsl/kiss_sdl: Simple generic GUI widget toolkit for SDL2. 19. Dezember 2019 .
- ↑ Gio - immediate mode GUI in Go. In: gioui.org. Abgerufen am 14. November 2019.
- ↑ Omar Cornut: ocornut/imgui: Dear ImGui: Bloat-free Immediate Mode Graphical User interface for C++ with minimal dependencies. 22. Dezember 2019 .
- ↑ kotlin-graphics: kotlin-graphics/imgui: Bloat-free Immediate Mode Graphical User interface for JVM with minimal dependencies (rewrite of dear imgui). 19. Dezember 2019 .