• <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 閱讀(312) 評論(0)  編輯 收藏 引用

            公告

            導(dǎo)航

            統(tǒng)計

            常用鏈接

            隨筆分類(178)

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

            搜索

            最新評論

            国产精品久久久久影院嫩草| 99久久99久久精品国产片| 久久久久18| 久久人人爽人人爽人人片AV东京热| 伊人伊成久久人综合网777| 国产激情久久久久久熟女老人| 久久综合综合久久综合| 99久久国产热无码精品免费久久久久| 国产精品亚洲美女久久久| 亚洲午夜精品久久久久久浪潮 | 久久精品国产亚洲7777| 久久这里有精品| www.久久热| 久久精品国产99国产精品亚洲| 国产精品一区二区久久精品| 蜜桃麻豆www久久国产精品| 熟妇人妻久久中文字幕| 99久久精品免费看国产| 97久久久久人妻精品专区| 伊人久久大香线蕉综合网站| 99久久99久久精品国产| 久久水蜜桃亚洲av无码精品麻豆| 久久天天躁狠狠躁夜夜2020| 久久精品国产亚洲av水果派 | 久久91精品国产91久| 久久免费高清视频| 久久不见久久见免费视频7| 久久婷婷午色综合夜啪| 久久久久国产精品嫩草影院| 国产精品久久久久久久| 久久婷婷五月综合色奶水99啪| 思思久久精品在热线热| 无码任你躁久久久久久老妇| 久久99精品久久久久久不卡| 国产成人久久精品麻豆一区| 国产精品福利一区二区久久| 久久婷婷五月综合色奶水99啪| 亚洲AV日韩精品久久久久久| 国产激情久久久久久熟女老人| 久久国语露脸国产精品电影| 久久人人爽人人人人爽AV |