//@date 1-13-2009
//@param [in] format 图片格式 值可以为以下几种
//@"image/bmp"
//@"image/jpeg"
//@"image/gif"
//@"image/tiff"
//@"image/png"
//@param [in] pClsid
//@return 成功则返回值 >= 0,失败则返回值为-1
int GetEncoderClsid(const WCHAR* format, CLSID *pClsid)
{
int nRet = -1;
ImageCodecInfo* pCodecInfo = NULL;
UINT nNum = 0,nSize = 0;
GetImageEncodersSize(&nNum,&nSize);
if (nSize<0)
{
return nRet;
}
pCodecInfo= new ImageCodecInfo[nSize];
if (pCodecInfo==NULL)
{
return nRet;
}
GetImageEncoders(nNum,nSize,pCodecInfo);
for (UINT i=0; i<nNum;i++)
{
if (wcscmp(pCodecInfo[i].MimeType,format)==0)
{
*pClsid= pCodecInfo[i].Clsid;
nRet = i;
delete[] pCodecInfo;
return nRet;
}
else
{
continue;
}
}
delete[] pCodecInfo;
return nRet;
}
//@brief 用GDI+将Bitmap图片保存为文件
//@date 1-13-2009
//@param [in] hBitmap hBitmap的句柄(handle)
//@param [in] lpszFileName 保存图片的完整路径
//@return 成功返回TRUE,失败返回FALSE
BOOL SaveBitmapToFile(HBITMAP hBitmap, LPCTSTR lpszFileName)
{
CLSID pngClsid;
Bitmap bmp(hBitmap,NULL);
//获取BMP文件的编码方式(如果希望获取JPEG的编码方式,
//那么参数一要设置为:_TEXT("image/jpeg"),其他支持的图片格式类似)
int nResult = GetEncoderClsid(_TEXT("image/bmp"),&pngClsid);
if(nResult >= 0)
{
//保存所截取的屏幕图片
bmp.Save(lpszFileName,&pngClsid);
}
else
{
return FALSE;
}
return TRUE;
}
1 个解决方案
#1
仅供参考:
#include <math.h>
#include <string.h>
#include <stdio.h>
#include <windows.h>
#include <gdiplus.h>
#pragma comment(lib, "gdiplus.lib")
using namespace Gdiplus;
wchar_t formats[5][11]={
L"image/bmp",
L"image/jpeg",
L"image/gif",
L"image/tiff",
L"image/png",
};
wchar_t exts[5][5]={
L".bmp",
L".jpg",
L".gif",
L".tif",
L".png",
};
int GetEncoderClsid(const WCHAR* format, CLSID* pClsid) {
UINT num = 0; // number of image encoders
UINT size = 0; // size of the image encoder array in bytes
ImageCodecInfo* pImageCodecInfo = NULL;
GetImageEncodersSize(&num, &size);
if(size == 0) return -1; // Failure
pImageCodecInfo = (ImageCodecInfo*)(malloc(size));
if(pImageCodecInfo == NULL) return -1; // Failure
GetImageEncoders(num, size, pImageCodecInfo);
for (UINT j = 0; j < num; ++j) {
if ( wcscmp(pImageCodecInfo[j].MimeType, format) == 0 ) {
*pClsid = pImageCodecInfo[j].Clsid;
free(pImageCodecInfo);
return j; // Success
}
}
free(pImageCodecInfo);
return -1; // Failure
}
int wmain(int argc,wchar_t *argv[]) {
int r=1;
if (argc<4) {
USAGE:
wprintf(L"%s srcimg.{bmp|jpg|gif|tif|png|wmf|emf|ico} desimg.{bmp|jpg|gif|tif|png} angle\n",argv[0]);
return r;
}
int i;
for (i=0;i<5;i++) {
if (0==_wcsicmp(argv[1]+wcslen(argv[1])-4,exts[i])) break;
}
if (i>=5) goto USAGE;
for (i=0;i<5;i++) {
if (0==_wcsicmp(argv[2]+wcslen(argv[2])-4,exts[i])) break;
}
if (i>=5) goto USAGE;
GdiplusStartupInput gdiplusstartupinput;
ULONG_PTR gdiplustoken;
GdiplusStartup(&gdiplustoken, &gdiplusstartupinput, NULL);
{
Image img(argv[1]);
if (Ok==img.GetLastStatus()) {
UINT height = img.GetHeight();
UINT width = img.GetWidth();
REAL angle;
if (1==swscanf_s(argv[3],L"%f",&angle)) {
REAL size;
size=(REAL)sqrt(1.0*width*width+1.0*height*height);
Matrix mat;
mat.Translate(size / -2.0f, size / -2.0f);
mat.Rotate(-angle, MatrixOrderAppend);
mat.Translate(size / 2.0f, size / 2.0f, MatrixOrderAppend);
PointF pfTL((size-width)/2.0f ,(size-height)/2.0f );
PointF pfTR((size-width)/2.0f+width,(size-height)/2.0f );
PointF pfBL((size-width)/2.0f ,(size-height)/2.0f+height);
PointF pfBR((size-width)/2.0f+width,(size-height)/2.0f+height);
Graphics tgp(&img);
Bitmap bmp((UINT)size,(UINT)size,&tgp);//Let bmp Resolution equal to img Resolution
Graphics gp(&bmp);
gp.SetTransform(&mat);
gp.DrawImage(&img,pfTL);
REAL xmin,ymin,xmax,ymax,x,y,rw,rh;
mat.TransformPoints(&pfTL);
xmin=xmax=pfTL.X;
ymin=ymax=pfTL.Y;
mat.TransformPoints(&pfTR);
if (xmin>pfTR.X) xmin=pfTR.X;
if (xmax<pfTR.X) xmax=pfTR.X;
if (ymin>pfTR.Y) ymin=pfTR.Y;
if (ymax<pfTR.Y) ymax=pfTR.Y;
mat.TransformPoints(&pfBL);
if (xmin>pfBL.X) xmin=pfBL.X;
if (xmax<pfBL.X) xmax=pfBL.X;
if (ymin>pfBL.Y) ymin=pfBL.Y;
if (ymax<pfBL.Y) ymax=pfBL.Y;
mat.TransformPoints(&pfBR);
if (xmin>pfBR.X) xmin=pfBR.X;
if (xmax<pfBR.X) xmax=pfBR.X;
if (ymin>pfBR.Y) ymin=pfBR.Y;
if (ymax<pfBR.Y) ymax=pfBR.Y;
x=xmin;
y=ymin;
rw=xmax-x;
rh=ymax-y;
Bitmap* clone;
clone = bmp.Clone(x,y,rw,rh,PixelFormat24bppRGB);//bmp.GetPixelFormat()
CLSID encoderClsid;
if (0<=GetEncoderClsid(formats[i],&encoderClsid)) {
if (Ok==clone->Save(argv[2],&encoderClsid)) {
wprintf(L"OK to %s %s %s %s\n",argv[0],argv[1],argv[2],argv[3]);
r=0;
} else {
wprintf(L"Error to save %s\n",argv[2]);
r=4;
}
} else {
wprintf(L"Error to GetEncoderClsid(%s,...)\n",formats[i]);
r=3;
}
delete clone;
} else {
wprintf(L"Error to get angle %s\n",argv[3]);
r=2;
}
} else {
wprintf(L"Error to load %s\n",argv[1]);
r=5;
}
}
GdiplusShutdown(gdiplustoken);
return r;
}
#1
仅供参考:
#include <math.h>
#include <string.h>
#include <stdio.h>
#include <windows.h>
#include <gdiplus.h>
#pragma comment(lib, "gdiplus.lib")
using namespace Gdiplus;
wchar_t formats[5][11]={
L"image/bmp",
L"image/jpeg",
L"image/gif",
L"image/tiff",
L"image/png",
};
wchar_t exts[5][5]={
L".bmp",
L".jpg",
L".gif",
L".tif",
L".png",
};
int GetEncoderClsid(const WCHAR* format, CLSID* pClsid) {
UINT num = 0; // number of image encoders
UINT size = 0; // size of the image encoder array in bytes
ImageCodecInfo* pImageCodecInfo = NULL;
GetImageEncodersSize(&num, &size);
if(size == 0) return -1; // Failure
pImageCodecInfo = (ImageCodecInfo*)(malloc(size));
if(pImageCodecInfo == NULL) return -1; // Failure
GetImageEncoders(num, size, pImageCodecInfo);
for (UINT j = 0; j < num; ++j) {
if ( wcscmp(pImageCodecInfo[j].MimeType, format) == 0 ) {
*pClsid = pImageCodecInfo[j].Clsid;
free(pImageCodecInfo);
return j; // Success
}
}
free(pImageCodecInfo);
return -1; // Failure
}
int wmain(int argc,wchar_t *argv[]) {
int r=1;
if (argc<4) {
USAGE:
wprintf(L"%s srcimg.{bmp|jpg|gif|tif|png|wmf|emf|ico} desimg.{bmp|jpg|gif|tif|png} angle\n",argv[0]);
return r;
}
int i;
for (i=0;i<5;i++) {
if (0==_wcsicmp(argv[1]+wcslen(argv[1])-4,exts[i])) break;
}
if (i>=5) goto USAGE;
for (i=0;i<5;i++) {
if (0==_wcsicmp(argv[2]+wcslen(argv[2])-4,exts[i])) break;
}
if (i>=5) goto USAGE;
GdiplusStartupInput gdiplusstartupinput;
ULONG_PTR gdiplustoken;
GdiplusStartup(&gdiplustoken, &gdiplusstartupinput, NULL);
{
Image img(argv[1]);
if (Ok==img.GetLastStatus()) {
UINT height = img.GetHeight();
UINT width = img.GetWidth();
REAL angle;
if (1==swscanf_s(argv[3],L"%f",&angle)) {
REAL size;
size=(REAL)sqrt(1.0*width*width+1.0*height*height);
Matrix mat;
mat.Translate(size / -2.0f, size / -2.0f);
mat.Rotate(-angle, MatrixOrderAppend);
mat.Translate(size / 2.0f, size / 2.0f, MatrixOrderAppend);
PointF pfTL((size-width)/2.0f ,(size-height)/2.0f );
PointF pfTR((size-width)/2.0f+width,(size-height)/2.0f );
PointF pfBL((size-width)/2.0f ,(size-height)/2.0f+height);
PointF pfBR((size-width)/2.0f+width,(size-height)/2.0f+height);
Graphics tgp(&img);
Bitmap bmp((UINT)size,(UINT)size,&tgp);//Let bmp Resolution equal to img Resolution
Graphics gp(&bmp);
gp.SetTransform(&mat);
gp.DrawImage(&img,pfTL);
REAL xmin,ymin,xmax,ymax,x,y,rw,rh;
mat.TransformPoints(&pfTL);
xmin=xmax=pfTL.X;
ymin=ymax=pfTL.Y;
mat.TransformPoints(&pfTR);
if (xmin>pfTR.X) xmin=pfTR.X;
if (xmax<pfTR.X) xmax=pfTR.X;
if (ymin>pfTR.Y) ymin=pfTR.Y;
if (ymax<pfTR.Y) ymax=pfTR.Y;
mat.TransformPoints(&pfBL);
if (xmin>pfBL.X) xmin=pfBL.X;
if (xmax<pfBL.X) xmax=pfBL.X;
if (ymin>pfBL.Y) ymin=pfBL.Y;
if (ymax<pfBL.Y) ymax=pfBL.Y;
mat.TransformPoints(&pfBR);
if (xmin>pfBR.X) xmin=pfBR.X;
if (xmax<pfBR.X) xmax=pfBR.X;
if (ymin>pfBR.Y) ymin=pfBR.Y;
if (ymax<pfBR.Y) ymax=pfBR.Y;
x=xmin;
y=ymin;
rw=xmax-x;
rh=ymax-y;
Bitmap* clone;
clone = bmp.Clone(x,y,rw,rh,PixelFormat24bppRGB);//bmp.GetPixelFormat()
CLSID encoderClsid;
if (0<=GetEncoderClsid(formats[i],&encoderClsid)) {
if (Ok==clone->Save(argv[2],&encoderClsid)) {
wprintf(L"OK to %s %s %s %s\n",argv[0],argv[1],argv[2],argv[3]);
r=0;
} else {
wprintf(L"Error to save %s\n",argv[2]);
r=4;
}
} else {
wprintf(L"Error to GetEncoderClsid(%s,...)\n",formats[i]);
r=3;
}
delete clone;
} else {
wprintf(L"Error to get angle %s\n",argv[3]);
r=2;
}
} else {
wprintf(L"Error to load %s\n",argv[1]);
r=5;
}
}
GdiplusShutdown(gdiplustoken);
return r;
}