• <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>
            隨筆 - 8  文章 - 4  trackbacks - 0

            本程序只關注對Gif紋理的實現。不對GIF加解密進行詳細的說明。
            GIF文檔解析采用gif89a.h, gif89a.cpp實現。

            gif89a 代碼下載

            詳細紋理生成代碼:


            bool Cmenu::CreateTextureFromGif()
            {
                HRESULT hr;
              CGif89a
            * pGif    = new CGif89a();
                BOOL bopen 
            = pGif->open("110743081.gif",true);
                
                
            int index = 0;
                LPCFRAME pFrame    
            = pGif->getFrame(index);
                
            if (!pFrame)
                    
            return false;


                BYTE
            * pColorTable    = pGif->getColorTable(index);
                
            if (!pColorTable)
                    
            return false;

                
            //create empty Texture.
                hr = D3DXCreateTexture(m_pDevice,pFrame->imageWidth,pFrame->imageHeight,0,0,D3DFMT_X8B8G8R8,D3DPOOL_MANAGED,&m_pTexture[0]);
                
            if(FAILED(hr))
                    
            return false;

                D3DSURFACE_DESC textureDesc;
                m_pTexture[
            0]->GetLevelDesc(0,&textureDesc);

                
            if(textureDesc.Format != D3DFMT_X8B8G8R8)
                    
            return false;

                D3DLOCKED_RECT locketrect;
                hr 
            = m_pTexture[0]->LockRect( 0,&locketrect,0,0 );
                
            if(FAILED(hr))
                    
            return false;

                BYTE
            * pBytes = (BYTE*)locketrect.pBits;
                DWORD lPitch 
            = locketrect.Pitch;

                
            int idx_trs    = pFrame->ctrlExt.trsFlag ? pFrame->ctrlExt.trsColorIndex : -1;

                
            int x=0,y=0;
                
            int    sx, sy;
                
            if(x<0)
                    sx    
            = -x;
                
            else
                    sx    
            = 0;
                
            if(y<0)
                    sy    
            = -y;
                
            else
                    sy    
            = 0;


                DWORD width    
            = pFrame->imageWidth;

                pBytes 
            += lPitch*sy;
                
            for( DWORD h=sy; y+h<pFrame->imageHeight; h++ )
                
            {
                    DWORD
            * pDstData32 = ((DWORD*)pBytes) + sx;
                    WORD
            *  pDstData16 = ((WORD*)pBytes) + sx;
                    BYTE
            * pPixel;

                    BYTE* pIdx    = pFrame->dataBuf + (pFrame->imageWidth*(((y>0)?y:0)+h) + ((x>0)?x:0));

                    
            for( DWORD w=sx; w<width; w++ )
                    
            {
                        pPixel    
            = pColorTable + (*pIdx)*3;
                        
            if (*pIdx==idx_trs)
                        
            {
                            
            //if( 32 == ddsd.ddpfPixelFormat.dwRGBBitCount )
                            
            //    pDstData32[w] = 0;
                            
            //else
                            
            //    pDstData16[w] = 0;
                        }

                        
            else
                        
            {

                            DWORD m_nRShiftL 
            = 0; DWORD m_nRShiftR = 0;
                            DWORD m_nGShiftL 
            = 0; DWORD m_nGShiftR = 0;
                            DWORD m_nBShiftL 
            = 0; DWORD m_nBShiftR = 0;
                            DWORD m_nAShiftL 
            = 0; DWORD  m_nAShiftR = 0;

                            DWORD dr 
            = ((DWORD(pPixel[0])>>(m_nRShiftL))<<m_nRShiftR);
                            DWORD dg = ((DWORD(pPixel[1])>>(m_nGShiftL))<<8);
                            DWORD db = ((DWORD(pPixel[2])>>(m_nBShiftL))<<16);
                            DWORD da = ((0xff>>(m_nAShiftL))<<24);
              
                       pDstData32[w] = (DWORD)(dr+dg+db+da);
             

                        }

                        pIdx 
            ++;
                    }

                    
                    pBytes 
            += lPitch;
                }


                m_pTexture[
            0]->UnlockRect(0);
                
            return true;
            }
            如有任何疑問請留言。交流~~
            posted on 2009-04-04 01:05 Only Soft 閱讀(831) 評論(0)  編輯 收藏 引用 所屬分類: D3D
            久久99国产精品99久久| 欧美黑人激情性久久| 2021久久精品国产99国产精品| 色综合色天天久久婷婷基地| 久久久久久久免费视频| 久久青青草原综合伊人| 精品久久久久久无码中文野结衣| 久久精品无码专区免费青青 | 久久最近最新中文字幕大全| 国产综合精品久久亚洲| 中文字幕日本人妻久久久免费| 国产精品狼人久久久久影院| 久久福利青草精品资源站| 久久久WWW成人免费毛片| 久久香蕉国产线看观看99| 一本久久精品一区二区| 欧美日韩精品久久久免费观看| 成人免费网站久久久| 99久久做夜夜爱天天做精品| 久久精品国产福利国产秒| 亚洲中文字幕无码久久综合网| 久久97久久97精品免视看 | 人妻丰满AV无码久久不卡| 久久99精品久久久大学生| 亚洲精品美女久久久久99| 色综合久久综合中文综合网| 国产免费久久精品丫丫| 国产精品久久久久天天影视| 久久久久亚洲av成人网人人软件| 久久久久亚洲精品中文字幕| 四虎国产精品成人免费久久| 久久精品?ⅴ无码中文字幕| 青青青青久久精品国产| 国产美女久久久| 亚洲国产精品久久久久| 性做久久久久久久久老女人| 精品一久久香蕉国产线看播放| 欧美日韩中文字幕久久伊人| 国产精品久久一区二区三区 | 久久福利青草精品资源站| 国产精品毛片久久久久久久 |