VB6之GIF分解
原文链接:http://hi.baidu.com/coo_boi/item/1264a64172fe8dec1f19bc08
还是找了个C++的翻译下,原文链接:http://www.360doc.com/content/05/1122/15/1894_34348.shtml
GDI+的函数声明 我就不放上了,网上有个做好的GDI+公共模块。
Private Declare Sub RtlZeroMemory Lib "kernel32" (dest As Any, ByVal numBytes As Long) Private Declare Sub RtlMoveMemory Lib "kernel32" (Destination As Any, Source As Any, ByVal Length As Long) Private Declare Function GetTickCount Lib "kernel32" () As Long Private GifFramesDelay() As Long Private Graphics As Long Private Sub Command1_Click() Dim hImage As Long Dim Guid As Clsid Dim dCount As Long Dim fCount As Long Dim pItem_() As Byte Dim pSize As Long Dim pDelay() As Long Dim bmpCLSID As Clsid Call GdipLoadImageFromFile(StrPtr("d:\1.gif"), hImage) Guid = GetImageEncoderClsid(GIF) 'bmpCLSID = GetImageEncoderClsid(BMP) Call GdipImageGetFrameDimensionsCount(hImage, dCount) Call GdipImageGetFrameDimensionsList(hImage, Guid, dCount) Call GdipImageGetFrameCount(hImage, Guid, fCount) If fCount > 1 Then Call GdipGetPropertyItemSize(hImage, PropertyTagFrameDelay, pSize) ReDim pItem_(pSize - 1) ReDim GifFramesDelay(fCount - 1) Call RtlZeroMemory(ByVal VarPtr(pItem_(0)), pSize) Call GdipGetPropertyItem(hImage, PropertyTagFrameDelay, pSize, ByVal VarPtr(pItem_(0))) '这里我把最后一个参数的类型(PropertyItem)改成了Any,直接读内存方便些 For i = 16 To pSize - 1 Step 4 GifFramesDelay(j) = pItem_(i) j = j + 1 Next For i = 0 To fCount - 1 Call GdipImageSelectActiveFrame(hImage, Guid, i) Call GdipDrawImage(Graphics, hImage, 0, 0) Call delay_(GifFramesDelay(i) * 10) 'Call GdipSaveImageToFile(hImage, StrPtr("d:\" & i & ".bmp"), bmpCLSID, ByVal 0&) Next End If Call GdipDisposeImage(hImage) End Sub Private Sub Form_Load() InitGDIPlus Call GdipCreateFromHDC(Form1.hdc, Graphics) End Sub Private Sub Form_Unload(Cancel As Integer) Call GdipDeleteGraphics(Graphics) TerminateGDIPlus End Sub Private Sub delay_(ByVal d As Long) Dim n As Long n = GetTickCount() Do Until n + d < GetTickCount() DoEvents Loop End Sub