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

            天行健 君子當自強而不息

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

            公告

            導航

            統計

            常用鏈接

            隨筆分類(178)

            3D游戲編程相關鏈接

            搜索

            最新評論

            久久免费视频观看| 久久人妻少妇嫩草AV蜜桃| 欧美熟妇另类久久久久久不卡 | 7777精品伊人久久久大香线蕉| 亚洲精品97久久中文字幕无码| 亚洲国产精品无码久久98| 国内精品久久久人妻中文字幕| 久久久久人妻一区精品| 91精品国产高清91久久久久久| 一97日本道伊人久久综合影院 | 国产精品18久久久久久vr | 少妇人妻综合久久中文字幕| www.久久热| 久久久久久久精品妇女99| 亚洲国产精品久久久久网站 | 精品久久久久久无码国产| 亚洲∧v久久久无码精品| 久久久噜噜噜久久中文字幕色伊伊| 精品国产乱码久久久久软件| 伊人久久大香线蕉影院95| 久久亚洲精品无码aⅴ大香| 久久99精品九九九久久婷婷| 久久精品国产99久久久| 99精品久久久久久久婷婷 | 天天做夜夜做久久做狠狠| 热久久国产精品| www.久久热| 久久久精品一区二区三区| 97久久天天综合色天天综合色hd| 亚洲精品乱码久久久久久蜜桃图片 | 狠狠色噜噜色狠狠狠综合久久 | 国内精品伊人久久久久影院对白| 久久亚洲精品国产精品| 午夜精品久久久久久久| 久久久久亚洲AV无码麻豆| 久久精品国产亚洲AV无码偷窥| 人妻无码αv中文字幕久久琪琪布 人妻无码久久一区二区三区免费 人妻无码中文久久久久专区 | 久久人人超碰精品CAOPOREN | 精品欧美一区二区三区久久久| 久久福利青草精品资源站| 2020最新久久久视精品爱|