Doom motor - Doom engine - Wikipedia

iD Tech 1
Vývojářiid Software (John Carmack, John Romero, Dave Taylor)
Konečné vydání
1.9 / 1. února 1995; Před 25 lety (1995-02-01)
Úložištěgithub.com/id-Software/DOOM
NapsánoC, Montážní jazyk
PlošinaDOS, Microsoft Windows, Operační Systém Mac, Linux, Android, Amiga Workbench, Další krok, Macintosh, Commodore Amiga, Další, SNES, Atari Jaguar, Sega 32X, Sony PlayStation, Panasonic 3DO, Nintendo 64, Sega Saturn, Game Boy Advance, Nintendo Switch
NástupceQuake engine
LicenceGNU General Public License
Licence MIT[1]

id Tech 1, také známý jako Osud motor, je herní engine který pohání id Software hry Osud a Doom II: Peklo na Zemi. Používá se také v Heretik, Hexen: Beyond Heretic, Strife: Quest for the Sigil, Hacx: Twitch 'n Kill, Freedoom a další hry vyrobené držiteli licence. Vytvořil John Carmack, s pomocnými funkcemi napsanými Mike Abrash, John Romero, Dave Taylor a Paul Radek. Původně vyvinut na Další počítače, to bylo přeneseno na DOS pro OsudPočáteční vydání a později bylo přeneseno na několik herní konzole a operační systémy.

The zdrojový kód do Linux verze Osud byl propuštěn pro veřejnost na základě licence, která poskytla práva pro nekomerční použití 23. prosince 1997, následovaná verzí Linuxu pro Linux Doom II o týden později 29. prosince 1997.[2] Zdrojový kód byl později znovu vydán pod GNU General Public License 3. října 1999.[3][4]Desítky neoficiálních Osud zdrojové porty které byly od té doby vytvořeny povolit Osud běžet na dříve nepodporovaných operačních systémech a někdy radikálně rozšířit funkčnost motoru o nové funkce.

Ačkoli motor vykresluje 3D prostor, tento prostor se promítá z dvourozměrného prostoru půdorys. Přímka pohledu je vždy rovnoběžná s podlahou, stěny musí být kolmé k podlahám a není možné vytvářet víceúrovňové konstrukce nebo šikmé plochy (podlahy a stropy s různými úhly). Navzdory těmto omezením představoval motor technologický skok od předchozího id Wolfenstein 3D motor. The Osud engine byl později přejmenován na "id Tech 1", aby jej bylo možné zařadit do seznamu Dlouhá řada herních enginů id Software.[5]

Herní svět

The Osud engine odděluje vykreslování od zbytku hry. Grafický modul běží co nejrychleji, ale herní svět běží rychlostí 35 snímků za sekundu bez ohledu na hardware, takže více hráčů může hrát proti sobě pomocí počítačů s různým výkonem.[6]

Struktura úrovně

Jednoduché nastavení, které ukazuje, jak na to Osud představuje úrovně interně

Zobrazení mapy v editoru

Při pohledu shora dolů, vše Osud úrovně jsou ve skutečnosti dvourozměrné, což ukazuje jedno z klíčových omezení Osud motor: pokoj přes pokoj není možné. Toto omezení však má stříbrnou podšívku: lze snadno zobrazit „režim mapy“, který představuje stěny a pozici hráče, podobně jako první obrázek vpravo.

Základní objekty

Základní jednotkou je vrchol, což představuje jeden 2D bod. Vrcholy (nebo „vrcholy“, jak se na ně interně odkazuje) jsou pak spojeny do formy řádky, známé jako „linedefs“. Každý lemovaný povrch může mít jednu nebo dvě strany, které se označují jako „sidedefs“. Sidedefy jsou poté seskupeny do formy mnohoúhelníky; tyto se nazývají „sektory“. Sektory představují konkrétní oblasti úrovně.

Odvětví

Každý sektor obsahuje řadu vlastností: výšku podlahy, výšku stropu, úroveň světla, podlahu textura a stropní textury. Chcete-li mít například v určité oblasti jinou úroveň světla, musíte pro tuto oblast s jinou úrovní světla vytvořit nový sektor. Jednostranné liniové definice proto představují pevné stěny, zatímco dvoustranné liniové definice představují mosty mezi sektory.

Oboustranné

Sidedefs se používají k uložení zdi textury; jsou zcela oddělené od textury podlahy a stropu. Každý sidedef může mít tři textury; tito se nazývají střední, horní a dolní textury. V jednostranných liniových deskách se pro texturu na zdi používá pouze střední textura. U oboustranných linií je situace složitější. Dolní a horní textury se používají k vyplnění mezer tam, kde sousední sektory mají různé výšky podlahy a stropu: spodní textury se používají například pro kroky. Sidedefy mohou mít také střední texturu, ačkoli většina ne; toto se používá k vytvoření textur visících ve vzduchu. Například když je vidět průhledná pruhová struktura tvořící klec, jedná se o příklad střední textury na oboustranném liniovém povrchu.

Rozdělení binárního prostoru

Osud využívá systém známý jako rozdělení binárního prostoru (BSP).[7] K předběžnému generování dat BSP pro úroveň se používá nástroj. Tento proces může nějakou dobu trvat poměrně dlouho. Z tohoto důvodu není možné stěny pohybovat dovnitř Osud; zatímco dveře a výtahy se pohybují nahoru a dolů, žádný z nich se nikdy nepohybuje do strany.

Úroveň je rozdělena na a binární strom: každé místo ve stromu je „uzel“, který představuje určitou oblast úrovně (přičemž kořenový uzel představuje celou úroveň). U každé větve stromu je dělicí čára, která rozděluje oblast uzlu na dvě poduzly. Dělící čára zároveň rozděluje liniové definice na úsečky zvané „segs“.[8]

U listů stromu jsou konvexní polygony, kde není nutné další dělení úrovně. Tyto konvexní polygony se označují jako subsektory (neboli „SSECTORS“) a jsou vázány na konkrétní sektor. Každý subsektor má k sobě přidružený seznam seg.[7]

Systém BSP třídí subsektory do správného pořadí pro vykreslování. Algoritmus je poměrně jednoduchý:

  1. Začněte v kořenovém uzlu.
  2. Nakreslete rekurzivně podřízené uzly tohoto uzlu. Podřízený uzel nejblíže k fotoaparátu je nakreslen jako první pomocí a Algoritmus Scanline. To lze zjistit z pohledu, na které straně dělící čáry uzlu je kamera.
  3. Když je dosažen subsektor, nakreslete jej.[9]

Proces je dokončen, když je vyplněn celý sloupec pixelů (tj. Nezbývají už žádné mezery). Toto uspořádání zajišťuje, že se nebude používat žádný čas kreslení objektů, které nejsou viditelné, a v důsledku toho se mapy mohou velmi zvětšit bez jakéhokoli trestu rychlosti.

Vykreslování

Kreslení stěn

Všechny zdi uvnitř Osud jsou nakresleny svisle; proto není možné správně se dívat nahoru a dolů. Je možné provést formu vyhledávání nahoru / dolů pomocí "stříhání y" a mnoho moderních Osud zdrojové porty to dělají, stejně jako pozdější hry, které používají engine, například Heretik. V podstatě to funguje tak, že pohybujete horizontální linií nahoru a dolů na obrazovce, což ve skutečnosti poskytuje „okno“ na vyšší viditelné ploše. Pohybem okna nahoru a dolů je možné vytvořit iluzi pohledu nahoru a dolů. To však naruší pohled, čím dále hráč vypadá nahoru a dolů.

The Osud engine vykresluje stěny, když prochází stromem BSP, kreslí subsektory podle pořadí vzdálenosti od kamery, takže nejdříve jsou nakresleny nejbližší segs. Jakmile jsou segy nakresleny, jsou uloženy v propojeném seznamu. Slouží k oříznutí dalších segmentů vykreslených později, čímž se snižuje přečerpání. Toto se také později použije k oříznutí okrajů skřítků.

Jakmile motor dosáhne pevné (jednostranné) stěny na určité ose x, již v této oblasti není třeba kreslit žádné čáry. Pro oříznutí motor ukládá „mapu“ oblastí obrazovky, kde bylo dosaženo pevných stěn. To umožňuje úplné oříznutí vzdálených částí úrovně, které jsou pro hráče neviditelné.

The Osud grafický formát ukládá textury zdi jako sady svislých sloupů; to je užitečné pro renderer, který v podstatě vykresluje stěny nakreslením mnoha svislých sloupců textur.

Podlaha a strop

Systém kreslení podlah a stropů („bytů“) je méně elegantní než systém používaný pro stěny. Byty jsou nakresleny a povodňová výplň -jako algoritmus. Z tohoto důvodu je někdy možné použít špatný stavitel BSP k získání „děr“ tam, kde podlaha nebo strop krvácí dolů k okrajům obrazovky. To je také důvod, že pokud hráč cestuje mimo úroveň pomocí noclip cheat podlahy a stropy vypadají, že se táhnou od úrovně přes prázdný prostor.

Podlaha a strop jsou nakresleny jako „visplanes“. Představují horizontální běhy textury od podlahy nebo stropu v určité výšce, úrovni světla a textury (pokud mají dva sousední sektory přesně stejnou podlahu, mohou být sloučeny do jedné visplane). Každá poloha x ve vislonu má zvláštní svislou čáru textury, která má být nakreslena.

Kvůli tomuto limitu kreslení jedné svislé čáry v každé poloze x je někdy nutné rozdělit visplanes na více visplanes. Zvažte například prohlížení patra se dvěma koncentrický čtverce. Vnitřní čtverec vertikálně rozdělí okolní podlahu. V tomto vodorovném rozsahu, kde je nakreslen vnitřní čtverec, jsou pro okolní podlahu zapotřebí dva visloplany.

To vede k jednomu z OsudKlasická omezení, která dlouho frustrovala mnoho mapovačů. Osud obsahoval statický limit počtu vimplanesů; pokud bude překročeno, dojde k „přetečení vislony“, což způsobí, že hra skončí v systému DOS s jednou ze dvou zpráv „Už žádná visplanes!“ nebo "přetečení visplane (128 nebo vyšší)". Nejjednodušší způsob, jak vyvolat limit visplane, je velký šachovnicový podlahový vzor; to vytváří velké množství vimplanes.

Při vykreslování segů se přidávají také vislonesy, které sahají od okrajů seg směrem ke svislým okrajům obrazovky. Ty se prodlužují, dokud nedosáhnou stávajících visplanes. Z důvodu způsobu, jakým to funguje, je systém závislý na skutečnosti, že segs jsou vykreslovány v pořadí podle celkového motoru; nejdříve je třeba nakreslit bližší roviny, aby je mohli „odříznout“ další vzdálenější. Pokud se nezastaví, podlaha nebo strop „vykrvácejí“ k okrajům obrazovky, jak bylo popsáno výše. Nakonec vimplanes vytvoří „mapu“ konkrétních oblastí obrazovky, do kterých budou kresleny konkrétní textury.

Zatímco vislony jsou konstruovány v podstatě ze svislých „pásů“, skutečné vykreslování na nízké úrovni se provádí ve formě vodorovných „rozpětí“ textury. Po zkonstruování všech vimplanes se převedou na rozpětí, která se poté vykreslí na obrazovku. To se zdá být kompromisem: je snazší konstruovat visplanes jako svislé pruhy, ale vzhledem k povaze toho, jak vypadají textury podlahy a stropu, je snadnější je nakreslit jako vodorovné pruhy.

Věci (skřítci)

Každý sektor na úrovni má propojený seznam věcí uložených v tomto sektoru. Když je každý sektor nakreslen, skřítci jsou umístěni do seznamu skřítků, které mají být nakresleny. Pokud nejsou v zorném poli, jsou ignorovány.

Okraje skřítků jsou oříznuty kontrolou seznamu dříve nakreslených seg. Skřítci dovnitř Osud jsou uloženy ve stejném formátu založeném na sloupcích jako stěny, což je opět užitečné pro renderer. Stejné funkce, které se používají k kreslení stěn, se používají také k kreslení spritů.

I když je zaručeno, že subsektory budou v pořádku, skřítci v nich nejsou. Osud uloží seznam skřítků, které mají být nakresleny ("vissprites") a před vykreslením seřadí seznam. Daleko vzdálení skřítci jsou kresleni před blízkými. To způsobí určité přečerpání, ale obvykle je to zanedbatelné.

Existuje finální vydání středních textur na 2stranných řádcích, které se používají například v průhledných pruzích. Ty jsou namíchány a nakresleny skřítky na konci procesu vykreslování, nikoli jinými stěnami.

Hry využívající Osud motor

The Osud engine dosáhl většiny své slávy díky napájení klasické střílečky z pohledu první osoby Osud a bylo použito v několika dalších hrách. Obvykle se má za to, že „velká čtyřka“ Osud motorové hry jsou Osud, Heretik, Hexen: Beyond Heretic, a Strife: Quest for the Sigil.

Hry postavené přímo na internetu Osud motor
Hry založené na Osud nebo Doom II kód

Viz také

Poznámky

Reference

  1. ^ https://github.com/Olde-Skuul/doom3do/blob/master/LICENSE
  2. ^ Zaměstnanci (29. prosince 1997). „Zdroj Doom II k dispozici“. PC Gamer USA. Archivovány od originál dne 18. února 1998. Citováno 20. listopadu 2019.
  3. ^ The Osud zdrojový kód[trvalý mrtvý odkaz ] - vydáno v roce 1997, nyní pod GNU General Public License ze stránky FTP společnosti Id Software
  4. ^ The Osud zdrojový kód z 3ddownloads.com Archivováno 24. Února 2004 v Wayback Machine - vydáno v roce 1997, nyní pod GNU General Public License
  5. ^ „id Tech 1 (koncept)“. Obří bomba.
  6. ^ Schuytema, Paul C. (srpen 1994). „Světlejší strana zkázy“. Svět počítačových her. 140, 142.
  7. ^ A b Abrash, Michael. „Quake's 3-D Engine: The Big Picture“. Citováno 22. srpna 2012.
  8. ^ Apted, Andrew. „SPECIFIKACE pro uzly GL“. Citováno 22. srpna 2012.
  9. ^ Sanglard, Fabien. "Kontrola kódu motoru Doom". Citováno 23. srpna 2012.

externí odkazy