Enumeración de codificadores instalados
GDI+ proporciona la función GetImageEncoders para que pueda determinar qué codificadores de imagen están disponibles en el equipo. GetImageEncoders devuelve una matriz de objetos ImageCodecInfo . Antes de llamar a GetImageEncoders, debe asignar un búfer lo suficientemente grande como para recibir esa matriz. Puede llamar a GetImageEncodersSize para determinar el tamaño del búfer necesario.
En la siguiente aplicación de consola se enumeran los codificadores de imágenes disponibles:
#include <windows.h>
#include <gdiplus.h>
#include <stdio.h>
using namespace Gdiplus;
INT main()
{
// Initialize GDI+.
GdiplusStartupInput gdiplusStartupInput;
ULONG_PTR gdiplusToken;
GdiplusStartup(&gdiplusToken, &gdiplusStartupInput, NULL);
UINT num; // number of image encoders
UINT size; // size, in bytes, of the image encoder array
ImageCodecInfo* pImageCodecInfo;
// How many encoders are there?
// How big (in bytes) is the array of all ImageCodecInfo objects?
GetImageEncodersSize(&num, &size);
// Create a buffer large enough to hold the array of ImageCodecInfo
// objects that will be returned by GetImageEncoders.
pImageCodecInfo = (ImageCodecInfo*)(malloc(size));
// GetImageEncoders creates an array of ImageCodecInfo objects
// and copies that array into a previously allocated buffer.
// The third argument, imageCodecInfo, is a pointer to that buffer.
GetImageEncoders(num, size, pImageCodecInfo);
// Display the graphics file format (MimeType)
// for each ImageCodecInfo object.
for(UINT j = 0; j < num; ++j)
{
wprintf(L"%s\n", pImageCodecInfo[j].MimeType);
}
free(pImageCodecInfo);
GdiplusShutdown(gdiplusToken);
return 0;
}
Al ejecutar la aplicación de consola anterior, la salida será similar a la siguiente:
image/bmp
image/jpeg
image/gif
image/tiff
image/png