• <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 Animation Basis(7)

            Updating Skinned Meshes

            A skinned mesh works like this: Each vertex is attached to an imaginary bone (which is specified by a frame object). As these frames move, so do the vertices attached to them. To update the coordinates of the vertices as the bones move, you need to call a special function that takes the source vertex data, transforms it according to the bones' transformations, and stores the results in a second mesh object. This special function is called ID3DXSkinInfo::UpdateSkinnedMesh.

            Whenever you load a mesh using the D3DXLoadSkinMeshFromXof function (which is what the second LoadMesh function does), you get a pointer to an ID3DXSkinInfo object. This object contains the information about which vertices are attached to which bones. This way, the object knows which transformations to apply to the vertices.

            To update the vertices, you must first lock the mesh's vertex buffer (which contains the source vertex coordinates), as well as the destination mesh's vertex buffer. The destination mesh will receive the updated vertices as they are transformed. Once locked, you need to call UpdateSkinnedMesh, also specifying a series of transformation matrices (stored as D3DXMATRIX objects) that represent the various bone transformations.

            For now, just check out the update_skin_mesh helper function code to see how it updates the skinned meshes for you.

            HRESULT update_skin_mesh(D3DXMESHCONTAINER_EX* mesh_container)
            {
                
            if(mesh_container == NULL)
                    
            return E_FAIL;

                
            if(mesh_container->MeshData.pMesh == NULL || mesh_container->skin_mesh == NULL || mesh_container->pSkinInfo == NULL)
                    
            return E_FAIL;

                
            if(mesh_container->bone_matrices == NULL || mesh_container->frame_matrices == NULL)
                    
            return E_FAIL;

                
            // copy the bone matrices over (must have been combined before call draw_mesh)
                for(DWORD i = 0; i < mesh_container->pSkinInfo->GetNumBones(); i++)
                {
                    
            // start with bone offset matrix
                    mesh_container->bone_matrices[i] = *(mesh_container->pSkinInfo->GetBoneOffsetMatrix(i));

                    
            // apply frame transformation
                    if(mesh_container->frame_matrices[i])
                        mesh_container
            ->bone_matrices[i] *= (*mesh_container->frame_matrices[i]);
                }

                
            void* src_vertices;
                
            void* dest_vertices;

                mesh_container
            ->MeshData.pMesh->LockVertexBuffer(D3DLOCK_READONLY, (void**)&src_vertices);
                mesh_container
            ->skin_mesh->LockVertexBuffer(0, (void**)&dest_vertices);

                
            // update the skinned mesh using provided transformations
                mesh_container->pSkinInfo->UpdateSkinnedMesh(mesh_container->bone_matrices, NULL, src_vertices, dest_vertices);

                mesh_container
            ->MeshData.pMesh->UnlockVertexBuffer();
                mesh_container
            ->skin_mesh->UnlockVertexBuffer();    

                
            return S_OK;
            }

             

            Aside from the typical error−checking code, the update_skin_mesh function starts by looping through each bone contained within the ID3DXSkinInfo object (stored in the D3DXMESHCONTAINER_EX object you've already loaded). For each bone, the original transformation matrix from the .X file is grabbed and stored in an array of matrices used in the call to UpdateSkinnedMesh.

            From here the bone's transformation, as stored in the bone's respective frame object, is applied to the transformation matrix. This process continues until all transformation matrices are set up

            At this point, you are ready to lock the vertex buffers and call the UpdateSkinnedMesh function.

            The function is finished by unlocking the buffers and returning a success code.

            And once again speaking of rendering, it is finally time to see the helper functions I created to get those
            meshes on screen!


            posted on 2008-04-15 10:22 lovedday 閱讀(313) 評(píng)論(0)  編輯 收藏 引用


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


            公告

            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            隨筆分類(178)

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

            搜索

            最新評(píng)論

            久久精品国产99国产精品| 久久亚洲精品无码播放| 久久国产精品成人影院| 丰满少妇高潮惨叫久久久| 久久国产成人午夜AV影院| 亚洲国产成人精品无码久久久久久综合 | 性做久久久久久久久久久| 亚洲国产另类久久久精品小说| 久久久无码精品亚洲日韩按摩| 国产—久久香蕉国产线看观看| yy6080久久| 久久久久久a亚洲欧洲aⅴ| 一本久久精品一区二区| 久久香蕉国产线看观看99| 伊人情人综合成人久久网小说 | 精品久久久久久无码人妻热| 久久福利资源国产精品999| 国内精品久久九九国产精品| 热久久视久久精品18| 青青草原综合久久| 麻豆成人久久精品二区三区免费| 国产精品热久久毛片| 99精品久久精品| 亚洲色欲久久久综合网东京热| 久久精品国产亚洲Aⅴ香蕉| 久久香蕉国产线看观看乱码 | 久久久中文字幕| 人妻无码精品久久亚瑟影视| 精品久久久久中文字幕日本| 久久久噜噜噜久久中文福利| 国产精品99久久久久久www| 久久精品国产亚洲av高清漫画| 一本一本久久A久久综合精品| 女人香蕉久久**毛片精品| 久久青青草原国产精品免费| 亚洲国产日韩综合久久精品| 久久久久国产成人精品亚洲午夜| 久久99国产精品99久久| 色婷婷综合久久久中文字幕| 日韩精品久久久久久久电影蜜臀 | 久久精品国产亚洲av水果派|