• <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>

            天行健 君子當(dāng)自強(qiáng)而不息

            D3D中的網(wǎng)格模型(1)

            ID3DXMesh接口的主要功能繼承自ID3DXBaseMesh父接口,了解這些是很重要的,其它一些mesh接口如ID3DXPMesh也是繼承自ID3DXBaseMesh。


            10.1 幾何信息

            ID3DXBaseMesh接口包含一個用來存儲網(wǎng)格頂點的頂點緩存和一個用來定義這些頂點怎樣連接在一起組成網(wǎng)格三角形的索引緩存。我們使用下面的方法來得到這些緩存的指針:

            HRESULT ID3DXMesh::GetVertexBuffer(LPDIRECT3DVERTEXBUFFER9* ppVB);

            HRESULT ID3DXMesh::GetIndexBuffer(LPDIRECT3DINDEXBUFFER9* ppIB);

            這里有一些使用這些方法的例子:

            IDirect3DVertexBuffer9* vb = 0;

            Mesh->GetVertexBuffer( &vb );

            IDirect3DIndexBuffer9* ib = 0;

            Mesh->GetIndexBuffer( &ib );

            假如想鎖定這些緩存來讀寫數(shù)據(jù),那么我們能夠使用下面的方法。注意這些方法鎖定整個頂點/索引緩存。

            Locks a vertex buffer and obtains a pointer to the vertex buffer memory.

            HRESULT LockVertexBuffer(
            DWORD Flags,
            LPVOID * ppData
            );

            Parameters

            Flags

            Combination of zero or more locking flags that describe the type of lock to perform. For this method, the valid flags are:

            • D3DLOCK_DISCARD
            • D3DLOCK_NO_DIRTY_UPDATE
            • D3DLOCK_NOSYSLOCK
            • D3DLOCK_READONLY
            • D3DLOCK_NOOVERWRITE
            [in] For a description of the flags, see D3DLOCK.

             

            ppData
            [out, retval] VOID* pointer to a buffer containing the vertex data.

            Return Values

            If the method succeeds, the return value is D3D_OK. If the method fails, the return value can be D3DERR_INVALIDCALL.

            Remarks

            When working with vertex buffers, you are allowed to make multiple lock calls; however, you must ensure that the number of lock calls match the number of unlock calls. DrawPrimitive calls will not succeed with any outstanding lock count on any currently set vertex buffer.

            Locks an index buffer and obtains a pointer to the index buffer memory.

            HRESULT LockIndexBuffer(
            DWORD Flags,
            LPVOID * ppData
            );

            Parameters

            Flags

            Combination of zero or more locking flags that describe the type of lock to perform. For this method, the valid flags are:

            • D3DLOCK_DISCARD
            • D3DLOCK_NO_DIRTY_UPDATE
            • D3DLOCK_NOSYSLOCK
            • D3DLOCK_READONLY
            [in] For a description of the flags, see D3DLOCK.

             

            ppData
            [out, retval] VOID* pointer to a buffer containing the index data. The count of indices in this buffer will be equal to ID3DXBaseMesh::GetNumFaces * 3.

            Return Values

            If the method succeeds, the return value is D3D_OK. If the method fails, the return value can be D3DERR_INVALIDCALL.

            Remarks

            When working with index buffers, you are allowed to make multiple lock calls. However, you must ensure that the number of lock calls match the number of unlock calls. DrawPrimitive calls will not succeed with any outstanding lock count on any currently set index buffer.


            D3DLOCK

            A combination of zero or more locking options that describe the type of lock to perform.

            #define Description
            D3DLOCK_DISCARD The application discards all memory within the locked region. For vertex and index buffers, the entire buffer will be discarded. This option is only valid when the resource is created with dynamic usage (see D3DUSAGE).
            D3DLOCK_DONOTWAIT Allows an application to gain back CPU cycles if the driver cannot lock the surface immediately. If this flag is set and the driver cannot lock the surface immediately, the lock call will return D3DERR_WASSTILLDRAWING. This flag can only be used when locking a surface created using IDirect3DDevice9::CreateOffscreenPlainSurface, IDirect3DDevice9::CreateRenderTarget, or IDirect3DDevice9::CreateDepthStencilSurface. This flag can also be used with a back buffer.
            D3DLOCK_NO_DIRTY_UPDATE By default, a lock on a resource adds a dirty region to that resource. This option prevents any changes to the dirty state of the resource. Applications should use this option when they have additional information about the set of regions changed during the lock operation.
            D3DLOCK_NOOVERWRITE Indicates that memory that was referred to in a drawing call since the last lock without this flag will not be modified during the lock. This can enable optimizations when the application is appending data to a resource. Specifying this flag enables the driver to return immediately if the resource is in use, otherwise, the driver must finish using the resource before returning from locking.
            D3DLOCK_NOSYSLOCK The default behavior of a video memory lock is to reserve a system-wide critical section, guaranteeing that no display mode changes will occur for the duration of the lock. This option causes the system-wide critical section not to be held for the duration of the lock.

            The lock operation is time consuming, but can enable the system to perform other duties, such as moving the mouse cursor. This option is useful for long-duration locks, such as the lock of the back buffer for software rendering that would otherwise adversely affect system responsiveness.

            D3DLOCK_READONLY The application will not write to the buffer. This enables resources stored in non-native formats to save the recompression step when unlocking.

            當(dāng)然在你鎖定以后一定要記得解鎖:

            HRESULT ID3DXMesh::UnlockVertexBuffer();

            HRESULT ID3DXMesh::UnlockIndexBuffer();

            下面是另外一些與mesh幾何結(jié)構(gòu)有關(guān)的ID3DXMesh接口方法:

             DWORD GetFVF() — 返回頂點的格式

            DWORD GetNumVertices() — 返回頂點緩存中的頂點數(shù)

            DWORD GetNumBytesPerVertex() — 返回一個頂點所占的字節(jié)數(shù)

            DWORD GetNumFaces() — 返回在mesh中的面(三角形)數(shù)


            10.2 子集和屬性緩存

            一個mesh由一個或數(shù)個子集組成。一個子集(subset)是在mesh中的使用相同屬性渲染的一組三角形。這里的屬性是指材質(zhì),紋理和渲染狀態(tài)。圖10.1顯示了一座房子mesh可能被分成的幾個子集。

            在mesh中的每個三角形都與一個屬性ID相關(guān)聯(lián),表示該三角形屬于該子集。例如,圖10.1中組成地板的三角形具有屬性ID0,它表示這些三角形屬于子集0。同樣,組成墻的三角形具有屬性ID1,它表示這些三角形屬于子集1。

            三角形的屬性ID存儲在mesh的屬性緩存中,它是一個DWORD數(shù)組。因為每個面對應(yīng)屬性緩存中的一項,所以屬性緩存中的項目數(shù)等于mesh中的面的個數(shù)。屬性緩存中的項目和索引緩存中定義的三角形一一對應(yīng)。即,屬性緩存中的第i項和索引緩存中的第i個三角形相對應(yīng)。三角形i由下面三個索引緩存中的索引項定義:

            A = i * 3

            B = i * 3 + 1

            C = i * 3 + 2

            圖10.2顯示了這個對應(yīng)關(guān)系:

            我們可以通過LockAttributeBuffer()鎖定屬性緩存:

            Locks the mesh buffer that contains the mesh attribute data, and returns a pointer to it.

            HRESULT LockAttributeBuffer(
            DWORD Flags,
            DWORD ** ppData
            );

            Parameters

            Flags

            Combination of zero or more locking flags that describe the type of lock to perform. For this method, the valid flags are:

            • D3DLOCK_DISCARD
            • D3DLOCK_NO_DIRTY_UPDATE
            • D3DLOCK_NOSYSLOCK
            • D3DLOCK_READONLY
            [in] For a description of the flags, see D3DLOCK.

             

            ppData
            [out] Address of a pointer to a buffer containing a DWORD for each face in the mesh.

            Return Values

            If the method succeeds, the return value is D3D_OK. If the method fails, the return value can be D3DERR_INVALIDCALL.

            Remarks

            If ID3DXMesh::Optimize has been called, the mesh will also have an attribute table that can be accessed using the ID3DXBaseMesh::GetAttributeTable method.

            就象下面的代碼片段:

            DWORD* buffer = 0;

            Mesh->LockAttributeBuffer(lockingFlags, &buffer);

            // Read or write to attribute buffer...

            Mesh->UnlockAttributeBuffer();


            10.3 繪制

            ID3DXMesh接口提供了DrawSubset(DWORD AttribId)方法來繪制AttribId指示的子集中的各個三角形。

            Draws a subset of a mesh.

            HRESULT DrawSubset(
            DWORD AttribId
            );

            Parameters

            AttribId
            [in] DWORD that specifies which subset of the mesh to draw. This value is used to differentiate faces in a mesh as belonging to one or more attribute groups.

            Return Values

            If the method succeeds, the return value is D3D_OK. If the method fails, the return value can be D3DERR_INVALIDCALL.

            Remarks

            The subset that is specified by AttribId will be rendered by the IDirect3DDevice9::DrawIndexedPrimitive method, using the D3DPT_TRIANGLELIST primitive type, so an index buffer must be properly initialized.

            An attribute table is used to identify areas of the mesh that need to be drawn with different textures, render states, materials, and so on. In addition, the application can use the attribute table to hide portions of a mesh by not drawing a given attribute identifier (AttribId) when drawing the frame.

            例如,要繪制子集0中的所有三角形,我們將這樣寫:

            Mesh->DrawSubset(0);

            為了繪制整個mesh,我們必須繪制mesh的所有子集。這是非常方便的用0,1,2,…,n-1來標(biāo)識子集,這里的n是子集的總數(shù)。且有一個相對應(yīng)的材質(zhì)和紋理數(shù)組,即子集i與材質(zhì)和紋理數(shù)組的第i項對應(yīng)。這就使我們能夠簡單的用循環(huán)來渲染mesh:

            for(int i = 0; i < numSubsets; i++)

            {

                   Device->SetMaterial( mtrls[i] );

                   Device->SetTexture( 0, textures[i] );

                   Mesh->DrawSubset(i);

            }


            posted on 2008-03-27 09:54 lovedday 閱讀(1482) 評論(0)  編輯 收藏 引用


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


            公告

            導(dǎo)航

            統(tǒng)計

            常用鏈接

            隨筆分類(178)

            3D游戲編程相關(guān)鏈接

            搜索

            最新評論

            亚洲精品乱码久久久久久| 久久久久国产亚洲AV麻豆| 久久综合一区二区无码| 伊人久久免费视频| 精品综合久久久久久97超人| 色综合久久中文字幕无码| 久久99久国产麻精品66| 久久亚洲AV无码精品色午夜麻豆| 久久精品亚洲男人的天堂| 久久久久人妻精品一区三寸蜜桃 | 精品久久久久久国产三级| 7777久久亚洲中文字幕| 久久国产免费观看精品| 91亚洲国产成人久久精品网址| 亚洲国产成人久久综合一| 日本久久久精品中文字幕| 丰满少妇人妻久久久久久4| 久久亚洲精品无码播放| 欧美粉嫩小泬久久久久久久| 四虎久久影院| 亚洲精品无码成人片久久| 久久99国产乱子伦精品免费| 久久se精品一区精品二区| 久久播电影网| 久久亚洲中文字幕精品有坂深雪 | 久久精品国产清自在天天线 | 99精品国产99久久久久久97| 久久久噜噜噜久久中文福利| 久久国产精品-久久精品| 久久精品成人免费国产片小草| 奇米影视7777久久精品人人爽| 国产麻豆精品久久一二三| 久久精品人妻一区二区三区| 久久亚洲精品无码VA大香大香| 国产精品久久久久久搜索| 四虎亚洲国产成人久久精品| 国产亚洲欧美精品久久久| 热久久国产欧美一区二区精品| 久久超碰97人人做人人爱| 久久无码精品一区二区三区| 国产精品99精品久久免费|