GDI+ 旋转后如何获取旋转后的图像 20

使用graphics.RotateTransform(18,MatrixOrder.Prepend);后将画布旋转后,再画图,怎么讲旋转后的图片保存下来。代码如下:Gra... 使用graphics.RotateTransform(18, MatrixOrder.Prepend);后将画布旋转后,再画图,怎么讲旋转后的图片保存下来。代码如下:
Graphics imageGraphics = Graphics.FromImage(IniImage);
Graphics g = e.Graphics;
g.RotateTransform(rotateNum, MatrixOrder.Prepend);
g.DrawImage(IniImage, 0, 0, IniImage.Width, IniImage.Height);
如何把界面上显示出来旋转后的图片获取下来
展开
 我来答
任明星Ming
2014-04-15 · TA获得超过798个赞
知道小有建树答主
回答量:1061
采纳率:100%
帮助的人:1153万
展开全部
刚开始使用的是gdi保存cview中的绘图内容,但是发现由于保存的是位图所以保存下来的图片的大小很大,每个大概有2M左右,所以在网上找解决方法,选择使用GDI+来保存绘图为图片,大小为20K左右,主要过程如下
一,添加gdi相关文件
1,从网络上下载gdi头文件和库文件 http://www.codeguru.com/code/legacy/gdi/GDIPlus.zip
2,解压之后将将其中的Includes和Lib中的文件拷到vc目录下的Includes和Lib文件夹中;
3,将以下代码加入StdAfx.h头文件中:
#ifndef ULONG_PTR
#define ULONG_PTR unsigned long*
#include "GdiPlus.h "
using namespace Gdiplus;
#pragma comment(lib, "gdiplus.lib ")
#endif
4,将gdiplus.dll考到debug和release目录下
二,在程序中加载库
1,在C*APP头文件中添加两个变量
GdiplusStartupInput m_gdiplusStartupInput;
ULONG_PTR m_pGdiToken;
2,在C*APP文件 的InitInstance函数中加入初始化GDI+的函数:
GdiplusStartup(&m_gdiplusToken, &m_gdiplusStartupInput, NULL);
3,在C*APP文件 中添加ExitInstance()虚函数
在ExitInstance()虚函数中添加
GdiplusShutdown(m_gdiplusToken);
三使用GDI+ GDI+的使用很方便代码如下
CDC MemDC; //首先定义一个显示设备对象
CBitmap MemBitmap;//定义一个位图对象
MemBitmap.CreateCompatibleBitmap(pdc,nWidth,nHeight);
//随后建立与屏幕显示兼容的内存显示设备
MemDC.CreateCompatibleDC(pdc);
//这时还不能绘图,因为没有地方画 ^_^
//下面建立一个与屏幕显示兼容的位图,至于位图的大小嘛,可以用窗口的大小
//将位图选入到内存显示设备中
//只有选入了位图的内存显示设备才有地方绘图,画到指定的位图上
CBitmap *pOldBit=MemDC.SelectObject(&MemBitmap);
//先用背景色将位图清除干净,这里我用的是白色作为背景
//你也可以用自己应该用的颜色
MemDC.FillSolidRect(0,0,nWidth,nHeight,RGB(255,255,255));

CString filename;//名字
这里用MemDC绘图//
MemDC.move(0,0);
MemDC.lineto(100,100);
USES_CONVERSION; //将cstring转化为const wchar*
WCHAR* pBuf = T2W((LPCTSTR)filename);

//这里就是将内存中的绘图转化成图片了
Bitmap bm((HBITMAP)MemBitmap, NULL);//定义bitmap
CLSID pngClsid;
GetEncoderClsid(L"image/jpeg", &pngClsid);
bm.Save(pBuf, &pngClsid, NULL);
MemDC.DeleteDC();
其中GetEncoderClsid(const WCHAR* format, CLSID* pClsid)代码如下

int GetEncoderClsid(const WCHAR* format, CLSID* pClsid)
{
UINT num= 0;
UINT size= 0;
ImageCodecInfo* pImageCodecInfo= NULL;
GetImageEncodersSize(&num, &size);
if(size== 0)
{
return -1;
}
pImageCodecInfo= (ImageCodecInfo*)(malloc(size));
if(pImageCodecInfo== NULL)
{
return -1;
}
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;
}
}
free(pImageCodecInfo);
return -1;
}
该函数使用方法很方便,如下面的代码就分别获得5中图像编码器的CLSID
CLSID encoderClsid
GetEncoderClsid(L"image/png", &encoderClsid); //png
GetEncoderClsid(L"image/bmp", &encoderClsid);
GetEncoderClsid(L"image/gif", &encoderClsid);
GetEncoderClsid(L"image/jpeg", &encoderClsid);
GetEncoderClsid(L"image/tiff", &encoderClsid);
追问
这是C的写法吧,我需要C#的
追答
反正都是gdi加,语法都差不多。
轮回归来
2014-04-11
知道答主
回答量:7
采纳率:0%
帮助的人:5461
展开全部
大致能想到2种方法:
第一种:用内存流去存储。
using(MemoryStream ms = new MemoryStream())
{
image.Save(ms, ImageFormat.Jpeg);//图片保存格式
image.save(filepath);//图片保存地址
ms.dispose();//清空内存
image.Dispose();//清空图片缓存
}
第二种:将内存流转换为字节数组保存,效率更高
using(MemoryStream ms=new MemoryStream())

{
image.Save(ms, ImageFormat.Jpeg);
byte[] Imgs = ms.ToArray();
ms.Dispose();
image.Dispose();
System.IO.File.WriteAllBytes(filepath, Imgs);
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式