C#放缩、截取、合并图片并生成高质量新图的类
using System;
using System.Drawing;
using System.Drawing.Imaging;
using System.Drawing.Drawing2D;
using System.IO;
namespace Framework
{
public class ImageClass
{
public Image ResourceImage;
public int Width=0;
public int Height=0;
private int ImageWidth;
private int ImageHeight;
private ImageFormat imgFormat;
public string ErrMessage;
public ImageClass(string ImageFileName)
{
ResourceImage = Image.FromFile(ImageFileName);
Width = ResourceImage.Width;
Height = ResourceImage.Height;
imgFormat = ResourceImage.RawFormat;
ErrMessage = "";
}
public ImageClass(byte[] Img)
{
MemoryStream imgStream = new MemoryStream(Img);
try
{
ResourceImage = System.Drawing.Image.FromStream(imgStream);
Width = ResourceImage.Width;
Height = ResourceImage.Height;
imgFormat = ResourceImage.RawFormat;
}
catch (Exception ex)
{
ErrMessage = ex.ToString();
}
}
public bool ThumbnailCallback()
{
return false;
}
public Image GetReducedImage(int Width, int Height)
{
try
{
Image ReducedImage;
Image.GetThumbnailImageAbort callb = new Image.GetThumbnailImageAbort(ThumbnailCallback);
ReducedImage = ResourceImage.GetThumbnailImage(Width, Height, callb, IntPtr.Zero);
return ReducedImage;
}
catch (Exception e)
{
ErrMessage = e.Message;
return null;
}
}
public bool GetReducedImage(int Width, int Height, string targetFilePath)
{
try
{
EncoderParameter p;
EncoderParameters ps;
ps = new EncoderParameters(1);
p = new EncoderParameter(System.Drawing.Imaging.Encoder.Quality, 85L);
ps.Param[0] = p;
Image ReducedImage;
Image.GetThumbnailImageAbort callb = new Image.GetThumbnailImageAbort(ThumbnailCallback);
ReducedImage = ResourceImage.GetThumbnailImage(Width, Height, callb, IntPtr.Zero);
Graphics g = System.Drawing.Graphics.FromImage(ReducedImage);
// 设置画布的描绘质量
g.CompositingQuality = CompositingQuality.HighQuality;
g.SmoothingMode = SmoothingMode.HighQuality;
g.InterpolationMode = InterpolationMode.HighQualityBicubic;
//清空画布并以透明背景色填充
g.Clear(Color.Transparent);
g.DrawImage(ResourceImage, new Rectangle(0, 0, Width, Height), new Rectangle(0, 0, ResourceImage.Width, ResourceImage.Height), GraphicsUnit.Pixel);
ImageCodecInfo imgCodecInfo = GetCodecInfo(imgFormat.ToString());
if (imgCodecInfo == null)
{
ReducedImage.Save(targetFilePath, imgFormat);
}
else
{
ReducedImage.Save(targetFilePath, GetCodecInfo(targetFilePath), ps);
}
ReducedImage.Dispose();
g.Dispose();
return true;
}
catch (Exception e)
{
ErrMessage = e.Message;
return false;
}
}
public Image GetReducedImage(double Percent)
{
try
{
Image ReducedImage;
Image.GetThumbnailImageAbort callb = new Image.GetThumbnailImageAbort(ThumbnailCallback);
ImageWidth = Convert.ToInt32(ResourceImage.Width * Percent);
ImageHeight = Convert.ToInt32(ResourceImage.Height * Percent);
ReducedImage = ResourceImage.GetThumbnailImage(ImageWidth, ImageHeight, callb, IntPtr.Zero);
return ReducedImage;
}
catch (Exception e)
{
ErrMessage = e.Message;
return null;
}
}
public bool GetReducedImage(double Percent, string targetFilePath)
{
try
{
EncoderParameter p;
EncoderParameters ps;
ps = new EncoderParameters(1);
p = new EncoderParameter(System.Drawing.Imaging.Encoder.Quality, 85L);
ps.Param[0] = p;
Image ReducedImage;
Image.GetThumbnailImageAbort callb = new Image.GetThumbnailImageAbort(ThumbnailCallback);
ImageWidth = Convert.ToInt32(ResourceImage.Width * Percent);
ImageHeight = Convert.ToInt32(ResourceImage.Height * Percent);
ReducedImage = ResourceImage.GetThumbnailImage(ImageWidth, ImageHeight, callb, IntPtr.Zero);
Graphics g = System.Drawing.Graphics.FromImage(ReducedImage);
// 设置画布的描绘质量
g.CompositingQuality = CompositingQuality.HighQuality;
g.SmoothingMode = SmoothingMode.HighQuality;
g.InterpolationMode = InterpolationMode.HighQualityBicubic;
//清空画布并以透明背景色填充
g.Clear(Color.Transparent);
g.DrawImage(ResourceImage, new Rectangle(0, 0, ImageWidth, ImageHeight), new Rectangle(0, 0, ResourceImage.Width, ResourceImage.Height), GraphicsUnit.Pixel);
ImageCodecInfo imgCodecInfo = GetCodecInfo(imgFormat.ToString());
if (imgCodecInfo == null)
{
ReducedImage.Save(targetFilePath, imgFormat);
}
else
{
ReducedImage.Save(targetFilePath, GetCodecInfo(targetFilePath), ps);
}
ReducedImage.Dispose();
g.Dispose();
return true;
}
catch (Exception e)
{
ErrMessage = e.Message;
return false;
}
}
public bool GetReducedImage(string targetFilePath)
{
try
{
ResourceImage.Save(targetFilePath, ImageHelper.GetFormat(targetFilePath));
return true;
}
catch (Exception e)
{
ErrMessage = e.Message;
return false;
}
}
public bool CaptureImg(string targetFilePath, int width, int height, int spaceX, int spaceY)
{
try
{
//载入底图
int x = 0; //截取X坐标
int y = 0; //截取Y坐标
//原图宽与生成图片宽 之差
//当小于0(即原图宽小于要生成的图)时,新图宽度为较小者 即原图宽度 X坐标则为0
//当大于0(即原图宽大于要生成的图)时,新图宽度为设置值 即width X坐标则为 sX与spaceX之间较小者
//Y方向同理
int sX = ResourceImage.Width - width;
int sY = ResourceImage.Height - height;
if (sX > 0)
{
x = sX > spaceX ? spaceX : sX;
}
else
{
width = ResourceImage.Width;
}
if (sY > 0)
{
y = sY > spaceY ? spaceY : sY;
}
else
{
height = ResourceImage.Height;
}
EncoderParameter p;
EncoderParameters ps;
ps = new EncoderParameters(1);
p = new EncoderParameter(System.Drawing.Imaging.Encoder.Quality, 85L);
ps.Param[0] = p;
Bitmap ReducedImage = new Bitmap(width, height);
Graphics g = System.Drawing.Graphics.FromImage(ReducedImage);
// 设置画布的描绘质量
g.CompositingQuality = CompositingQuality.HighQuality;
g.SmoothingMode = SmoothingMode.HighQuality;
g.InterpolationMode = InterpolationMode.HighQualityBicubic;
//清空画布并以透明背景色填充
g.Clear(Color.Transparent);
g.DrawImage(ResourceImage, 0, 0, new Rectangle(x, y, width, height), GraphicsUnit.Pixel);
ImageCodecInfo imgCodecInfo = GetCodecInfo(imgFormat.ToString());
if (imgCodecInfo == null)
{
ReducedImage.Save(targetFilePath, imgFormat);
}
else
{
ReducedImage.Save(targetFilePath, GetCodecInfo(targetFilePath), ps);
}
//释放资源
//saveImage.Dispose();
ReducedImage.Dispose();
g.Dispose();
}
catch (Exception ex)
{
ErrMessage = ex.Message;
return false;
}
return true;
}
public bool MergerImg(string targetFilePath, int ImgWidth, int ImgHeight)
{
try
{
EncoderParameter p;
EncoderParameters ps;
ps = new EncoderParameters(1);
p = new EncoderParameter(System.Drawing.Imaging.Encoder.Quality, 85L);
ps.Param[0] = p;
//创建要显示的图片对象,根据参数的个数设置宽度
Bitmap ReducedImage = new Bitmap(ImgWidth, ImgHeight);
Graphics g = Graphics.FromImage(ReducedImage);
// 设置画布的描绘质量
g.CompositingQuality = CompositingQuality.HighQuality;
g.SmoothingMode = SmoothingMode.HighQuality;
g.InterpolationMode = InterpolationMode.HighQualityBicubic;
//清空画布并以透明背景色填充
g.Clear(Color.Transparent);
int StartX = (ImgWidth - this.Width) / 2;
int StartY = (ImgHeight - this.Height) / 2;
g.DrawImage(ResourceImage, StartX, StartY, this.Width, this.Height);
//保存图象
ImageCodecInfo imgCodecInfo = GetCodecInfo(imgFormat.ToString());
if (imgCodecInfo == null)
{
ReducedImage.Save(targetFilePath, imgFormat);
}
else
{
ReducedImage.Save(targetFilePath, GetCodecInfo(targetFilePath), ps);
}
//释放资源
ReducedImage.Dispose();
g.Dispose();
}
catch (Exception ex)
{
ErrMessage = ex.Message;
return false;
}
return true;
}
public bool MergerImg(string targetFilePath, System.Drawing.Image image, int ImgWidth, int ImgHeight)
{
try
{
EncoderParameter p;
EncoderParameters ps;
ps = new EncoderParameters(1);
p = new EncoderParameter(System.Drawing.Imaging.Encoder.Quality, 85L);
ps.Param[0] = p;
//创建要显示的图片对象,根据参数的个数设置宽度
Bitmap ReducedImage = new Bitmap(ImgWidth, ImgHeight);
Graphics g = Graphics.FromImage(ReducedImage);
// 设置画布的描绘质量
g.CompositingQuality = CompositingQuality.HighQuality;
g.SmoothingMode = SmoothingMode.HighQuality;
g.InterpolationMode = InterpolationMode.HighQualityBicubic;
//清空画布并以透明背景色填充
g.Clear(Color.Transparent);
int StartX = (ImgWidth - image.Width) / 2;
int StartY = (ImgHeight - image.Height) / 2;
g.DrawImage(image, StartX, StartY, image.Width, image.Height);
//保存图象
ImageCodecInfo imgCodecInfo = GetCodecInfo(imgFormat.ToString());
if (imgCodecInfo == null)
{
ReducedImage.Save(targetFilePath, imgFormat);
}
else
{
ReducedImage.Save(targetFilePath, GetCodecInfo(targetFilePath), ps);
}
//释放资源
ReducedImage.Dispose();
g.Dispose();
}
catch (Exception ex)
{
ErrMessage = ex.Message;
return false;
}
return true;
}
//返回图片解码器信息用于jpg图片
private ImageCodecInfo GetCodecInfo(string str)
{
string ext = str.Substring(str.LastIndexOf(".") + 1);
string mimeType = "";
switch (ext.ToLower())
{
case "jpe":
case "jpg":
case "jpeg":
mimeType = "image/jpeg";
break;
case "bmp":
mimeType = "image/bmp";
break;
case "png":
mimeType = "image/png";
break;
case "tif":
case "tiff":
mimeType = "image/tiff";
break;
default:
mimeType = "image/jpeg";
break;
}
ImageCodecInfo[] CodecInfo = ImageCodecInfo.GetImageEncoders();
foreach (ImageCodecInfo ici in CodecInfo)
{
if (ici.MimeType == mimeType) return ici;
}
return null;
}
public void Dispose()
{
ResourceImage.Dispose();
}
}
}
因为tiff格式的图片,一张可以有多页,所以现在有需求如下:
1. 可以随便添加一张图片(tiff,jpeg,png等格式)的图片到指定的tiff图片中去
2. 可以从tiff图片中抽取出任意张图片出来,可以保存为(tiff,png,jpeg等格式)
1 Image img = Image.FromFile("C:\\1.tif");
2 Guid guid = (Guid)img.FrameDimensionsList.GetValue(0);
3 FrameDimension dimension = new FrameDimension(guid);
4 int totalPage = img.GetFrameCount(dimension);
5
6 this.statusBar1.Text = "共"+totalPage+"页";
7
8 for(int i=0;i<totalPage;i++)
9 {
10 img.SelectActiveFrame(dimension,i);
11 img.Save("C:\\Gif"+i+".gif",System.Drawing.Imaging.ImageFormat.Gif);
12 }
13
C#放缩、截取、合并图片并生成高质量新图的类的更多相关文章
- atitit.thumb生成高质量缩略图 php .net c++ java
atitit.java thumb生成高质量缩略图 php .net c++ 1. 图像缩放(image scaling)---平滑度(smoothness)和清晰度(sharpness) 1 2. ...
- C#剪切生成高质量缩放图片
/// <summary> /// 高质量缩放图片 /// </summary> /// <param name="OriginFilePath"&g ...
- Highcharts结合PhantomJS在服务端生成高质量的图表图片
项目背景 最近忙着给部门开发一套交互式的报表系统,来替换原有的静态报表系统. 老系统是基于dotnetCHARTING开发的,dotnetCHARTING的优势是图表类型丰富,接口调用简单,使用时只需 ...
- MPlayer-ww 增加边看边剪切功能+生成高质量GIF功能
http://pan.baidu.com/s/1eQm5a74 下载FFmpeg palettegen paletteuse documentation 需要下载 FFmpeg2.6 以上 并FFmp ...
- <1>Python生成高质量Html文件:Pyh模块+Bootstrap框架
一,介绍 QQ交流群:585499566 本文的目的是怎么使用Pyh+Bootstrap快速生成简约,大方,清新的Html页面,涉及到的技能:Python小白技能,Pyh会阅读中文文档,Html基础, ...
- ASP.NET 画图与图像处理-生成高质量缩略图
http://www.cftea.com/c/2007/08/SG9WFLZJD62Z2D0O.asp
- [golang]按图片中心旋转后的新图左顶点和原图左顶点的偏移量计算
1 前言 略,作为记录使用 2 代码 /** * @Author: FB * @Description: * @File: RotateSample.go * @Version: 1.0.0 * @D ...
- PHPThumb处理图片,生成缩略图,图片尺寸调整,图片截取,图片加水印,图片旋转
[强烈推荐]下载地址(github.com/masterexploder/PHPThumb). 注意这个类库有一个重名的叫phpThumb,只是大小写的差别,所以查找文档的时候千万注意. 在网站建设过 ...
- C#一些常用的图片操作方法:生成文字图片 合并图片等
生成文字图片: /// <summary> /// 生成文字图片 /// </summary> /// <param name="text">& ...
随机推荐
- hdu 2067 兔子板
兔子板 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submis ...
- 【iOS发展-28】制造业UITabBarController标记控制器、定制UITabBarItem文字图像6途径和More评论
一个.一个简单的制作过程(实际工程中不建议这样的方式,不要只展示所用原理的理解) 在AppDelegate.m在: - (BOOL)application:(UIApplication *)appli ...
- 图widget--jqplot样品和参数描述的简单演示
最简单的线图 第一步:引入必要的CSS.JS文件 <link rel="stylesheet" type="text/css" href="js ...
- Rabbitmq 加入用户訪控制台(guest无法登陆控制台问题)
对于rabbitmq的guest用户无法訪问控制台的问题,是由于rabbitmq做了安全措施,禁止guest登陆控制台.须要我们自己创建用户进行登陆 1,运行加入用户命令 rabbitmqctl ad ...
- 60分钟Python快速学习(转)
60分钟Python快速学习(给发哥一个交代) 阅读目录 第一步:开发环境搭建: 第一个Python功能:初识Python 02.Python中定义变量不需要数据类型 03.在Pythod中定义方法 ...
- HDU 4123 Bob’s Race 树的直径+单调队列
题意: 给定n个点的带边权树Q个询问. 以下n-1行给出树 以下Q行每行一个数字表示询问. 首先求出dp[N] :dp[i]表示i点距离树上最远点的距离 询问u, 表示求出 dp 数组中最长的连续序列 ...
- CentOS 7 / RHEL 7 上安装 LAMP + phpMyAdmin
原文 CentOS 7 / RHEL 7 上安装 LAMP + phpMyAdmin 发表于 2014-11-02 作者 Haoxian Zeng 更新于 2014-12-12 之前根据在 Lin ...
- polay定理总结
参考资料:url=YveSCnlx_dlXo4oGjE8w3_2QRObRXvXMbix81ppCxBGqBswxffwDN9frzY5xxaKf7GgEMY8K93JTPEhkBzY66XOaN0G ...
- Apache conf文件配置个人总结
其实说到conf文件的配置,网上那必定是大堆大堆的,故今儿写着篇小博文,也只是做个总结,至于分享的价值吗,如果对屏幕前的你有用,我也很乐意啦. 首先,我们要找到Apache安装目录,我的是Ap ...
- oracle_删除同一列的重复数据
<!--删除同一列的重复数据 rowid 在orcle中 数据的物理地址---> delete from tbl_over_picture_alarm a where rowid not ...