Mapování krychle - Cube mapping - Wikipedia
v počítačová grafika, mapování krychle je metoda mapování prostředí který používá šest tvarů krychle jako tvar mapy. Prostředí se promítá na strany krychle a ukládá se jako šest čtvercových textur nebo se rozkládá do šesti oblastí jedné textury. Mapa krychle je generována prvním vykreslením scény šestkrát z pohledu, přičemž pohledy jsou definovány o 90 stupňů zobrazit frustum představující každý obličej krychle.[1]
Ve většině případů je upřednostňováno mapování krychle před starší metodou mapování koule protože eliminuje mnoho problémů, které jsou vlastní mapování koulí, jako je zkreslení obrazu, závislost pohledu a výpočetní neefektivnost. Mapování krychle také poskytuje mnohem větší kapacitu podpory vykreslování v reálném čase z odrazy vzhledem k mapování koulí, protože kombinace neefektivity a závislosti na hledisku vážně omezuje možnost použití mapování koulí v případě, že se neustále mění hledisko.
Dějiny
Mapování krychle bylo poprvé navrženo v roce 1986 Ned Greene ve svém příspěvku „Mapování prostředí a další aplikace světových projekcí“,[2] deset let poté, co bylo poprvé předloženo mapování prostředí Jim Blinn a Martin Newell. Hardwarová omezení možnosti přístupu k šesti obrázkům textur současně však znemožnila implementaci mapování krychle bez dalšího technologického vývoje. Tento problém byl napraven v roce 1999 vydáním Nvidia GeForce 256. Nvidia mapovala krychli v hardwaru jako „průlomovou vlastnost kvality obrazu GeForce 256, která ... umožní vývojářům vytvářet přesné odrazy v reálném čase. Mapování prostředí krychle, zrychlené v hardwaru, uvolní kreativitu vývojářů při používání odrazů a zrcadlových světelných efektů k vytváření zajímavých, pohlcujících prostředí. “[3] Dnes je mapování krychle stále používáno v různých grafických aplikacích jako oblíbená metoda mapování prostředí.
Výhody
Mapování krychle je upřednostňováno před jinými metodami mapování prostředí kvůli jeho relativní jednoduchosti. Mapování krychle také produkuje výsledky podobné těm, které získal sledování paprsku, ale je výpočetně mnohem efektivnější - mírné snížení kvality je kompenzováno velkým nárůstem efektivity.
Předcházet mapování krychle, mapování koule má mnoho inherentních nedostatků, díky nimž je pro většinu aplikací nepraktické. Mapování koulí je závislé na pohledu, což znamená, že pro každé hledisko je nutná jiná struktura. Proto v aplikacích, kde je hledisko mobilní, by bylo nutné dynamicky generovat nové mapování koulí pro každý nový hledáček (nebo předem vygenerovat mapování pro každý hledáček). Také textura namapovaná na povrch koule musí být roztažena a stlačena, a přímým důsledkem toho je deformace a zkreslení (zejména podél okraje koule). Přestože lze tyto nedostatky obrazu snížit pomocí určitých triků a technik, jako je „pre-stretching“, přidává to do mapování koulí jen další vrstvu složitosti.
Paraboloidní mapování poskytuje určité vylepšení omezení mapování koulí, vyžaduje však kromě speciálních operací deformace obrazu a více zapojeného výpočtu dva průchody vykreslování.
Naopak mapování krychle vyžaduje pouze jeden průchod vykreslení a díky své jednoduché povaze je vývojářům velmi snadno pochopitelné a generovatelné. Mapování krychle také používá celé rozlišení obrazu textury ve srovnání s mapováním koulí a paraboloidů, což mu také umožňuje používat obrázky s nižším rozlišením k dosažení stejné kvality. Přestože je manipulace se švy mapy krychle problémem, byly vyvinuty algoritmy, které zpracovávají chování švů a vedou k bezproblémovému odrazu.
Nevýhody
Pokud je do scény zaveden nový objekt nebo nové osvětlení nebo pokud se nějaký objekt, který se v něm odráží, nějakým způsobem pohybuje nebo mění, pak se odraz změní a mapa krychle musí být znovu vykreslena. Když je mapa krychle připevněna k objektu, který se pohybuje scénou, musí být mapa krychle také znovu vykreslena z této nové polohy.
Aplikace
Stabilní zrcadlové zvýraznění
Počítačem podporovaný design (CAD) používají programy zrcadlové zvýraznění jako vizuální podněty zprostředkující pocit zakřivení povrchu při vykreslování 3D objektů. Mnoho programů CAD však vykazuje problémy se vzorkováním zrcadlových zvýraznění, protože výpočty zrcadlového osvětlení se provádějí pouze na vrcholech sítě použité k reprezentaci objektu a interpolace se používá k odhadu osvětlení na povrchu objektu. Problémy nastávají, když vrcholy ok nejsou dostatečně husté, což má za následek nedostatečné vzorkování zrcadlového osvětlení. To má zase za následek zvýraznění s jasem úměrným vzdálenosti od vrcholů sítě, což nakonec ohrozí vizuální narážky, které naznačují zakřivení. Bohužel tento problém nelze vyřešit jednoduše vytvořením hustší sítě, protože to může výrazně snížit účinnost vykreslování objektů.
Mapy krychle poskytují poměrně jednoduché a efektivní řešení pro vykreslení stabilních zrcadlových vrcholů. Do textury krychlové mapy lze zakódovat více zvláštních zvýraznění, ke kterým lze poté přistupovat interpolovat přes povrch odraz vektor dodat souřadnice. Ve srovnání s výpočtem osvětlení v jednotlivých vrcholech poskytuje tato metoda čistší výsledky, které přesněji představují zakřivení. Další výhodou této metody je, že se dobře škáluje, protože do textury lze zakódovat další zrcadlová zvýraznění bez zvýšení nákladů na vykreslování. Tento přístup je však omezen tím, že světelnými zdroji musí být buď vzdálená nebo nekonečná světla, i když naštěstí to obvykle platí v programech CAD.
Skyboxy
Snad nejpokročilejší aplikací mapování krychlí je vytvoření předem vykresleného panoramatu nebe obrázky které jsou poté grafickým modulem vykresleny jako plochy krychle v prakticky nekonečné vzdálenosti s vyhlídkovým bodem umístěným ve středu krychle. The perspektivní projekce tváří krychle provedených grafickým modulem zruší účinky promítnutí prostředí na vytvoření mapy krychle, takže pozorovatel zažije iluzi obklopení scénou, která byla použita ke generování skyboxu. Tato technika našla široké použití v videohry protože umožňuje návrhářům přidávat do hry složitá (i když ne prozkoumatelná) prostředí téměř bez nákladů na výkon.
Osvětlení světlíku
Krychlové mapy mohou být užitečné pro přesné modelování venkovního osvětlení. Pouhé modelování slunečního světla jako jediného nekonečného světla zjednodušuje venkovní osvětlení a vede k nerealistickému osvětlení. Ačkoli spousta světla pochází ze slunce, rozptyl paprsků v atmosféře způsobí, že celá obloha bude fungovat jako zdroj světla (často se označuje jako osvětlení světlíku). Použitím krychlové mapy však lze zachytit difúzní příspěvek z osvětlení světlíku. Na rozdíl od map prostředí, kde se používá odrazový vektor, tato metoda přistupuje k krychlové mapě na základě normálního vektoru povrchu, aby poskytla rychlou aproximaci rozptýleného osvětlení ze světlíku. Nevýhodou této metody je, že výpočet krychlových map, aby správně představovaly střešní okno, je velmi složitá; jedním nedávným procesem je výpočet sférického harmonického základu, který nejlépe představuje nízkofrekvenční difuzní osvětlení z krychlové mapy. Bylo však provedeno značné množství výzkumu k efektivnímu modelování osvětlení střešního okna.
Dynamický odraz
Základní mapování prostředí používá statickou krychlovou mapu - i když lze objekt přesouvat a deformovat, odražené prostředí zůstává konzistentní. Texturu mapy krychle však lze důsledně aktualizovat tak, aby představovala dynamicky se měnící prostředí (například stromy kymácející se ve větru). Jednoduchý, ale nákladný způsob generování dynamických odrazů, zahrnuje vytváření map krychle za běhu pro každý snímek. I když je to mnohem méně efektivní než statické mapování kvůli dalším krokům vykreslování, stále to lze provádět interaktivním tempem.
Tato technika se bohužel nemění dobře, pokud je přítomno více reflexních objektů. U každého reflexního objektu je obvykle vyžadována jedinečná mapa dynamického prostředí. Přidávají se také další komplikace, pokud se reflexní objekty mohou vzájemně odrážet - dynamické krychlové mapy lze rekurzivně generovat aproximovat účinky normálně generované pomocí raytracingu.
Globální osvětlení
Algoritmus pro globální osvětlení výpočet interaktivním tempem pomocí datové struktury krychlové mapy, byl představen na ICCVG 2002.[1]
Projekční textury
Další aplikací, která našla široké použití ve videohrách, je projektivní mapování textur. Při promítání obrazů prostředí na okolní scénu se spoléhá na krychlové mapy; například bodový světelný zdroj je svázán s mapou krychle, což je panoramatický snímek natočený zevnitř lucerny nebo okenního rámu, kterým světlo filtruje. To umožňuje vývojářům her dosáhnout realistického osvětlení, aniž by museli komplikovat geometrii scény nebo se uchýlit k nákladnému real-time objem stínu výpočty.
Adresování paměti
Textura krychle indexuje šest map textury od 0 do 5 v pořadí Pozitivní X, Negativní X, Pozitivní Y, Negativní Y, Pozitivní Z, Negativní Z.[4][5] Obrázky jsou uloženy s počátkem v levé dolní části obrázku. Pozitivní plochy X a Y musí obrátit souřadnici Z a záporná plocha Z musí negovat souřadnici X. Pokud jsou uvedeny souřadnice obličeje a textury , nenormalizovaný vektor lze vypočítat funkcí:
prázdnota convert_cube_uv_to_xyz(int index, plovák u, plovák proti, plovák *X, plovák *y, plovák *z){ // převede rozsah 0 na 1 až -1 na 1 plovák vidíš = 2,0f * u - 1,0f; plovák vc = 2,0f * proti - 1,0f; přepínač (index) { případ 0: *X = 1,0f; *y = vc; *z = -vidíš; přestávka; // POZITIVNÍ X případ 1: *X = -1,0f; *y = vc; *z = vidíš; přestávka; // NEGATIVNÍ X případ 2: *X = vidíš; *y = 1,0f; *z = -vc; přestávka; // POZITIVNÍ Y případ 3: *X = vidíš; *y = -1,0f; *z = vc; přestávka; // NEGATIVNÍ Y případ 4: *X = vidíš; *y = vc; *z = 1,0f; přestávka; // POZITIVNÍ Z případ 5: *X = -vidíš; *y = vc; *z = -1,0f; přestávka; // NEGATIVNÍ Z }}
Podobně vektor lze převést na index tváře a souřadnice textury s funkcí:
prázdnota convert_xyz_to_cube_uv(plovák X, plovák y, plovák z, int *index, plovák *u, plovák *proti){ plovák absX = báječné(X); plovák absY = báječné(y); plovák absZ = báječné(z); int isXPositive = X > 0 ? 1 : 0; int je pozitivní = y > 0 ? 1 : 0; int isZPositive = z > 0 ? 1 : 0; plovák maxAxis, vidíš, vc; // POZITIVNÍ X -li (isXPositive && absX >= absY && absX >= absZ) { // u (0 až 1) přechází z + z do -z // v (0 až 1) přechází z -y do + y maxAxis = absX; vidíš = -z; vc = y; *index = 0; } // NEGATIVNÍ X -li (!isXPositive && absX >= absY && absX >= absZ) { // u (0 až 1) přechází z -z do + z // v (0 až 1) přechází z -y do + y maxAxis = absX; vidíš = z; vc = y; *index = 1; } // POZITIVNÍ Y -li (je pozitivní && absY >= absX && absY >= absZ) { // u (0 až 1) přechází z -x do + x // v (0 až 1) jde od + z do -z maxAxis = absY; vidíš = X; vc = -z; *index = 2; } // NEGATIVNÍ Y -li (!je pozitivní && absY >= absX && absY >= absZ) { // u (0 až 1) přechází z -x do + x // v (0 až 1) přechází z -z do + z maxAxis = absY; vidíš = X; vc = z; *index = 3; } // POZITIVNÍ Z -li (isZPositive && absZ >= absX && absZ >= absY) { // u (0 až 1) přechází z -x do + x // v (0 až 1) přechází z -y do + y maxAxis = absZ; vidíš = X; vc = y; *index = 4; } // NEGATIVNÍ Z -li (!isZPositive && absZ >= absX && absZ >= absY) { // u (0 až 1) přechází z + x do -x // v (0 až 1) přechází z -y do + y maxAxis = absZ; vidíš = -X; vc = y; *index = 5; } // Převede rozsah od -1 do 1 na 0 na 1 *u = 0,5f * (vidíš / maxAxis + 1,0f); *proti = 0,5f * (vc / maxAxis + 1,0f);}
Příbuzný
Velká sada bezplatných map krychlí pro experimentování:http://www.humus.name/index.php?page=Textures
Mark VandeWettering vzal M. C. Escher slavný autoportrét Ruka s odraznou koulí a obrátil mapování, aby získal tyto obrázky krychlové mapy: vlevo, odjet, že jo, nahoru, dolů, zadní, přední. Tady je three.js demo pomocí těchto obrázků (nejlépe prohlíženo v širokém okně prohlížeče a pro zobrazení dema bude možná nutné obnovit stránku):https://web.archive.org/web/20140519021736/http://threejs.org/examples/webgl_materials_cubemap_escher.html
Můžete také převést další environmentální projekce na mapu krychle (např. od ekvirectangulární projekce po mapu krychle )
Reference
- ^ Fernando, R. & Kilgard M. J. (2003). Výukový program CG: Definitivní průvodce programovatelnou grafikou v reálném čase. (1. vyd.). Addison-Wesley Longman Publishing Co., Inc. Boston, MA, USA. Kapitola 7: Techniky mapování prostředí
- ^ Greene, N (1986). "Mapování prostředí a další aplikace světových projekcí". IEEE Comput. Graf. Appl. 6 (11): 21–29. doi:10.1109 / MCG.1986.276658.
- ^ Nvidia, leden 2000. Technické informace: Perfektní odrazy a efekty světelného spektra s mapováním prostředí krychle Archivováno 2008-10-04 na Wayback Machine
- ^ https://msdn.microsoft.com/en-us/library/windows/desktop/ff476906(v=vs.85).aspx
- ^ http://www.nvidia.com/object/cube_map_ogl_tutorial.html