• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            3D游戲之神-——約翰.卡馬克

            常用鏈接

            統(tǒng)計(jì)

            最新評(píng)論

            QUAKE系列引擎以及基于QUAKE擴(kuò)展引擎的源代碼全面分析(三) --bsp文件格式分析1

             

            一:一些廢話  
               
            好久沒(méi)更新了,一方面是年底了,對(duì)于做銷(xiāo)售的人來(lái)說(shuō),利用這段時(shí)間出出差,拜訪拜訪經(jīng)銷(xiāo)商以及KA客戶,目的是確定明年的銷(xiāo)售指標(biāo),暈。另一個(gè)更重要的原因是竟然把密碼忘記了,沒(méi)辦法進(jìn)入我的博客。前天整理東西時(shí)候竟然發(fā)現(xiàn)寫(xiě)密碼的那張紙了,內(nèi)心狂喜,哈哈!!
                
            本來(lái)想接上次的,寫(xiě)一些關(guān)于渲染器方面的東西,但是因?yàn)檎麄€(gè)渲染器是依賴與BSP進(jìn)行操作的,而且QUAKE中的碰撞檢測(cè)也是依賴與BSP樹(shù)的,因此先寫(xiě)一些關(guān)于BSP樹(shù)方面的基礎(chǔ)東西,以利于大家有個(gè)比較具體的印象,希望能夠?qū)懙谋容^通俗易懂吧。
                
            事實(shí)上,前天我寫(xiě)了將近500字的BSP編譯器的分析的文章,發(fā)現(xiàn)好象如果直接寫(xiě)編譯器這個(gè)核心東西,可能需要一些關(guān)于QUAKEBSP的相關(guān)理論的和基礎(chǔ)的東西,特別是QQ上有個(gè)朋友和我說(shuō),他研究QUAKE2的渲染器代碼已經(jīng)很久了,但是有些函數(shù)看了半年還是看不懂,哈哈,其實(shí)這和我以前的感覺(jué)一樣。為什么呢,因?yàn)閷?shí)在網(wǎng)絡(luò)資料很少,如果你不從Q3MAP這個(gè)源代碼以及關(guān)卡編輯器產(chǎn)生的結(jié)果數(shù)據(jù)和GAME.DLL模塊中以SP_開(kāi)頭的函數(shù)進(jìn)行分析的話,BSP永遠(yuǎn)都是一知半解的,那是因?yàn)椴恢?span>BSP
            生成的原理,所以很多東西都看不懂。所以決定了,先從結(jié)果推導(dǎo)BSP的編譯原理,當(dāng)然我想這是一個(gè)非常大的代碼分析,基本上最起碼可以寫(xiě)15000字以上的文章了,呵呵,反正現(xiàn)在有的是時(shí)間,就慢慢寫(xiě)吧
            二:分析生成BSP后的文件結(jié)構(gòu):
                 BSP
            事實(shí)上分為三個(gè)部分,第一部分是關(guān)卡編輯器生成.map的文件格式(Q3RADIANT),第二部分是通過(guò)Q3MAP.map的文件格式編譯成.BSP格式,對(duì)于BSP文件而言,我們可以將BSP格式的文件數(shù)據(jù)分成兩個(gè)大類(lèi),即用于渲染用的數(shù)據(jù)和用于碰撞檢測(cè)的數(shù)據(jù)(QUAKE3里面稱為CLIPMAP),至于編譯過(guò)程就是一個(gè)流水線式的操作,要進(jìn)行多次步驟產(chǎn)生結(jié)果. 第三部分是操作BSP,關(guān)于BSP的操作,以后我慢慢來(lái)寫(xiě),事實(shí)上是非常非常重要的和好玩的東東.
               
            在這里我只想簡(jiǎn)單說(shuō)一下為什么BSP的文件格式里面包含渲染數(shù)據(jù)和物理碰撞數(shù)據(jù),那是因?yàn)?span>QUAKE3的渲染部分和物理碰撞部分是分離的,這樣的好處是渲染部分是客戶端進(jìn)行調(diào)用的,服務(wù)器端不需要用到渲染模塊,然而碰撞檢測(cè)卻是服務(wù)器端和客戶端都要用到的,所以分離以后就具有很大的靈活性事實(shí)上服務(wù)器是上帝,定義一切規(guī)則和進(jìn)行物理動(dòng)力學(xué)的計(jì)算,而客戶端使用碰撞檢測(cè)是為了進(jìn)行同步服務(wù)器,進(jìn)行客戶端預(yù)測(cè)使用的,這是一個(gè)網(wǎng)絡(luò)端編程的概念,以后進(jìn)行C/S架構(gòu)分析再說(shuō)吧
            : BSP文件結(jié)構(gòu)代碼

             typedef struct {
             int  fileofs, filelen;
            } lump_t;

            typedef struct {
             int   ident;
             int   version;
             lump_t  lumps[HEADER_LUMPS];
            } dheader_t;//

            typedef struct {
             char  shader[MAX_QPATH];
             int   surfaceFlags;//
            絕對(duì)經(jīng)典的東西,還是和q3map一起說(shuō)比較有趣,
             int   contentFlags;//
            絕對(duì)經(jīng)典的東西,還是和q3map一起說(shuō)比較有趣
            } dshader_t; //               lump1

            // planes x^1 is allways the opposite of plane x

            typedef struct {
             float  normal[3];
             float  dist;
            } dplane_t; //              lump2

            typedef struct {
             int   planeNum;
             int   children[2]; // negative numbers are -(leafs+1), not nodes
             int   mins[3];  // for frustom culling
             int   maxs[3];
            } dnode_t; //                lump3

            typedef struct {
             int   cluster;   // -1 = opaque cluster (do I still store these?)
             int   area;
             int   mins[3];   // for frustum culling
             int   maxs[3];
             int   firstLeafSurface;
             int   numLeafSurfaces;
             //
            用于碰撞檢測(cè),不用于渲染模塊
             int   firstLeafBrush;
             int   numLeafBrushes;
            } dleaf_t; //                lump4

            int leafsurfaces; // lump5
            int leafbrushes; //lump6

            typedef struct {
             float          mins[3], maxs[3];
             int   firstSurface, numSurfaces;

            //下面的變量用于碰撞檢測(cè)用
             int   firstBrush, numBrushes;
            } dmodel_t;//        lump7

            typedef struct {
             int   firstSide;
             int   numSides;
             int   shaderNum;   // the shader that determines the contents flags
            } dbrush_t;// lump8

            typedef struct {
             int   planeNum; // positive plane side faces out of the leaf
             int   shaderNum;
            } dbrushside_t;// lump9

             

            typedef struct {
             vec3_t  xyz;
             float  st[2];
             float  lightmap[2];
             vec3_t  normal;
             byte  color[4];
            } drawVert_t;//      lump10

            int drawIndexes; // lump11

            typedef struct {
             char  shader[MAX_QPATH];
             int   brushNum;
             int   visibleSide; // the brush side that ray tests need to clip against (-1 == none)
            } dfog_t;//        lump12

            //對(duì)表面類(lèi)型進(jìn)行總結(jié),具體見(jiàn)下面

            typedef enum {
             MST_BAD,
             MST_PLANAR,//
            很重要的,說(shuō)明該表面是一個(gè)世界的靜態(tài)表面,例如墻面,地板等,可以通

            //過(guò)brushside計(jì)算出來(lái)
             MST_PATCH,//
            二次貝塞爾表面,要進(jìn)行相應(yīng)三角型化,要求速度的話,可以使用前向差分

            //算法,二次貝塞爾使用9個(gè)控制點(diǎn)插值計(jì)算
             MST_TRIANGLE_SOUP,//
            用于BMODEL的表面,可以進(jìn)行三角形扇或帶化或頂點(diǎn)索引三角形

            //如果要了解具體算法,可以參考一些計(jì)算幾何的算法,如果有足夠

            //深厚的功力,建議參考nvstriper相關(guān)代碼,還有關(guān)于計(jì)算幾何或

            //拓拔方面的知識(shí),網(wǎng)絡(luò)上有一個(gè)很好的庫(kù)ttl,里面有篇實(shí)現(xiàn)的論

            //文,關(guān)于gmap概念以及使用半邊結(jié)構(gòu)進(jìn)行各種拓拔查找以及修改,

            //絕對(duì)經(jīng)典的東西
             MST_FLARE //
            實(shí)際上就是公告版,因該都會(huì)使用吧
            } mapSurfaceType_t;

            typedef struct {
             int   shaderNum;//
            索引指向shaderlump
             int   fogNum;//
            索引指向foglump
             int   surfaceType;// mapSurfaceType_t,
            具體說(shuō)明見(jiàn)上

             int   firstVert;//索引指向drawVert_tlump
             int   numVerts;

             int   firstIndex;//索引指向頂點(diǎn)索引lump
             int   numIndexes;

            //下面一些變量和靜態(tài)lightmap相關(guān),事實(shí)上現(xiàn)在的圖形硬件足夠快,靜態(tài)光照?qǐng)D相關(guān)算

            //法已有沒(méi)落的趨勢(shì),事實(shí)上現(xiàn)在比較先進(jìn)的引擎都是全動(dòng)態(tài)光照,通過(guò)BSP進(jìn)行場(chǎng)景管理

            //可以非常高效的實(shí)現(xiàn),使渲染效果大幅度提高。這部分是我最感興趣的部分,以后有機(jī)會(huì)

            //可以探討一下,但是必須要對(duì)BSP相關(guān)操作有非常的了解才可以深入

             int   lightmapNum;
             int   lightmapX, lightmapY;
             int   lightmapWidth, lightmapHeight;

             vec3_t          lightmapOrigin;
             vec3_t          lightmapVecs[3];   // for patches, [0] and [1] are lodbounds

            //下面兩個(gè)變量用于貝塞爾曲面

             int   patchWidth;
             int   patchHeight;
            } dsurface_t;//       lump13

            byte lightBytes; //        lump14

            byte lightgridData;//      lump15

            byte visBytes;//          lump16

             

            這里我列出bsp文件格式的各個(gè)lump,除了entity這個(gè)比較特別的lump,這個(gè)留到q3map再說(shuō),是比較特別一個(gè)東東。還有就是具體表面,bmodel以及著名的brush/side等之間的關(guān)系,以及shader各個(gè)元素還是下次再寫(xiě)把,發(fā)現(xiàn)寫(xiě)東西還真是很費(fèi)腦子的拉,今天就先到這里了.

            posted on 2008-01-27 21:48 落魄江湖 閱讀(5483) 評(píng)論(7)  編輯 收藏 引用

            評(píng)論

            # re: QUAKE系列引擎以及基于QUAKE擴(kuò)展引擎的源代碼全面分析(三) --bsp文件格式分析1 2008-01-28 15:33

            寫(xiě)的很不錯(cuò),期待更核心的內(nèi)容。
            提個(gè)建議:如果能從模塊的角度先分析Quake的大結(jié)構(gòu),我想更能讓別人好理解。
            我是學(xué)生,近來(lái)都一直在看Quake3 1.32b,雖然看不透,但還是學(xué)了不少東西。  回復(fù)  更多評(píng)論   

            # re: QUAKE系列引擎以及基于QUAKE擴(kuò)展引擎的源代碼全面分析(三) --bsp文件格式分析1 2008-01-29 21:42 LOGOS

            今天的lump的介紹有點(diǎn)簡(jiǎn)單,只是貼代碼,有種一筆帶過(guò)的感覺(jué)  回復(fù)  更多評(píng)論   

            # re: QUAKE系列引擎以及基于QUAKE擴(kuò)展引擎的源代碼全面分析(三) --bsp文件格式分析1 2008-02-01 10:04 daids

            終于更新了啊  回復(fù)  更多評(píng)論   

            # re: QUAKE系列引擎以及基于QUAKE擴(kuò)展引擎的源代碼全面分析(三) --bsp文件格式分析1 2008-03-05 17:20 lovebird

            為什么不按照當(dāng)初自己設(shè)定的思路一步一步分析呢?  回復(fù)  更多評(píng)論   

            # re: QUAKE系列引擎以及基于QUAKE擴(kuò)展引擎的源代碼全面分析(三) --bsp文件格式分析1 2008-04-04 17:11 stevevan

            支持你!期待更新  回復(fù)  更多評(píng)論   

            # re: QUAKE系列引擎以及基于QUAKE擴(kuò)展引擎的源代碼全面分析(三) --bsp文件格式分析1 2008-04-14 16:40 dfsd


            [url=http://blog.0dfsdfo.cn]搜索引擎優(yōu)化博客[/url]
              回復(fù)  更多評(píng)論   

            # re: QUAKE系列引擎以及基于QUAKE擴(kuò)展引擎的源代碼全面分析(三) --bsp文件格式分析1 2008-08-05 00:03 aBC

            呵呵,終于寫(xiě)不下去了吧  回復(fù)  更多評(píng)論   


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            99国产精品久久| 久久中文字幕一区二区| 久久久高清免费视频| 久久久久久亚洲精品影院| 国产亚洲精品久久久久秋霞| 婷婷久久久亚洲欧洲日产国码AV| 国产麻豆精品久久一二三| 国产免费久久精品99久久| 一本久久a久久精品综合香蕉 | 性做久久久久久久| 久久精品国产99国产精偷| 伊色综合久久之综合久久| 99久久国产热无码精品免费| 亚洲另类欧美综合久久图片区| www性久久久com| 亚洲国产小视频精品久久久三级| 亚洲狠狠婷婷综合久久久久| 久久人人爽人爽人人爽av| 久久精品视频免费| 久久精品毛片免费观看| 久久婷婷午色综合夜啪| 精品久久久久久无码国产| 久久亚洲春色中文字幕久久久 | 精品国产乱码久久久久久1区2区 | 伊人伊成久久人综合网777| 久久综合久久久| www.久久热.com| AV狠狠色丁香婷婷综合久久| 伊人久久精品无码av一区 | 亚洲乱码中文字幕久久孕妇黑人| 久久人人爽人人爽人人片AV东京热| 久久婷婷五月综合色高清| 亚洲综合日韩久久成人AV| 思思久久99热只有频精品66 | 精品国产乱码久久久久软件| 久久久久无码精品国产app| 国产日韩久久免费影院| 国产一区二区三精品久久久无广告| 国产精品免费福利久久| 国产精品18久久久久久vr| 国产99精品久久|