青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

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

常用鏈接

統(tǒng)計(jì)

最新評(píng)論

置頂隨筆 #

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

 

一:一些廢話  
   
好久沒(méi)更新了,一方面是年底了,對(duì)于做銷售的人來(lái)說(shuō),利用這段時(shí)間出出差,拜訪拜訪經(jīng)銷商以及KA客戶,目的是確定明年的銷售指標(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è)大類,即用于渲染用的數(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ì)表面類型進(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 @ 2008-01-27 21:48 落魄江湖 閱讀(5508) | 評(píng)論 (7)編輯 收藏

[置頂]QUAKE系列引擎以及基于QUAKE擴(kuò)展引擎的源代碼全面分析(二)

    本來(lái)想直接進(jìn)入quake源碼分析,但發(fā)現(xiàn)如果沒(méi)有好的寫(xiě)作框架,就憑QUAKE引擎這么大的代碼群,真的很難寫(xiě)的,所以決定先搭一個(gè)分析框架,定義好各個(gè)章節(jié),爭(zhēng)取在本周內(nèi)全部完成該工作,然后從下個(gè)禮拜開(kāi)始就往分析框架里面填寫(xiě)內(nèi)容了!哈哈!!
     聲明:1。本人從未進(jìn)入程序員行列,只是喜好才寫(xiě)這些文章的,所以在文章寫(xiě)作過(guò)程中,有任何技術(shù)性的錯(cuò)誤,以及沒(méi)有甬道正確的術(shù)語(yǔ),請(qǐng)見(jiàn)諒(因?yàn)楹芏鄎uake中的術(shù)語(yǔ)都是我自己定義的)
                2。在整體的分析過(guò)程中,并不一定按照目錄所定義好的順序來(lái)寫(xiě)的,想到什么就寫(xiě)什么,這就是博客的精神把!!整個(gè)目錄框架是分析的思路,可能會(huì)改變。
                3。在目錄各個(gè)章節(jié)都是主題的定義,我會(huì)在空閑時(shí)間慢慢的填進(jìn)去的,希望能夠最終堅(jiān)持下來(lái)形成一整套關(guān)于quake系列比較系統(tǒng)的文擋。
                4。 本人的目的是在中國(guó)形成一個(gè)比較活躍的以quake為基礎(chǔ)的社群,希望更多的人了解quake的精神,我想在中國(guó)研究quake引擎的人應(yīng)該很多,高手更是不少,但是在中國(guó)的網(wǎng)絡(luò)上卻看不到系統(tǒng)的quake源碼分析,不知道為什么??所以由本人,一個(gè)不在程序員序列的圖形學(xué)愛(ài)好者來(lái)稍微引導(dǎo)一下。由于本人不屬于程序員,因此也更本沒(méi)有所謂違反某個(gè)軟件公司的知識(shí)產(chǎn)權(quán),具有更大的靈活性,希望其他地方的各個(gè)quake高手進(jìn)行完善與修整本人所寫(xiě)的東東。
             5。 本人渴望與從事游戲行業(yè)的程序員進(jìn)行交流。由于本人的生活圈子與程序員根本不搭界,所以沒(méi)有機(jī)會(huì)和從事游戲設(shè)計(jì)的人員進(jìn)行交流,很郁悶啊。很想了解一下現(xiàn)在的圖形學(xué)在中國(guó)處于什么狀態(tài),各個(gè)游戲公司底層的引擎是自己開(kāi)發(fā)的還是使用開(kāi)源的或則是購(gòu)買世界著名的游戲引擎。希望能有機(jī)會(huì)與各位交流,本人的qq號(hào)碼是47178234,本人生活在上海,如果有上海的高手,我們可以多多交流,時(shí)而可以face to face的交流拉,以增加對(duì)程序員生活的真正了解!! 

目錄:

 第一章:QUAKE引擎的整體框架結(jié)構(gòu):

         1.引擎和API的精確定義

         2.整個(gè)quake引擎是基于C/S模式

         3.各個(gè)模塊間的關(guān)系圖

         4.客戶端如何與服務(wù)器端相連接(網(wǎng)絡(luò)消息的傳遞與響應(yīng)以及客戶端數(shù)據(jù)庫(kù)的產(chǎn)生)

         5.當(dāng)客戶端連接到服務(wù)器后如何進(jìn)入游戲狀態(tài)的流程(即玩家的產(chǎn)生)

         6.當(dāng)客戶端死亡后重生的流程

         7.簡(jiǎn)要說(shuō)明進(jìn)入游戲狀態(tài)后一幀運(yùn)行的流程,包括各個(gè)模塊函數(shù)調(diào)用的示意圖                  

 第二章:渲染器(refresh模塊)

         1. 兩個(gè)重要的由外部操作的結(jié)構(gòu)(refEntity_trefdef_t)以及這些結(jié)構(gòu)各個(gè)值域的詳細(xì)解釋

         2.渲染器模塊導(dǎo)出函數(shù)(API)的分類以及作用(quake3-1.32b原代碼為準(zhǔn))

            A:渲染數(shù)據(jù)資源管理函數(shù)集(12個(gè)函數(shù),資源包括BSP世界數(shù)據(jù),模型數(shù)據(jù),shader數(shù)據(jù),skin數(shù)據(jù),vis數(shù)據(jù)以及字體)

            B:設(shè)置渲染命令流水線的函數(shù)集(4個(gè)函數(shù))

            C:場(chǎng)景管理以及渲染的函數(shù)集(7個(gè)函數(shù))

            D:其他函數(shù)集(6個(gè)函數(shù))總計(jì)29個(gè)導(dǎo)出函數(shù)

         3Quake3 渲染器的整體結(jié)構(gòu):

            AQUAKE3渲染器是以OPENGL為基礎(chǔ)并支持雙處理器并行運(yùn)算的

            BQUAKE3渲染器在渲染過(guò)程中可以分為前端部分和后端部分(圖解),他們是如何協(xié)調(diào)起來(lái)的。

            C: QUAKE3是如何支持雙處理器并行進(jìn)行渲染

         4.對(duì)quake3模型系統(tǒng)的擴(kuò)展(使用MD5模型格式以及skm模型格式)

            A: 為什么不用MD3模型

            BMD5&SKM骨骼模型的格式分析

            C:骨骼動(dòng)畫(huà)的原理以及應(yīng)用

(1)       骨骼動(dòng)畫(huà)的分類(boneoffset類型和vertexoffset類型的詳解以及各自的優(yōu)缺點(diǎn))

(2)       詳細(xì)分析骨骼動(dòng)畫(huà)數(shù)學(xué)原理

(3)       在定義骨骼動(dòng)畫(huà)的時(shí)候需要詳細(xì)考慮的一些問(wèn)題以及目的,不同的目的會(huì)有不同的編碼方式

(4)       重點(diǎn)分析SKM骨骼動(dòng)畫(huà)在warsow游戲中的運(yùn)用以及編碼方式

(5)       骨骼動(dòng)畫(huà)的CPU實(shí)現(xiàn)和GPU實(shí)現(xiàn)的優(yōu)缺點(diǎn)分析以及如何平衡各自的優(yōu)缺點(diǎn)

(6)       附我的計(jì)劃:市面上公開(kāi)格式的骨骼動(dòng)畫(huà)事實(shí)上在渲染原理上基本差別不是很大,因此在學(xué)習(xí)骨骼動(dòng)畫(huà)的過(guò)程中,感受很多啊,現(xiàn)在本人正在進(jìn)行系統(tǒng)設(shè)計(jì),根據(jù)骨骼動(dòng)畫(huà)的原理,參考相關(guān)資料,提煉出一條骨骼動(dòng)畫(huà)統(tǒng)一渲染流水線。完成后公開(kāi)源代碼。系統(tǒng)設(shè)計(jì)的要求是

(A)       可以直接并入quake3引擎的多核渲染流水線

(B)       使用CPU實(shí)現(xiàn)的,以SIMD為基礎(chǔ)數(shù)學(xué)運(yùn)算(因?yàn)?span lang=EN-US>CPU實(shí)現(xiàn)進(jìn)行轉(zhuǎn)化后可以直接獲得頂點(diǎn)數(shù)據(jù)再進(jìn)行陰影系統(tǒng)的繪制,而GPU數(shù)據(jù)的取回比較麻煩,再說(shuō)本人也沒(méi)有支持D3D10版本的GPU,無(wú)法使用新增加的stream output statge以及幾何shader

(C)       能夠在運(yùn)行過(guò)程中人工控制各個(gè)骨頭的運(yùn)動(dòng)

(D)       使用統(tǒng)一的骨骼動(dòng)畫(huà)渲染流水線,使模型與數(shù)據(jù)相分離,并且將陰影系統(tǒng)并入該渲染流水線。

 

         5BSP文件格式以及QUAKE3 SHADER文件格式


今天就寫(xiě)到目錄的前兩章,計(jì)劃在本周內(nèi)將所有章節(jié)全部定義出來(lái),然后再填寫(xiě)各個(gè)小節(jié)的內(nèi)容
                                                                                
           

 

posted @ 2007-11-20 16:28 落魄江湖 閱讀(5668) | 評(píng)論 (8)編輯 收藏

2008年1月27日 #

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

 

一:一些廢話  
   
好久沒(méi)更新了,一方面是年底了,對(duì)于做銷售的人來(lái)說(shuō),利用這段時(shí)間出出差,拜訪拜訪經(jīng)銷商以及KA客戶,目的是確定明年的銷售指標(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è)大類,即用于渲染用的數(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ì)表面類型進(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 @ 2008-01-27 21:48 落魄江湖 閱讀(5508) | 評(píng)論 (7)編輯 收藏

2007年11月20日 #

QUAKE系列引擎以及基于QUAKE擴(kuò)展引擎的源代碼全面分析(二)

    本來(lái)想直接進(jìn)入quake源碼分析,但發(fā)現(xiàn)如果沒(méi)有好的寫(xiě)作框架,就憑QUAKE引擎這么大的代碼群,真的很難寫(xiě)的,所以決定先搭一個(gè)分析框架,定義好各個(gè)章節(jié),爭(zhēng)取在本周內(nèi)全部完成該工作,然后從下個(gè)禮拜開(kāi)始就往分析框架里面填寫(xiě)內(nèi)容了!哈哈!!
     聲明:1。本人從未進(jìn)入程序員行列,只是喜好才寫(xiě)這些文章的,所以在文章寫(xiě)作過(guò)程中,有任何技術(shù)性的錯(cuò)誤,以及沒(méi)有甬道正確的術(shù)語(yǔ),請(qǐng)見(jiàn)諒(因?yàn)楹芏鄎uake中的術(shù)語(yǔ)都是我自己定義的)
                2。在整體的分析過(guò)程中,并不一定按照目錄所定義好的順序來(lái)寫(xiě)的,想到什么就寫(xiě)什么,這就是博客的精神把!!整個(gè)目錄框架是分析的思路,可能會(huì)改變。
                3。在目錄各個(gè)章節(jié)都是主題的定義,我會(huì)在空閑時(shí)間慢慢的填進(jìn)去的,希望能夠最終堅(jiān)持下來(lái)形成一整套關(guān)于quake系列比較系統(tǒng)的文擋。
                4。 本人的目的是在中國(guó)形成一個(gè)比較活躍的以quake為基礎(chǔ)的社群,希望更多的人了解quake的精神,我想在中國(guó)研究quake引擎的人應(yīng)該很多,高手更是不少,但是在中國(guó)的網(wǎng)絡(luò)上卻看不到系統(tǒng)的quake源碼分析,不知道為什么??所以由本人,一個(gè)不在程序員序列的圖形學(xué)愛(ài)好者來(lái)稍微引導(dǎo)一下。由于本人不屬于程序員,因此也更本沒(méi)有所謂違反某個(gè)軟件公司的知識(shí)產(chǎn)權(quán),具有更大的靈活性,希望其他地方的各個(gè)quake高手進(jìn)行完善與修整本人所寫(xiě)的東東。
             5。 本人渴望與從事游戲行業(yè)的程序員進(jìn)行交流。由于本人的生活圈子與程序員根本不搭界,所以沒(méi)有機(jī)會(huì)和從事游戲設(shè)計(jì)的人員進(jìn)行交流,很郁悶啊。很想了解一下現(xiàn)在的圖形學(xué)在中國(guó)處于什么狀態(tài),各個(gè)游戲公司底層的引擎是自己開(kāi)發(fā)的還是使用開(kāi)源的或則是購(gòu)買世界著名的游戲引擎。希望能有機(jī)會(huì)與各位交流,本人的qq號(hào)碼是47178234,本人生活在上海,如果有上海的高手,我們可以多多交流,時(shí)而可以face to face的交流拉,以增加對(duì)程序員生活的真正了解!! 

目錄:

 第一章:QUAKE引擎的整體框架結(jié)構(gòu):

         1.引擎和API的精確定義

         2.整個(gè)quake引擎是基于C/S模式

         3.各個(gè)模塊間的關(guān)系圖

         4.客戶端如何與服務(wù)器端相連接(網(wǎng)絡(luò)消息的傳遞與響應(yīng)以及客戶端數(shù)據(jù)庫(kù)的產(chǎn)生)

         5.當(dāng)客戶端連接到服務(wù)器后如何進(jìn)入游戲狀態(tài)的流程(即玩家的產(chǎn)生)

         6.當(dāng)客戶端死亡后重生的流程

         7.簡(jiǎn)要說(shuō)明進(jìn)入游戲狀態(tài)后一幀運(yùn)行的流程,包括各個(gè)模塊函數(shù)調(diào)用的示意圖                  

 第二章:渲染器(refresh模塊)

         1. 兩個(gè)重要的由外部操作的結(jié)構(gòu)(refEntity_trefdef_t)以及這些結(jié)構(gòu)各個(gè)值域的詳細(xì)解釋

         2.渲染器模塊導(dǎo)出函數(shù)(API)的分類以及作用(quake3-1.32b原代碼為準(zhǔn))

            A:渲染數(shù)據(jù)資源管理函數(shù)集(12個(gè)函數(shù),資源包括BSP世界數(shù)據(jù),模型數(shù)據(jù),shader數(shù)據(jù),skin數(shù)據(jù),vis數(shù)據(jù)以及字體)

            B:設(shè)置渲染命令流水線的函數(shù)集(4個(gè)函數(shù))

            C:場(chǎng)景管理以及渲染的函數(shù)集(7個(gè)函數(shù))

            D:其他函數(shù)集(6個(gè)函數(shù))總計(jì)29個(gè)導(dǎo)出函數(shù)

         3Quake3 渲染器的整體結(jié)構(gòu):

            AQUAKE3渲染器是以OPENGL為基礎(chǔ)并支持雙處理器并行運(yùn)算的

            BQUAKE3渲染器在渲染過(guò)程中可以分為前端部分和后端部分(圖解),他們是如何協(xié)調(diào)起來(lái)的。

            C: QUAKE3是如何支持雙處理器并行進(jìn)行渲染

         4.對(duì)quake3模型系統(tǒng)的擴(kuò)展(使用MD5模型格式以及skm模型格式)

            A: 為什么不用MD3模型

            BMD5&SKM骨骼模型的格式分析

            C:骨骼動(dòng)畫(huà)的原理以及應(yīng)用

(1)       骨骼動(dòng)畫(huà)的分類(boneoffset類型和vertexoffset類型的詳解以及各自的優(yōu)缺點(diǎn))

(2)       詳細(xì)分析骨骼動(dòng)畫(huà)數(shù)學(xué)原理

(3)       在定義骨骼動(dòng)畫(huà)的時(shí)候需要詳細(xì)考慮的一些問(wèn)題以及目的,不同的目的會(huì)有不同的編碼方式

(4)       重點(diǎn)分析SKM骨骼動(dòng)畫(huà)在warsow游戲中的運(yùn)用以及編碼方式

(5)       骨骼動(dòng)畫(huà)的CPU實(shí)現(xiàn)和GPU實(shí)現(xiàn)的優(yōu)缺點(diǎn)分析以及如何平衡各自的優(yōu)缺點(diǎn)

(6)       附我的計(jì)劃:市面上公開(kāi)格式的骨骼動(dòng)畫(huà)事實(shí)上在渲染原理上基本差別不是很大,因此在學(xué)習(xí)骨骼動(dòng)畫(huà)的過(guò)程中,感受很多啊,現(xiàn)在本人正在進(jìn)行系統(tǒng)設(shè)計(jì),根據(jù)骨骼動(dòng)畫(huà)的原理,參考相關(guān)資料,提煉出一條骨骼動(dòng)畫(huà)統(tǒng)一渲染流水線。完成后公開(kāi)源代碼。系統(tǒng)設(shè)計(jì)的要求是

(A)       可以直接并入quake3引擎的多核渲染流水線

(B)       使用CPU實(shí)現(xiàn)的,以SIMD為基礎(chǔ)數(shù)學(xué)運(yùn)算(因?yàn)?span lang=EN-US>CPU實(shí)現(xiàn)進(jìn)行轉(zhuǎn)化后可以直接獲得頂點(diǎn)數(shù)據(jù)再進(jìn)行陰影系統(tǒng)的繪制,而GPU數(shù)據(jù)的取回比較麻煩,再說(shuō)本人也沒(méi)有支持D3D10版本的GPU,無(wú)法使用新增加的stream output statge以及幾何shader

(C)       能夠在運(yùn)行過(guò)程中人工控制各個(gè)骨頭的運(yùn)動(dòng)

(D)       使用統(tǒng)一的骨骼動(dòng)畫(huà)渲染流水線,使模型與數(shù)據(jù)相分離,并且將陰影系統(tǒng)并入該渲染流水線。

 

         5BSP文件格式以及QUAKE3 SHADER文件格式


今天就寫(xiě)到目錄的前兩章,計(jì)劃在本周內(nèi)將所有章節(jié)全部定義出來(lái),然后再填寫(xiě)各個(gè)小節(jié)的內(nèi)容
                                                                                
           

 

posted @ 2007-11-20 16:28 落魄江湖 閱讀(5668) | 評(píng)論 (8)編輯 收藏

2007年11月19日 #

QUAKE系列引擎以及基于QUAKE擴(kuò)展引擎的源代碼全面分析(一)

QUAKE系列引擎以及基于QUAKE擴(kuò)展引擎的源代碼全面分析()

前言:

一:研究quake系列引擎斷斷續(xù)續(xù)也已經(jīng)兩年有余了,一直想寫(xiě)點(diǎn)什么,但是真的到了那一步,又發(fā)現(xiàn)其實(shí)很難下筆,原因有三:1 文筆不流暢,特別是技術(shù)性技巧的缺乏,概念難以精確定義,無(wú)法想內(nèi)心的真實(shí)表達(dá)轉(zhuǎn)換為文字,郁悶啊!!2 QUAKE系列引擎的龐大結(jié)構(gòu)以及各個(gè)模塊的協(xié)作關(guān)系,真的想寫(xiě)的時(shí)候不知道如何組織,導(dǎo)致思路極其紊亂。3 對(duì)于QUAKE系列的深?yuàn)W部分,列如bsp的編譯程序部分的源碼還未完全理解,這是整個(gè)QUAKE引擎的核心部分,這是QUAKE系列引擎最核心的部分,可以說(shuō),整個(gè)QUAKE系列引擎就是圍繞這張圖推進(jìn)的。雖然BSP的生成確實(shí)是一個(gè)非常非常難的難點(diǎn),好在使用起BSP來(lái)相對(duì)比較簡(jiǎn)單,即使不知道如何生成,但至少可以靈活使用,偉大的慷慨的卡馬克。

   二:QUAKE系列的引擎源碼分析涉及到的引擎包括如下幾個(gè):

           1  QUAKE1 及其基于   QUAKE1框架的擴(kuò)展引擎DARKPLACES

           2  QUAKE2 及其基于 QUAKE2 框架的擴(kuò)展引擎 QFUSION

           3  QUAKE3及其基于 QUAKE3 框架的擴(kuò)展引擎  XREAL/EVQ3 

   三:為什么要使用上述的擴(kuò)展引擎?

1         QUAKE系列引擎畢竟時(shí)間久遠(yuǎn),現(xiàn)代硬件技術(shù)的發(fā)展以及渲染方面的新概念,新技術(shù)的出現(xiàn),一些擴(kuò)展引擎更加貼近當(dāng)今世界技術(shù)發(fā)展的潮流。例如這三個(gè)引擎都增加了GLSL進(jìn)行相應(yīng)的擴(kuò)展。

2         這些擴(kuò)展引擎都是非常著名的開(kāi)源項(xiàng)目,資料比較多,而且都有相應(yīng)使用這些擴(kuò)展引擎作成的游戲,可以觀看到游戲?qū)崟r(shí)效果。

例如基于DARKPLACES引擎的游戲—NEXUIZ,渲染效果極其驚人啊!!!

    基于 QFUSION 引擎的游戲-----WARSOW

基于 XREAL/EVQ3引擎的游戲-----REVOLUTION

3         對(duì)上述三個(gè)擴(kuò)展引擎的感受

A:DARKPLACES使用QUAKE1的框架結(jié)構(gòu),重寫(xiě)了全部的渲染模塊,網(wǎng)絡(luò)協(xié)議以及傳輸模塊,支持DOOM3類型的光影特效,根據(jù)我的感覺(jué),應(yīng)該是渲染效果最好的開(kāi)源的項(xiàng)目,使用到了相當(dāng)多的特效(DOOM3光影特效=Stencil Shadow Volume, Per Pixel Lighting, NormalizationCubeMap, 2D+1D Attenuation Texturing, and Light Projection Filtering.該引擎可以使用著名的QUAKEC進(jìn)行服務(wù)器端游戲邏輯的開(kāi)發(fā)(相當(dāng)于QUAKE3中的GAME.DLL模塊),同時(shí)相對(duì)于QUAKE1QUAKEC內(nèi)置函數(shù),該引擎擴(kuò)展了相當(dāng)多的服務(wù)器端QUAKEC函數(shù).更漂亮的是他同時(shí)擴(kuò)展了客戶端邏輯部分的函數(shù),通過(guò)這些函數(shù)可以編寫(xiě)客戶端游戲邏輯(相當(dāng)于QUAKE3中的CGAME.DLL模塊,但不完全等同).事實(shí)上本人是非常喜歡QUAKEC的編碼方式,簡(jiǎn)練而強(qiáng)大.

B:QFUSION引擎最大的特點(diǎn)是他的邏輯結(jié)構(gòu)非常清晰,他所擴(kuò)展的骨骼動(dòng)畫(huà)系統(tǒng)是其最大的特點(diǎn).本人的感覺(jué)是極其漂亮(當(dāng)然每個(gè)人的觀點(diǎn)不同,這只是本人的觀點(diǎn)罷了).他使用了skm骨骼動(dòng)畫(huà)文件格式.正是通過(guò)該引擎的骨骼動(dòng)畫(huà)系統(tǒng),讓本人完全掌握整個(gè)骨骼動(dòng)畫(huà)的精髓,真是收益非淺啊!!!而且整個(gè)游戲邏輯端非常清晰,在代碼分析時(shí)候主要以該引擎作為原代碼基礎(chǔ).

C:xreal/evq3整體框架與quake3變化不大,但是最重要的一點(diǎn)是,本人最喜歡的渲染器結(jié)構(gòu)是quake3render.dll,簡(jiǎn)直是太完美了,quake3的渲染器可以使用雙處理器,為了支持雙處理器的運(yùn)作,quake3自己實(shí)現(xiàn)了一條渲染命令流水線,及其完美,收益非淺啊!!!!又要說(shuō)一句非常重要的話了,偉大的慷慨的卡馬克.而引xreal/evq3擎完美的保留了quake3的渲染器框架結(jié)構(gòu)同時(shí)擴(kuò)展了較多的功能,光影特效足夠強(qiáng)大.增加了md5骨骼模型的渲染.在以后渲染器代碼分析時(shí)候,主要以該擴(kuò)展引擎為基礎(chǔ)結(jié)合darkplaces引擎的相關(guān)技術(shù).

 

 

        

      總體而言, quake系列引擎的整體架構(gòu)非常漂亮,是學(xué)習(xí)的好材料,并且從quake1quake3,整體邏輯端代碼變化不大, 真正比較有突破性的是渲染引擎.本人在學(xué)習(xí)quake引擎過(guò)程中常常敬佩卡馬克的想象力,api函數(shù)是如此之簡(jiǎn)潔,整體框架是如此之完美,面向?qū)ο蟮?/span>c寫(xiě)得如此之漂亮,通過(guò)quake引擎,可以學(xué)到游戲設(shè)計(jì)的各個(gè)概念以及各個(gè)模塊,外部工具是如何完美的結(jié)合起來(lái),這一點(diǎn)是非常非常重要的.

     

     

    

 

   

     

posted @ 2007-11-19 00:45 落魄江湖 閱讀(7631) | 評(píng)論 (11)編輯 收藏

2007年11月1日 #

第一次寫(xiě)博客(自我介紹,內(nèi)容定位以及疑問(wèn))----3D以及QUAKE

    本人第一次寫(xiě)博客,內(nèi)心誠(chéng)惶誠(chéng)恐。

    首先,介紹一下自己吧。
          1 一個(gè)老男人--今年31歲
          2 一個(gè)從未進(jìn)入編程行業(yè)的老男人--有一份與編程相差十萬(wàn)八千里的工作,程序設(shè)計(jì)僅是個(gè)人愛(ài)好
          3 一個(gè)對(duì)計(jì)算機(jī)圖形學(xué)以及QUAKE系列引擎有著特殊摯愛(ài)的老男人--計(jì)算機(jī)圖形學(xué)是OPENGL,D3D實(shí)   現(xiàn)的基礎(chǔ),而QUAKE系列引擎則對(duì)當(dāng)今世界的3D游戲以及引擎發(fā)展有著深遠(yuǎn)的影響,由于卡馬克的無(wú)私奉獻(xiàn), 讓我們有機(jī)會(huì)領(lǐng)略,了解3D世界的無(wú)限美麗。

     其次,關(guān)于本人博客的內(nèi)容定位
         1 關(guān)注OPENGL的軟件實(shí)現(xiàn)以及應(yīng)用
         2 跟蹤計(jì)算機(jī)圖形學(xué)底層方面的相關(guān)內(nèi)容
         3 交流3D的核心基礎(chǔ)----3D數(shù)學(xué)以及流水線管道相關(guān)內(nèi)容
         4 探討一些開(kāi)源的優(yōu)秀的3D引擎--例如OGRE,IRRLICHT,NEBULA等
         5 當(dāng)然最核心的是共同研究QUAKE系列引擎的架構(gòu),源代碼,MOD以及擴(kuò)展。

     最后,一個(gè)疑問(wèn)
         在GOOGLE上發(fā)現(xiàn)國(guó)外對(duì)QUAKE的研究有非常多的網(wǎng)站,但為什么在中國(guó)卻見(jiàn)不到幾個(gè)啊?
         根據(jù)我對(duì)QUAKE系列的不算專業(yè)的研究,感覺(jué)QUAKE系列引擎是個(gè)巨大的寶庫(kù),可以學(xué)習(xí)到非常多的先進(jìn)技術(shù)和理念,每一個(gè)模塊都可以獨(dú)立出來(lái)成為非常優(yōu)秀的項(xiàng)目。

    這是我第一次寫(xiě)播客,不知道寫(xiě)什么,所以想到什么寫(xiě)什么。上述的內(nèi)容是我現(xiàn)今最感興趣的方面,而且也非常龐大,希望有時(shí)間能夠慢慢的和大家進(jìn)行交流,探討甚至是爭(zhēng)論。

    對(duì)了,還有一件事情需要說(shuō)明:
         本人文筆較差,以前一直想寫(xiě),但是真的要寫(xiě)技術(shù)性文章時(shí)候發(fā)現(xiàn)無(wú)從下筆,因?yàn)榘l(fā)現(xiàn)很難把一些技術(shù)問(wèn)題清晰明了的用文章表達(dá)出來(lái),郁悶!!!所以以后寫(xiě)得不好,就多諒了
        

posted @ 2007-11-01 14:09 落魄江湖 閱讀(3019) | 評(píng)論 (11)編輯 收藏

僅列出標(biāo)題  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲欧美不卡| 亚洲欧美国产另类| 久久高清一区| 亚洲欧洲av一区二区三区久久| 亚洲人成在线播放| 亚洲精品午夜| 亚洲一区观看| 久久精品国产一区二区三| 久久久久天天天天| 亚洲电影在线播放| 欧美激情中文字幕一区二区 | 欧美 日韩 国产精品免费观看| 久久综合九色九九| 欧美成人精品福利| 99国产麻豆精品| 欧美一区二区日韩一区二区| 美女久久网站| 国产精品www.| 在线看日韩欧美| 亚洲一本视频| 欧美mv日韩mv国产网站| 亚洲激情校园春色| 亚洲欧美在线另类| 欧美精品在线一区| 国产视频在线观看一区二区| 亚洲精品乱码久久久久久日本蜜臀| 亚洲小视频在线| 欧美成人精品1314www| 亚洲私拍自拍| 欧美韩日一区二区| 好吊色欧美一区二区三区四区| 日韩视频不卡中文| 久久资源在线| 午夜久久电影网| 欧美三区在线视频| 亚洲黄色成人| 快播亚洲色图| 亚洲一区欧美一区| 欧美另类videos死尸| 尤物精品国产第一福利三区 | 亚洲欧洲日产国产网站| 欧美自拍偷拍午夜视频| 国产精品久久波多野结衣| 91久久香蕉国产日韩欧美9色| 欧美一区二区三区视频| 日韩一区二区精品| 欧美精品一线| 99亚洲一区二区| 欧美激情亚洲一区| 久久午夜精品| 伊人春色精品| 久久婷婷丁香| 久久精品欧美| 国产精品自拍一区| 亚洲女性喷水在线观看一区| 亚洲三级观看| 欧美日韩一级黄| 一本色道久久88综合亚洲精品ⅰ | 亚洲午夜视频在线| 亚洲大片免费看| 免费在线国产精品| 在线观看福利一区| 欧美a级片网| 欧美成黄导航| 99精品国产福利在线观看免费 | 久久久www成人免费毛片麻豆| 国产无一区二区| 久久久免费精品| 久久久噜噜噜久久狠狠50岁| 在线欧美日韩精品| 亚洲大胆视频| 欧美日韩精品三区| 亚洲综合精品一区二区| 亚洲性夜色噜噜噜7777| 国产精品亚洲美女av网站| 欧美亚洲综合在线| 先锋影音一区二区三区| 在线国产欧美| 最新热久久免费视频| 欧美日韩国产三级| 午夜精品久久久久久久久久久久| 午夜精品久久久久久99热| 国产亚洲精品aa| 欧美激情区在线播放| 欧美日产在线观看| 欧美一区二区成人| 久久天天狠狠| 宅男噜噜噜66一区二区| 午夜精品久久久久久久久 | 午夜久久99| 久久精品首页| 亚洲视频1区2区| 久久精品国产精品亚洲| 99精品国产在热久久下载| 亚洲男人影院| 亚洲美女视频网| 欧美在线观看网站| 亚洲午夜精品一区二区| 久久精品国产第一区二区三区最新章节| 亚洲福利小视频| 亚洲一区在线观看视频| 亚洲欧洲日本专区| 午夜伦欧美伦电影理论片| 亚洲日本理论电影| 午夜精品偷拍| 亚洲图片在线观看| 噜噜噜91成人网| 欧美在线免费观看视频| 欧美激情日韩| 蜜臀久久99精品久久久久久9| 欧美视频导航| 亚洲区欧美区| 久久精品99久久香蕉国产色戒| 先锋资源久久| 这里只有精品在线播放| 裸体一区二区三区| 久久av二区| 国产精品黄视频| 欧美高清视频www夜色资源网| 国产精品视频1区| 一卡二卡3卡四卡高清精品视频| 影音国产精品| 久久gogo国模啪啪人体图| 亚洲欧美福利一区二区| 欧美精品在线免费| 亚洲国产美女| 亚洲日本va在线观看| 久久这里有精品视频| 老司机精品久久| 狠久久av成人天堂| 欧美在线综合视频| 久久精品99久久香蕉国产色戒| 国产精品视频久久一区| 亚洲制服av| 久久精品国产免费观看| 国产精品人人做人人爽| 亚洲一区国产精品| 性做久久久久久久久| 国产精品日韩一区二区三区| 亚洲特级毛片| 欧美呦呦网站| 国产日韩成人精品| 欧美伊人久久| 久久综合电影一区| 亚洲国产精品电影| 欧美国产精品久久| 日韩亚洲不卡在线| 香蕉av福利精品导航| 国产一区二区三区网站| 久久精品免费电影| 亚洲福利视频专区| 亚洲性夜色噜噜噜7777| 国产精品一区二区欧美| 久久国产欧美精品| 免费在线看成人av| 亚洲乱码国产乱码精品精可以看| 欧美日韩另类字幕中文| 亚洲欧美不卡| 免费日韩成人| 中文在线一区| 国产亚洲精品久久久久久| 久久躁日日躁aaaaxxxx| 99在线精品视频| 久久久久综合网| 99天天综合性| 国产一区二区三区黄视频| 免费永久网站黄欧美| 亚洲在线视频| 欧美黄色小视频| 性做久久久久久久免费看| 在线观看欧美亚洲| 欧美性开放视频| 久久五月天婷婷| 亚洲尤物在线| 亚洲区第一页| 美女图片一区二区| 亚洲欧美中文日韩v在线观看| 在线看欧美视频| 国产精品看片你懂得| 免费成人av在线看| 亚洲欧美国产另类| 91久久久久久| 麻豆精品传媒视频| 亚洲欧美国产77777| 久久精品在线免费观看| 亚洲精品女av网站| 国产视频一区欧美| 欧美日韩国产综合久久| 久久精品电影| 亚洲欧美视频| 在线视频你懂得一区| 欧美成人精品高清在线播放| 欧美一区二区精品| 99在线|亚洲一区二区| 亚洲电影专区| 激情久久综合| 国产一区91| 国产视频久久久久| 国产精品伊人日日| 国产精品第十页|