Graf scény - Scene graph

Architektura města OpenSceneGraph, open-source 3D grafika API podpora implementace scénického grafu bohatého na funkce a široce přijímaného.

A graf scény je generál datová struktura běžně používaný vektorové grafické úpravy aplikace a moderní počítačové hry, které zajišťují logické a často prostorové znázornění grafické scény. Je to kolekce uzlů v a graf nebo strom struktura. Uzel stromu může mít mnoho dětí, ale pouze jednoho rodiče, s účinkem rodiče použitého na všechny jeho podřízené uzly; operace prováděná na skupině automaticky šíří její účinek na všechny její členy. V mnoha programech je přidružení geometrické transformační matice (viz také proměna a matice ) na každé úrovni skupiny a zřetězení takových matic dohromady je efektivní a přirozený způsob zpracování těchto operací. Společným znakem je například schopnost seskupit související tvary a objekty do složeného objektu, se kterým lze potom snadno manipulovat jako s jedním objektem.

Grafy scén v nástrojích pro úpravu grafiky

Ve vektorových grafických úpravách každý listový uzel ve scénickém grafu představuje nějakou atomovou jednotku dokumentu, obvykle tvar jako například elipsa nebo Bézierova cesta. I když samotné tvary (zejména cesty) lze rozložit dále na uzly jako např spline uzly, je praktické uvažovat o grafu scény, který je složen z tvarů, spíše než jít na nižší úroveň reprezentace.

Dalším užitečným a uživatelem řízeným konceptem uzlu je vrstva. Vrstva funguje jako průhledný list, na který lze umístit libovolný počet tvarů a skupin tvarů. Z dokumentu se pak stane sada vrstev, z nichž kteroukoli lze pohodlně nastavit jako neviditelnou, ztlumenou nebo uzamčenou (pouze pro čtení). Některé aplikace umisťují všechny vrstvy do lineárního seznamu, zatímco jiné podporují vrstvy ve vrstvách do libovolné požadované hloubky.

Interně mezi vrstvami a skupinami nemusí být vůbec žádný skutečný strukturální rozdíl, protože obě jsou pouze uzly grafu scény. Pokud jsou potřeba rozdíly, společné deklarace typu v C ++ by bylo vytvořit obecnou třídu uzlů a poté odvodit vrstvy a skupiny jako podtřídy. Člen viditelnosti by například byl znakem vrstvy, ale ne nutně skupiny.

Grafy scén v hrách a 3D aplikacích

Grafy scén jsou užitečné pro používání moderních her 3D grafika a stále větší světy nebo úrovně. V takových aplikacích představují uzly v grafu scény (obecně) entity nebo objekty ve scéně.

Například hra může definovat logický vztah mezi rytířem a koněm, takže rytíř je považován za rozšíření koně. Graf scény by měl uzel „koně“ s uzlem „rytíře“.

Scénický graf může také popisovat prostorový i logický vztah různých entit: rytíř se pohybuje 3D prostorem, jak se pohybuje kůň.

V těchto velkých aplikacích jsou při navrhování grafu scény důležitými požadavky na paměť. Z tohoto důvodu používá mnoho velkých grafových systémů scény instanci geometrie snížit náklady na paměť a zvýšit rychlost. V našem příkladu výše je každý rytíř samostatným uzlem scény, ale grafická reprezentace rytíře (tvořená 3D sítí, texturami, materiály a shadery) je instanční. To znamená, že je uchována pouze jedna kopie dat, na kterou pak odkazují libovolné „rytířské“ uzly v grafu scény. To umožňuje snížený rozpočet paměti a zvýšenou rychlost, protože když je vytvořen nový uzel rytíře, data vzhledu nemusí být duplikována.

Implementace grafu scény

Nejjednodušší forma grafu scény používá znak pole nebo spojový seznam datová struktura a zobrazení jeho tvarů je prostě otázkou lineárního iterace uzlů jeden po druhém. Další běžné operace, jako je kontrola za účelem zobrazení který tvar protíná ukazatel myši se také provádí pomocí lineárního vyhledávání. U grafů malých scén to obvykle postačuje.

Operace a odeslání grafu scény

Použití operace na graf scény vyžaduje nějaký způsob odeslání operace na základě typu uzlu. Například v operaci vykreslování by uzel transformační skupiny akumuloval svou transformaci pomocí násobení matic, vektorového posunutí, čtveřice nebo Eulerovy úhly. Poté listový uzel odešle objekt k vykreslení do vykreslovacího modulu. Některé implementace mohou vykreslit objekt přímo, což vyvolá podkladové vykreslení API, jako DirectX nebo OpenGL. Ale od základní implementace vykreslovací API obvykle postrádá přenositelnost, místo toho lze oddělit graf scény a vykreslovací systémy. K dosažení tohoto typu dispečinku lze použít několik různých přístupů.

V objektově orientovaných jazycích, jako je C ++, toho lze snadno dosáhnout pomocí virtuální funkce, kde každý představuje operaci, kterou lze provést na uzlu. Virtuální funkce se snadno píší, ale je obvykle nemožné přidávat nové operace do uzlů bez přístupu ke zdrojovému kódu. Případně vzor návštěvníka může být použito. To má podobnou nevýhodu v tom, že je podobně obtížné přidat nové typy uzlů.

Jiné techniky zahrnují použití RTTI (Informace o typu běhu ). Operaci lze realizovat jako třídu předanou aktuálnímu uzlu; poté se dotazuje na typ uzlu pomocí RTTI a vyhledá správnou operaci v poli zpětná volání nebo funktory. To vyžaduje, aby mapa typů zpětných volání nebo funktorů byla inicializována za běhu, ale nabízí větší flexibilitu, rychlost a rozšiřitelnost.

Varianty těchto technik existují a nové metody mohou nabídnout další výhody. Jednou z alternativ je opětovné sestavení grafu scény, kde je graf scény znovu vytvořen pro každou z provedených operací. To však může být velmi pomalé, ale výsledkem je vysoce optimalizovaný graf scény. Ukazuje, že dobrá implementace grafu scény silně závisí na aplikaci, ve které se používá.

Traversals

Traversals jsou klíčem k síle aplikace operací na grafy scén. Traversal obecně sestává ze začátku na nějakém libovolném uzlu (často kořen grafu scény), použití operace (operací) (často se operace aktualizace a vykreslení použijí jeden po druhém) a rekurzivní pohyb dolů grafem scény (strom ) do podřízených uzlů, dokud nedosáhnete uzlu listu. V tomto okamžiku mnoho motorů grafů scén poté přejde zpět do stromu a použije podobnou operaci. Zvažte například operaci vykreslení, která zohledňuje transformace: při rekurzivním procházení hierarchií grafu scény se nazývá operace předběžného vykreslení. Pokud je uzel transformační uzel, přidá vlastní transformaci do aktuální transformační matice. Jakmile operace dokončí procházení všemi potomky uzlu, zavolá operaci uzlu po vykreslení, aby transformační uzel mohl transformaci vrátit zpět. Tento přístup drasticky snižuje potřebné množství násobení matic.[Citace je zapotřebí ]

Některé operace s grafy scén jsou ve skutečnosti efektivnější, když se uzly procházejí v jiném pořadí - to je místo, kde některé systémy implementují opětovné sestavení grafu scény, aby se pořadí grafu scény změnilo ve snadněji analyzovatelný formát nebo strom.

Například v 2D případech se grafy scén obvykle vykreslují tak, že začínají v kořenovém uzlu stromu a poté rekurzivně kreslí podřízené uzly. Listy stromu představují objekty v popředí. Vzhledem k tomu, že kresba probíhá zezadu dopředu s bližšími objekty, které jednoduše přepisují ty další, je tento proces známý jako Painterův algoritmus. Ve 3D systémech, které často používají hloubkové nárazníky, je efektivnější nejdříve nakreslit nejbližší objekty, protože dál objekty je třeba namísto skutečného vykreslení pouze podrobit hloubkové zkoušce, protože jsou uzavřeny bližšími objekty.

Grafy scén a hierarchie objemových svazků (BVH)

Hranice objemových vazeb (BVH) jsou užitečné pro řadu úkolů - včetně účinného utracení a zrychlení detekce kolizí mezi objekty. BVH je prostorová struktura, ale nemusí dělit geometrii (viz prostorové rozdělení níže).

BVH je strom mezní objemy (často koule, zarovnané s osou ohraničující boxy nebo orientované ohraničující rámečky). Ve spodní části hierarchie je velikost svazku dostatečně velká, aby těsně obklopovala jeden objekt (nebo možná i nějaký menší zlomek objektu ve BVH s vysokým rozlišením). Jak jeden stoupá po hierarchii, každý uzel má svůj vlastní svazek, který pevně zahrnuje všechny svazky pod ním. V kořenovém adresáři stromu je svazek, který zahrnuje všechny svazky ve stromu (celou scénu).

BVH jsou užitečné pro urychlení detekce kolizí mezi objekty. Pokud ohraničující svazek objektu neprotíná svazek vyšší ve stromu, nemůže protínat žádný objekt pod tímto uzlem (takže jsou všechny velmi rychle odmítnuty).

Mezi BVH a scénickými grafy existují určité podobnosti. Graf scény lze snadno upravit tak, aby zahrnoval / stal se BVH - pokud má každý uzel přidružený svazek nebo je na výhodném místě v hierarchii přidán účelový „vázaný uzel“. Toto nemusí být typické zobrazení grafu scény, ale zahrnutí BVH do grafu scény má výhody.

Grafy scén a prostorové rozdělení

Efektivní způsob kombinování prostorové rozdělení a grafy scén je vytvořením uzlu listu scény, který obsahuje data prostorového dělení.[je zapotřebí objasnění ] To může zvýšit výpočetní účinnost vykreslování.

Prostorová data jsou obvykle statická a obecně obsahují nepohyblivá data scény v nějaké rozdělené formě.[je zapotřebí objasnění ] Některé systémy mohou mít systémy a jejich vykreslování samostatně. To je v pořádku a ani jedna z metod nemá žádné skutečné výhody. Zejména je špatné mít graf scény obsažený v systému prostorového dělení, protože graf scény je lépe chápán jako granderový systém pro prostorové dělení.[neutralita je sporný]

Velmi velké kresby nebo grafy scén, které jsou generovány pouze na runtime (jak se děje v sledování paprsku vykreslování programy), vyžadují automatizovanější definování skupinových uzlů. Raytracer například vezme popis scény a 3D modelujte a vytvořte interní reprezentaci, která rozdělí její jednotlivé části na ohraničující rámečky (nazývané také ohraničující desky). Tato pole jsou hierarchicky seskupena, aby bylo možné efektivně vypočítat testy průniku paprsků (jako součást stanovení viditelnosti). Skupinová schránka, která neprotíná například paprsek oka, může úplně přeskočit testování kteréhokoli z jejích členů.

Podobná účinnost platí i pro 2D aplikace. Pokud uživatel zvětšil dokument tak, že na jeho obrazovce je viditelná pouze jeho část, a poté se v něm posouvá, je užitečné rychle použít vymezovací rámeček (nebo v tomto případě schéma ohraničujícího obdélníku) prvky grafu jsou viditelné a je tedy nutné je nakreslit.

V závislosti na podrobnostech výkonu aplikace při kreslení může být velká část designu grafu scény ovlivněna úvahami o efektivnosti vykreslování. Ve 3D videohrách, jako je Zemětřesení, rozdělení binárního prostoru (BSP) jsou silně upřednostňovány, aby se minimalizovaly testy viditelnosti. Stromy BSP však výpočty z grafů návrhových scén trvají velmi dlouho a je nutné je přepočítat, pokud se graf návrhových scén změní, takže úrovně mají tendenci zůstat statické a dynamické znaky nejsou v schématu prostorového dělení obecně brány v úvahu.

Grafy scény pro husté běžné objekty, jako jsou výšková pole a mnohoúhelníkové sítě mají tendenci využívat čtyřkolky a oktávy, což jsou specializované varianty hierarchie 3D ohraničovacího rámečku. Vzhledem k tomu, že výškové pole zabírá samotný objem boxu, je rekurzivní rozdělení tohoto boxu na osm dílčích boxů (tedy 'oct' v oktree), dokud není dosaženo jednotlivých prvků výškového pole, efektivní a přirozené. Quadree je jednoduše 2D oktree.

Standardy

PHIGS

PHIGS byla první komerční specifikace grafu scény a v roce 1988 se stala standardem ANSI. Nesourodé implementace poskytl Unix prodejci hardwaru. The 3D grafický systém HOOPS se zdá být první komerční knihovnou grafů scén poskytovanou jediným prodejcem softwaru. Byl navržen tak, aby fungoval na různorodých 2D a 3D rozhraních nižší úrovně, přičemž první hlavní produkční verze (v3.0) byla dokončena v roce 1991. Krátce poté Křemíková grafika propuštěn IRIS Inventor 1.0 (1992), což byl graf scény postavený na rozhraní IRIS GL 3D API. Bylo sledováno Otevřete Inventor v roce 1994, přenosný scénický graf postavený na OpenGL. Více knihoven grafů 3D scén naleznete v Kategorie: API 3D scénografů.

X3D

X3D je bez licenčních poplatků otevřené standardy formát souboru a run-time architektura k reprezentaci a komunikaci 3D scén a objektů pomocí XML. Je to ISO - ověřený standard, který poskytuje systém pro ukládání, načítání a přehrávání grafického obsahu v reálném čase vloženého do aplikací, vše v rámci otevřená architektura k podpoře široké škály domén a uživatelských scénářů.

Viz také

Reference

Knihy

  • Leler, Wm and Merry, Jim (1996) 3D s HOOPS, Addison-Wesley
  • Wernecke, Josie (1994) The Inventor Mentor: Programování objektově orientované 3D grafiky pomocí Open Inventor, Addison-Wesley, ISBN  0-201-62495-8 (Vydání 2)

Články

externí odkazy