• <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>
            隨筆 - 505  文章 - 1034  trackbacks - 0
            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567


            子曾經曰過:編程無他,唯手熟爾!

            常用鏈接

            留言簿(94)

            隨筆分類(649)

            隨筆檔案(505)

            相冊

            BCB

            Crytek

            • crymod
            • Crytek's Offical Modding Portal

            Game Industry

            OGRE

            other

            Programmers

            Qt

            WOW Stuff

            搜索

            •  

            積分與排名

            • 積分 - 911296
            • 排名 - 14

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            Vertex Formats


            A flexible vertex format (FVF) code describes the contents of vertices stored interleaved in a single data stream. It generally specifies data to be processed by the fixed function vertex processing pipeline.

            Microsoft® Direct3D® applications can define model vertices in several different ways. Support for flexible vertex definitions, also known as flexible vertex formats or flexible vertex format codes, makes it possible for your application to use only the vertex components it needs, eliminating those components that aren't used. By using only the needed vertex components, your application can conserve memory and minimize the processing bandwidth required to render models. You describe how your vertices are formatted by using a combination of D3DFVF.

            The FVF specification includes formats for point size, specified by D3DFVF_PSIZE. This size is expressed in camera space units for non-TL vertices, and in device-space units for TL vertices.

            The rendering methods of the IDirect3DDevice9 interface provides C++ applications with methods that accept a combination of these flags, and uses them to determine how to render primitives. Basically, these flags tell the system which vertex components - position, vertex blending weights, normal, colors, the number and format of texture coordinates - your application uses and, indirectly, which parts of the rendering pipeline you want Direct3D to apply to them. In addition, the presence or absence of a particular vertex format flag communicates to the system which vertex component fields are present in memory and which you've omitted.

            To determine device limitations, you can query a device for the D3DFVFCAPS_DONOTSTRIPELEMENTS and D3DFVFCAPS_TEXCOORDCOUNTMASK flexible vertex format flags. For more information, see the FVFCaps member of the D3DCAPS9 structure.

            One significant requirement that the system places on how you format your vertices is on the order in which the data appears. The following illustration depicts the required order for all possible vertex components in memory, and their associated data types.


            Texture coordinates can be declared in different formats, allowing textures to be addressed using as few as one coordinate or as many as four texture coordinates (for 2-D projected texture coordinates). For more information, see Texture Coordinate Formats. Use the D3DFVF_TEXCOORDSIZEn set of macros to create bit patterns that identify the texture coordinate formats that your vertex format uses.

            No application will use every component - the reciprocal homogeneous W (RHW) and vertex normal fields are mutually exclusive. Nor will most applications try to use all eight sets of texture coordinates, but Direct3D has this capacity. There are several restrictions on which flags you can use with other flags. For example, you cannot use the D3DFVF_XYZ and D3DFVF_XYZRHW flags together, as this would indicate that your application is describing a vertex's position with both untransformed and transformed vertices.

            To use indexed vertex blending, the D3DFVF_LASTBETA_UBYTE4 flag should appear at the end of the FVF. The presence of this flag indicates that the fifth blending weight will be treated as a DWORD instead of float. For more information, see Indexed Vertex Blending.

            The following code samples shows the difference between an FVF code that uses the D3DFVF_LASTBETA_UBYTE4 flag and one that doesn't. The FVF defined below does not use the D3DFVF_LASTBETA_UBYTE4 flag. The flag D3DFVF_XYZ3 is present when four blending indices are used because you always use (1 - the sum of the first three) for the fourth.

            #define D3DFVF_BLENDVERTEX (D3DFVF_XYZB3|D3DFVF_NORMAL|D3DFVF_TEX1)

            struct BLENDVERTEX
            {
                D3DXVECTOR3 v;       
            // Referenced as v0 in the vertex shader
                FLOAT       blend1;  // Referenced as v1.x in the vertex shader
                FLOAT       blend2;  // Referenced as v1.y in the vertex shader
                FLOAT       blend3;  // Referenced as v1.z in the vertex shader
                                     
            // v1.w = 1.0 - (v1.x + v1.y + v1.z)
                D3DXVECTOR3 n;       // Referenced as v3 in the vertex shader
                FLOAT       tu, tv;  // Referenced as v7 in the vertex shader
            };

            The FVF defined below uses the D3DFVF_LAST_UBYTE4 flag.

            #define D3DFVF_BLENDVERTEX (D3DFVF_XYZB4 | D3DFVF_LASTBETA_UBYTE4 |D3DFVF_NORMAL|D3DFVF_TEX1)

            struct BLENDVERTEX
            {
                D3DXVECTOR3 v;       
            // Referenced as v0 in the vertex shader
                FLOAT       blend1;  // Referenced as v1.x in the vertex shader
                FLOAT       blend2;  // Referenced as v1.y in the vertex shader
                FLOAT       blend3;  // Referenced as v1.z in the vertex shader
                                     
            // v1.w = 1.0 - (v1.x + v1.y + v1.z)
                DWORD       indices; // Referenced as v2.xyzw in the vertex shader 
                D3DXVECTOR3 n;       // Referenced as v3 in the vertex shader
                FLOAT       tu, tv;  // Referenced as v7 in the vertex shader
            };

             

            posted on 2009-09-05 01:58 七星重劍 閱讀(2659) 評論(0)  編輯 收藏 引用 所屬分類: Game Graphics
            日韩精品久久久久久久电影蜜臀 | 国产色综合久久无码有码| 日韩欧美亚洲国产精品字幕久久久| 久久精品二区| 久久久久久亚洲精品影院| 久久人人妻人人爽人人爽| 国产精品久久久久久久午夜片 | 亚洲国产精品无码久久久不卡 | 日韩欧美亚洲国产精品字幕久久久 | 久久亚洲AV成人无码软件| 粉嫩小泬无遮挡久久久久久| 久久黄色视频| 曰曰摸天天摸人人看久久久| 久久人人爽人人爽人人片AV麻烦| 久久精品国产亚洲沈樵| 久久久国产打桩机| 精品久久国产一区二区三区香蕉 | 91麻豆国产精品91久久久| 久久综合综合久久97色| 亚洲中文久久精品无码ww16| 青青草原综合久久大伊人精品| 一本一本久久A久久综合精品 | 久久国产精品免费| 精品久久久久久| 国内精品久久久久伊人av| 亚洲香蕉网久久综合影视 | 久久精品国产亚洲沈樵| 久久国产亚洲高清观看| 欧美日韩精品久久久久| 久久免费视频6| 久久精品国产99久久丝袜| 国产精品内射久久久久欢欢| 91久久婷婷国产综合精品青草| 97精品伊人久久大香线蕉| 囯产极品美女高潮无套久久久| 久久久综合香蕉尹人综合网| 狠狠狠色丁香婷婷综合久久五月 | 日日噜噜夜夜狠狠久久丁香五月| 久久成人小视频| 久久久无码精品亚洲日韩京东传媒| 久久人人爽人人爽人人片AV不|