Rámec pro grafické úpravy - Graphical Editing Framework
The Rámec pro grafické úpravy (GEF) je Zatmění projekt, který poskytuje rámec a komponenty koncového uživatele související s grafickými aplikacemi.
Dějiny
Společnost GEF byla původně vyvinuta jako součást nástrojů etools IBM (com.ibm.etools.gef) a přispěla k Zatmění v roce 2002 ve verzi 2.0.0, skládající se ze dvou komponent: Draw2d, 2D vizualizační komponenty založené na Standard Widget Toolkit (SWT) a GEF (MVC), související rámec model-view-controller, který lze použít k realizaci grafických editorů jako součást aplikací Eclipse Rich Client Platform (RCP). První vydání na Eclipse bylo GEF 2.1.0 v březnu 2003. Další hlavní verze, GEF 3.0.0, byla vydána v červnu 2004 a poskytuje mnoho nových funkcí, jako je podpora pravidel a průvodců. Zest byl přidán jako třetí součást projektu v roce 2007 ve verzi 1.0.0 jako součást vydání GEF 3.4.0. Od roku 2004, kdy byla vydána verze GEF 3.0.0, byly na rozhraní aplikačního programování (API) rozhraní použity pouze kompatibilní změny.
Souběžně s údržbou komponent GEF 3.x projektovým týmem od roku 2010 byla vyvinuta nová významná revize rámce. Jedná se o kompletní redesign, který je mnohem modulárnější, používá JavaFX místo SWT jako základní rámec vykreslování, a lze je použít také nezávisle na aplikacích Eclipse RCP. Běžně označovaný jako GEF4, jeho komponenty byly původně vydány ve verzi 0.1.0 (se stále provizorním API) v červnu 2015 jako součást vydání GEF 3.10.0 (Mars). Součásti GEF4 mají být publikovány ve verzi 1.0.0 jako součást vydání GEF 4.0.0 (Neon) v červnu 2016.
GEF 3.x
GEF 3.x poskytuje rámcovou technologii pro realizaci grafických editorů a pohledů jako součást Eclipse Rich Client Platform (RCP) aplikace. Interně se rozkládá na tři složky:
- Draw2d - 2D vizualizační komponenta založená na Standard Widget Toolkit (SWT)
- GEF (MVC) - komponenta model-view-controller, kterou lze použít k realizaci grafických editorů jako součást aplikací Eclipse Rich Client Product (RCP)
- Zest - grafická vizualizační sada nástrojů, kterou lze použít k realizaci pohledů pro vizualizaci grafických datových struktur jako součást aplikací Eclipse RCP
Zatímco grafické aplikace lze postavit přímo na komponenty GEF 3.x, Draw2d a GEF (MVC) používá také Rámec grafického modelování (GMF), který je kombinuje s Eclipse Modeling Framework (EMF) k vytvoření kódu pro datový model i grafický editor.
Architektura
Editory vytvořené pomocí GEF (MVC) se skládají z následujících komponent:
- Editor diagramů včetně palety nástrojů
- Obrázky, které graficky představují podkladové prvky datového modelu
- EditParts, které odpovídají obrázkům a jejich příslušným prvkům modelu
- Vyžádejte si objekty pro vstup uživatele
- Objekty EditPolicy, které vyhodnocují požadavky a vytvářejí vhodné objekty příkazů
- Ovládejte objekty, které model upravují a poskytují vrátit -předělat
Použití návrhového vzoru
GEF hojně využívá designové vzory. Tyto vzorce jsou v rámci GEF často povinné a vývojáři jsou povinni jim porozumět.
- Řadič zobrazení modelu je architektonický návrhový vzor, který rozděluje aplikaci na samostatné části, které spolu komunikují specifickým způsobem. Cílem je oddělit datový model (model), grafické uživatelské rozhraní (pohled) a obchodní logiku (řadič). Společnost GEF značně využívá vzor MVC.
- Model: Datový model lze buď generovat pomocí EMF, sám implementovat uživatelem, nebo již může existovat v případě staršího softwaru.
- Řadič: EditParts fungují jako řadiče. Každý prvek modelu má obvykle odpovídající EditPart. EditParts mohou obsahovat další EditParts, čímž se shodují prvky modelu obsahující další prvky modelu. EditParts mají také odkaz na obrázek, který graficky představuje prvek modelu. Nakonec EditParts vyhodnotí požadavky a vytvoří příslušný příkaz pro úpravu podkladového modelu.
- Pohled: Pro každý prvek v modelu, včetně připojení, musí být obrázek implementován pomocí rámce Draw2d. Často je obrazem nějaký geometrický výkres.
- Továrna: Vytváření modelů z palety, vytváření EditParts a vytváření obrázků
- Pozorovatel: Typicky řadič (EditPart) naslouchající v Modelu a View
- Příkaz: Implementovat funkce Zpět a Znovu
- Strategie: EditParts může instalovat a odebírat EditPolicies dynamicky
- Řetěz odpovědnosti: Rozhodnout, která EditPolicy by měla zpracovat požadavek
Mechanismus požadavků a odpovědí
Jakákoli akce uživatele s editorem může vygenerovat požadavek. Povaze žádosti se rozumí kontext vyvolání. Kontext je určen EditPart, se kterým uživatel interaguje, a aktivním nástrojem. Nástrojem může být libovolná vybraná položka v paletě nástrojů. Žádost je předána vybrané EditPart, která zase vrátí příkaz.
Toho je dosaženo pomocí řetěz odpovědnosti mechanismus přes Editpolicies. Politiky úprav určují, zda mohou požadavek zpracovat, jinak předají další politiku úprav. Pořadí deklarace editačních politik určuje pořadí, ve kterém je požadavek předán. Schopná editační politika vytvoří příkaz. Tento příkaz je předán zpět nástroji, který inicioval „požadavek“. Provedení příkazu způsobí změnu modelu (Response).