Click here to Skip to main content
Click here to Skip to main content

Play GIF using GDI+

, 1 Sep 2011 CPOL
Rate this:
Please Sign up or sign in to vote.
A new choice for playing GIF using GDI+


In the past, there was no convenient enough way to play GIF using functions provided by Microsoft Windows but you may need a reference of 3rd libs. Well, now we have an alternative choice from using GDI+

Base of GDI+

First of all, you need to include GDI+ headers, link the libs and using the namespace. In my sample, I did it in stdafx.h.

//GDI+ references
#include<gdiplus.h />
using namespace Gdiplus;
#pragma comment(lib,"gdiplus.lib")

Before using GDI+ in your application, you should initialize the enviroment code below:

//Init GDI+
GdiplusStartupInput gdiplusStartupInput;
ULONG_PTR gdiplusToken;
Status state = GdiplusStartup(&gdiplusToken, &gdiplusStartupInput, NULL);

Correspondent to initialize, you should clean up the environment.


Critical Code

//Here, we load a GIF image file
void CGIFControl::Load(LPCTSTR sFileName)
	m_pImage = new Image(sFileName);
	//First of all we should get the number of frame dimensions
	//Images considered by GDI+ as:
	UINT count = m_pImage->GetFrameDimensionsCount();

	//Now we should get the identifiers for the frame dimensions 
	m_pDimensionIDs =new GUID[count];
	m_pImage->GetFrameDimensionsList(m_pDimensionIDs, count);
	//For gif image , we only care about animation set#0
	WCHAR strGuid[39];
	StringFromGUID2(m_pDimensionIDs[0], strGuid, 39);
	m_FrameCount = m_pImage->GetFrameCount(&m_pDimensionIDs[0]);

	//PropertyTagFrameDelay is a pre-defined identifier 
	//to present frame-delays by GDI+
	UINT TotalBuffer = m_pImage->GetPropertyItemSize(PropertyTagFrameDelay);
	m_pItem = (PropertyItem*)malloc(TotalBuffer);

//To start play
void CGIFControl::Play()
	//Set Current Frame at #0
	m_iCurrentFrame = 0;
	GUID Guid = FrameDimensionTime;

	//Use Timer
	//NOTE HERE: frame-delay values should be multiply by 10
	SetTimer(1,((UINT*)m_pItem[0].value)[m_iCurrentFrame]  * 10,NULL);

	//Move to the next frame
	++ m_iCurrentFrame;

//Using timer
void CGIFControl::OnTimer(UINT_PTR nIDEvent)
	//Because there will be a new delay value

	//Change Active frame
	GUID Guid = FrameDimensionTime;

	//New timer
	SetTimer(1,((UINT*)m_pItem[0].value)[m_iCurrentFrame] * 10,NULL);

	//Again move to the next
	m_iCurrentFrame = (++ m_iCurrentFrame) % m_FrameCount;

//Present current frame
void CGIFControl::DrawItem(LPDRAWITEMSTRUCT lpDrawItemStruct)
	Graphics g(lpDrawItemStruct->hDC);


	CRect rcClient;



Using the Code

Step 1: Set control correspondence in DoDataExchange method of sample dialog:


Step 2: Load the gif image in OnInitDialog:


Finally, add start and finish code in button event handler:

void CGifControlSampleDlg::OnBnClickedBtnPlay()

void CGifControlSampleDlg::OnBnClickedBtnStop()

About the Source

Binary files in attachment archive are compiled by VS2005SP1, so you may need to install the suit vcredist package by yourself first.


This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)


About the Author

Yi Li

China China
No Biography provided

Comments and Discussions

GeneralMy vote of 4 Pinmembershetkarabhijeet23-Nov-12 7:56 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

| Advertise | Privacy | Terms of Use | Mobile
Web01 | 2.8.150327.1 | Last Updated 1 Sep 2011
Article Copyright 2008 by Yi Li
Everything else Copyright © CodeProject, 1999-2015
Layout: fixed | fluid