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

            公告

            導航

            統(tǒng)計

            常用鏈接

            隨筆分類(178)

            3D游戲編程相關鏈接

            搜索

            最新評論

            乱亲女H秽乱长久久久| 久久精品国产影库免费看| 久久成人精品| 免费一级欧美大片久久网| 尹人香蕉久久99天天拍| 亚洲精品tv久久久久久久久| 无码国内精品久久人妻蜜桃| 一本大道久久a久久精品综合| 狠狠久久亚洲欧美专区| 国内精品综合久久久40p| 久久久久久夜精品精品免费啦| 狠狠色综合网站久久久久久久高清 | 久久久久青草线蕉综合超碰| 久久九九兔免费精品6| 精品久久久久久国产| 国产成人精品久久免费动漫| 久久精品国产一区二区电影| 亚洲va久久久噜噜噜久久男同| 久久99热狠狠色精品一区| 久久亚洲视频| 精品久久久久久久久中文字幕| 国产亚洲婷婷香蕉久久精品| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 久久精品国产一区二区| 污污内射久久一区二区欧美日韩| 久久99精品国产自在现线小黄鸭| 欧美激情精品久久久久| 免费久久人人爽人人爽av| 成人精品一区二区久久| 久久久久亚洲AV无码专区首JN| 久久se精品一区二区影院| 国产精品久久久久a影院| 99久久精品这里只有精品| 欧美va久久久噜噜噜久久| 久久久久久曰本AV免费免费| 久久国产免费直播| 久久精品视频91| 久久人人爽人人爽人人片AV麻豆| 久久99国产精品二区不卡| 色诱久久久久综合网ywww| 国产亚洲美女精品久久久2020|