实例介绍
【实例简介】
【实例截图】
【核心代码】
using System; using System.Collections; using System.IO; using System.Drawing; using System.Drawing.Imaging; using System.Drawing.Drawing2D; using System.Collections.Generic; namespace ComLibiary { /// <summary> /// 图片帮助类(静态方法) /// 作者:刘宏科 /// </summary> public class ImageHelper { /// <summary> /// 图片帮助类(静态方法) /// 作者:刘宏科 /// </summary> public ImageHelper() { } #region 图片合成 private enum Merger { /// <summary> /// 垂直合成自上而下 /// </summary> vertical, /// <summary> /// 水平合成从左到右 /// </summary> horizontal } /// <summary> /// 从文件加载多个图像(不会锁定文件) /// </summary> /// <param name="filepaths">文件列表</param> /// <returns></returns> public static System.Drawing.Bitmap[] LoadFromFiles(string[] filepaths) { Bitmap[] imas = new Bitmap[filepaths.Length]; for (int i = 0; i < filepaths.Length; i ) { System.Drawing.Bitmap img = (Bitmap)Bitmap.FromFile(filepaths[i]); System.Drawing.Bitmap bmp = new System.Drawing.Bitmap(img); img.Dispose(); imas[i] = bmp; } return imas; } static void MergerImg(string[] filepaths, Merger m) { switch (m) { case Merger.vertical: MergerverticalImg(LoadFromFiles(filepaths)); break; case Merger.horizontal: MergerhorizontalImg(LoadFromFiles(filepaths)); break; default: break; } } static void MergerverticalImg(Bitmap[] arrMap) { //获取图片数组长度 int len = arrMap.Length; if (len == 0) { return; } //求数组中最宽图片的宽度 int maxWidth = 0; //计算图片的总数 int sumHeight = 0; for (int i = 0; i < len; i ) { maxWidth = Math.Max(maxWidth, arrMap[i].Width); sumHeight = arrMap[i].Height; } //创建一个位图 Bitmap bgImg = new Bitmap(maxWidth, sumHeight); Graphics g = Graphics.FromImage(bgImg); //清除画布,背景设置为白色 g.Clear(Color.White); int gHeight = 0; for (int i = 0; i < len; i ) { gHeight = i == 0 ? 0 : gHeight = arrMap[i - 1].Height gHeight; g.DrawImage(arrMap[i], 0, gHeight, arrMap[i].Width, arrMap[i].Height); } g.Dispose(); bgImg.Save(@"图片合成\合成结果.png"); } static void MergerhorizontalImg(Bitmap[] arrMap) { //获取图片数组长度 int len = arrMap.Length; if (len == 0) { return; } //求数组中最宽图片的高度 int maxHeight = 0; //计算图片的总数 int sumWidth = 0; for (int i = 0; i < len; i ) { maxHeight = Math.Max(maxHeight, arrMap[i].Height); sumWidth = arrMap[i].Width; } //创建一个位图 Bitmap bgImg = new Bitmap(sumWidth, maxHeight); Graphics g = Graphics.FromImage(bgImg); //清除画布,背景设置为白色 g.Clear(Color.White); int gWidth = 0; for (int i = 0; i < len; i ) { gWidth = i == 0 ? 0 : gWidth = arrMap[i - 1].Width gWidth; g.DrawImage(arrMap[i], gWidth, 0, arrMap[i].Width, arrMap[i].Height); } g.Dispose(); bgImg.Save(@"图片合成\合成结果.png"); } #endregion #region 图片切割 /// <summary> /// 从文件加载图像(不会锁定文件) /// </summary> /// <param name="filepath"></param> /// <returns></returns> public static System.Drawing.Image LoadFromFile(string filepath) { System.Drawing.Image img = System.Drawing.Image.FromFile(filepath); System.Drawing.Image bmp = new System.Drawing.Bitmap(img); img.Dispose(); return bmp; } /// <summary> /// 按照指定尺寸分割图像 /// </summary> /// <param name="filePath">图像的路径</param> /// <param name="sizeW">每个图像的宽度</param> /// <param name="sizeH">每个图像的高度</param> /// <param name="RowCount">行数</param> /// <returns></returns> public static List<System.Drawing.Image> SplitImage(string filePath, int sizeW, int sizeH, out int RowCount) { return SplitImage(LoadFromFile(filePath), sizeW, sizeH, out RowCount); } /// <summary> /// 按照指定尺寸分割图像 /// </summary> /// <param name="img">要分割的图像</param> /// <param name="sizeW">每个图像的宽度</param> /// <param name="sizeH">每个图像的高度</param> /// <param name="RowCount">行数</param> /// <returns></returns> private static List<System.Drawing.Image> SplitImage(System.Drawing.Image img, int sizeW, int sizeH, out int RowCount) { if (img == null) throw new ArgumentNullException("img"); else if (img.Width < sizeW) throw new ArgumentOutOfRangeException("sizeW"); else if (img.Height < sizeH) throw new ArgumentOutOfRangeException("sizeH"); List<System.Drawing.Image> imglist = new List<System.Drawing.Image>(); int startIndex = 0; int startY = 0; RowCount = 0; while (startY < img.Height) { if (sizeH startY > img.Height) continue; while (startIndex < img.Width) { if (startIndex sizeW > img.Width) continue; System.Drawing.Image img1 = new System.Drawing.Bitmap(sizeW, sizeH); System.Drawing.Graphics g = System.Drawing.Graphics.FromImage(img1); g.DrawImage(img, 0F, 0F, new System.Drawing.Rectangle(startIndex, startY, sizeW, sizeH), System.Drawing.GraphicsUnit.Pixel); g.Flush(); g.Dispose(); imglist.Add(img1); startIndex = sizeW; } RowCount ; startY = sizeH; } return imglist; } #endregion #region 缩略图 /// <summary> /// 生成缩略图 /// </summary> /// <param name="originalImagePath">源图路径(物理路径)</param> /// <param name="thumbnailPath">缩略图路径(物理路径)</param> /// <param name="width">缩略图宽度</param> /// <param name="height">缩略图高度</param> /// <param name="mode">生成缩略图的方式</param> public static void MakeThumbnail(string originalImagePath, string thumbnailPath, int width, int height, string mode) { System.Drawing.Image originalImage = System.Drawing.Image.FromFile(originalImagePath); int towidth = width; int toheight = height; int x = 0; int y = 0; int ow = originalImage.Width; int oh = originalImage.Height; switch (mode) { case "HW": //指定高宽缩放(可能变形) break; case "W": //指定宽,高按比例 toheight = originalImage.Height * width / originalImage.Width; break; case "H": //指定高,宽按比例 towidth = originalImage.Width * height / originalImage.Height; break; case "Cut": //指定高宽裁减(不变形) if ((double)originalImage.Width / (double)originalImage.Height > (double)towidth / (double)toheight) { oh = originalImage.Height; ow = originalImage.Height * towidth / toheight; y = 0; x = (originalImage.Width - ow) / 2; } else { ow = originalImage.Width; oh = originalImage.Width * height / towidth; x = 0; y = (originalImage.Height - oh) / 2; } break; default: break; } //新建一个bmp图片 System.Drawing.Image bitmap = new System.Drawing.Bitmap(towidth, toheight); //新建一个画板 System.Drawing.Graphics g = System.Drawing.Graphics.FromImage(bitmap); //设置高质量插值法 g.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.High; //设置高质量,低速度呈现平滑程度 g.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.HighQuality; //清空画布并以透明背景色填充 g.Clear(System.Drawing.Color.Transparent); //在指定位置并且按指定大小绘制原图片的指定部分 g.DrawImage(originalImage, new System.Drawing.Rectangle(0, 0, towidth, toheight), new System.Drawing.Rectangle(x, y, ow, oh), System.Drawing.GraphicsUnit.Pixel); try { //以png格式保存缩略图 bitmap.Save(thumbnailPath, System.Drawing.Imaging.ImageFormat.Png); } catch (System.Exception e) { throw e; } finally { originalImage.Dispose(); bitmap.Dispose(); g.Dispose(); } } #endregion #region 图片水印 /// <summary> /// 图片水印处理方法 /// </summary> /// <param name="path">需要加载水印的图片路径(绝对路径)</param> /// <param name="waterpath">水印图片(绝对路径)</param> /// <param name="location">水印位置(传送正确的代码)</param> public static string ImageWatermark(string path, string waterpath, string location) { string kz_name = Path.GetExtension(path); if (kz_name == ".jpg" || kz_name == ".bmp" || kz_name == ".jpeg" || kz_name == ".png") { DateTime time = DateTime.Now; string filename = "" time.Year.ToString() time.Month.ToString() time.Day.ToString() time.Hour.ToString() time.Minute.ToString() time.Second.ToString() time.Millisecond.ToString(); Image img = Bitmap.FromFile(path); Image waterimg = Image.FromFile(waterpath); Graphics g = Graphics.FromImage(img); ArrayList loca = GetLocation(location, img, waterimg); g.DrawImage(waterimg, new Rectangle(int.Parse(loca[0].ToString()), int.Parse(loca[1].ToString()), waterimg.Width, waterimg.Height)); waterimg.Dispose(); g.Dispose(); string newpath = Path.GetDirectoryName(path) filename kz_name; img.Save(newpath); img.Dispose(); File.Copy(newpath, path, true); if (File.Exists(newpath)) { File.Delete(newpath); } } return path; } /// <summary> /// 图片水印位置处理方法 /// </summary> /// <param name="location">水印位置</param> /// <param name="img">需要添加水印的图片</param> /// <param name="waterimg">水印图片</param> private static ArrayList GetLocation(string location, Image img, Image waterimg) { ArrayList loca = new ArrayList(); int x = 0; int y = 0; if (location == "LT") { x = 10; y = 10; } else if (location == "T") { x = img.Width / 2 - waterimg.Width / 2; y = img.Height - waterimg.Height; } else if (location == "RT") { x = img.Width - waterimg.Width; y = 10; } else if (location == "LC") { x = 10; y = img.Height / 2 - waterimg.Height / 2; } else if (location == "C") { x = img.Width / 2 - waterimg.Width / 2; y = img.Height / 2 - waterimg.Height / 2; } else if (location == "RC") { x = img.Width - waterimg.Width; y = img.Height / 2 - waterimg.Height / 2; } else if (location == "LB") { x = 10; y = img.Height - waterimg.Height; } else if (location == "B") { x = img.Width / 2 - waterimg.Width / 2; y = img.Height - waterimg.Height; } else { x = img.Width - waterimg.Width; y = img.Height - waterimg.Height; } loca.Add(x); loca.Add(y); return loca; } #endregion #region 文字水印 /// <summary> /// 文字水印处理方法 /// </summary> /// <param name="path">图片路径(绝对路径)</param> /// <param name="size">字体大小</param> /// <param name="letter">水印文字</param> /// <param name="color">颜色</param> /// <param name="location">水印位置</param> public static string LetterWatermark(string path, int size, string letter, Color color, string location) { #region string kz_name = Path.GetExtension(path); if (kz_name == ".jpg" || kz_name == ".bmp" || kz_name == ".jpeg") { DateTime time = DateTime.Now; string filename = "" time.Year.ToString() time.Month.ToString() time.Day.ToString() time.Hour.ToString() time.Minute.ToString() time.Second.ToString() time.Millisecond.ToString(); Image img = Bitmap.FromFile(path); Graphics gs = Graphics.FromImage(img); ArrayList loca = GetLocation(location, img, size, letter.Length); Font font = new Font("宋体", size); Brush br = new SolidBrush(color); gs.DrawString(letter, font, br, float.Parse(loca[0].ToString()), float.Parse(loca[1].ToString())); gs.Dispose(); string newpath = Path.GetDirectoryName(path) filename kz_name; img.Save(newpath); img.Dispose(); File.Copy(newpath, path, true); if (File.Exists(newpath)) { File.Delete(newpath); } } return path; #endregion } /// <summary> /// 文字水印位置的方法 /// </summary> /// <param name="location">位置代码</param> /// <param name="img">图片对象</param> /// <param name="width">宽(当水印类型为文字时,传过来的就是字体的大小)</param> /// <param name="height">高(当水印类型为文字时,传过来的就是字符的长度)</param> private static ArrayList GetLocation(string location, Image img, int width, int height) { #region ArrayList loca = new ArrayList(); //定义数组存储位置 float x = 10; float y = 10; if (location == "LT") { loca.Add(x); loca.Add(y); } else if (location == "T") { x = img.Width / 2 - (width * height) / 2; loca.Add(x); loca.Add(y); } else if (location == "RT") { x = img.Width - width * height; } else if (location == "LC") { y = img.Height / 2; } else if (location == "C") { x = img.Width / 2 - (width * height) / 2; y = img.Height / 2; } else if (location == "RC") { x = img.Width - height; y = img.Height / 2; } else if (location == "LB") { y = img.Height - width - 5; } else if (location == "B") { x = img.Width / 2 - (width * height) / 2; y = img.Height - width - 5; } else { x = img.Width - width * height; y = img.Height - width - 5; } loca.Add(x); loca.Add(y); return loca; #endregion } #endregion #region 调整光暗 /// <summary> /// 调整光暗 /// </summary> /// <param name="mybm">原始图片</param> /// <param name="width">原始图片的长度</param> /// <param name="height">原始图片的高度</param> /// <param name="val">增加或减少的光暗值</param> public Bitmap LDPic(Bitmap mybm, int width, int height, int val) { Bitmap bm = new Bitmap(width, height);//初始化一个记录经过处理后的图片对象 int x, y, resultR, resultG, resultB;//x、y是循环次数,后面三个是记录红绿蓝三个值的 Color pixel; for (x = 0; x < width; x ) { for (y = 0; y < height; y ) { pixel = mybm.GetPixel(x, y);//获取当前像素的值 resultR = pixel.R val;//检查红色值会不会超出[0, 255] resultG = pixel.G val;//检查绿色值会不会超出[0, 255] resultB = pixel.B val;//检查蓝色值会不会超出[0, 255] bm.SetPixel(x, y, Color.FromArgb(resultR, resultG, resultB));//绘图 } } return bm; } #endregion #region 反色处理 /// <summary> /// 反色处理 /// </summary> /// <param name="mybm">原始图片</param> /// <param name="width">原始图片的长度</param> /// <param name="height">原始图片的高度</param> public Bitmap RePic(Bitmap mybm, int width, int height) { Bitmap bm = new Bitmap(width, height);//初始化一个记录处理后的图片的对象 int x, y, resultR, resultG, resultB; Color pixel; for (x = 0; x < width; x ) { for (y = 0; y < height; y ) { pixel = mybm.GetPixel(x, y);//获取当前坐标的像素值 resultR = 255 - pixel.R;//反红 resultG = 255 - pixel.G;//反绿 resultB = 255 - pixel.B;//反蓝 bm.SetPixel(x, y, Color.FromArgb(resultR, resultG, resultB));//绘图 } } return bm; } #endregion #region 浮雕处理 /// <summary> /// 浮雕处理 /// </summary> /// <param name="oldBitmap">原始图片</param> /// <param name="Width">原始图片的长度</param> /// <param name="Height">原始图片的高度</param> public Bitmap FD(Bitmap oldBitmap, int Width, int Height) { Bitmap newBitmap = new Bitmap(Width, Height); Color color1, color2; for (int x = 0; x < Width - 1; x ) { for (int y = 0; y < Height - 1; y ) { int r = 0, g = 0, b = 0; color1 = oldBitmap.GetPixel(x, y); color2 = oldBitmap.GetPixel(x 1, y 1); r = Math.Abs(color1.R - color2.R 128); g = Math.Abs(color1.G - color2.G 128); b = Math.Abs(color1.B - color2.B 128); if (r > 255) r = 255; if (r < 0) r = 0; if (g > 255) g = 255; if (g < 0) g = 0; if (b > 255) b = 255; if (b < 0) b = 0; newBitmap.SetPixel(x, y, Color.FromArgb(r, g, b)); } } return newBitmap; } #endregion #region 拉伸图片 /// <summary> /// 拉伸图片 /// </summary> /// <param name="bmp">原始图片</param> /// <param name="newW">新的宽度</param> /// <param name="newH">新的高度</param> public static Bitmap ResizeImage(Bitmap bmp, int newW, int newH) { try { Bitmap bap = new Bitmap(newW, newH); Graphics g = Graphics.FromImage(bap); g.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.HighQualityBicubic; g.DrawImage(bap, new Rectangle(0, 0, newW, newH), new Rectangle(0, 0, bap.Width, bap.Height), GraphicsUnit.Pixel); g.Dispose(); return bap; } catch { return null; } } #endregion #region 滤色处理 /// <summary> /// 滤色处理 /// </summary> /// <param name="mybm">原始图片</param> /// <param name="width">原始图片的长度</param> /// <param name="height">原始图片的高度</param> public Bitmap FilPic(Bitmap mybm, int width, int height) { Bitmap bm = new Bitmap(width, height);//初始化一个记录滤色效果的图片对象 int x, y; Color pixel; for (x = 0; x < width; x ) { for (y = 0; y < height; y ) { pixel = mybm.GetPixel(x, y);//获取当前坐标的像素值 bm.SetPixel(x, y, Color.FromArgb(0, pixel.G, pixel.B));//绘图 } } return bm; } #endregion #region 左右翻转 /// <summary> /// 左右翻转 /// </summary> /// <param name="mybm">原始图片</param> /// <param name="width">原始图片的长度</param> /// <param name="height">原始图片的高度</param> public Bitmap RevPicLR(Bitmap mybm, int width, int height) { Bitmap bm = new Bitmap(width, height); int x, y, z; //x,y是循环次数,z是用来记录像素点的x坐标的变化的 Color pixel; for (y = height - 1; y >= 0; y--) { for (x = width - 1, z = 0; x >= 0; x--) { pixel = mybm.GetPixel(x, y);//获取当前像素的值 bm.SetPixel(z , y, Color.FromArgb(pixel.R, pixel.G, pixel.B));//绘图 } } return bm; } #endregion #region 上下翻转 /// <summary> /// 上下翻转 /// </summary> /// <param name="mybm">原始图片</param> /// <param name="width">原始图片的长度</param> /// <param name="height">原始图片的高度</param> public Bitmap RevPicUD(Bitmap mybm, int width, int height) { Bitmap bm = new Bitmap(width, height); int x, y, z; Color pixel; for (x = 0; x < width; x ) { for (y = height - 1, z = 0; y >= 0; y--) { pixel = mybm.GetPixel(x, y);//获取当前像素的值 bm.SetPixel(x, z , Color.FromArgb(pixel.R, pixel.G, pixel.B));//绘图 } } return bm; } #endregion #region 压缩图片 /// <summary> /// 压缩到指定尺寸 /// </summary> /// <param name="oldfile">原文件</param> /// <param name="newfile">新文件</param> public bool Compress(string oldfile, string newfile) { try { System.Drawing.Image img = System.Drawing.Image.FromFile(oldfile); System.Drawing.Imaging.ImageFormat thisFormat = img.RawFormat; Size newSize = new Size(100, 125); Bitmap outBmp = new Bitmap(newSize.Width, newSize.Height); Graphics g = Graphics.FromImage(outBmp); g.CompositingQuality = CompositingQuality.HighQuality; g.SmoothingMode = SmoothingMode.HighQuality; g.InterpolationMode = InterpolationMode.HighQualityBicubic; g.DrawImage(img, new Rectangle(0, 0, newSize.Width, newSize.Height), 0, 0, img.Width, img.Height, GraphicsUnit.Pixel); g.Dispose(); EncoderParameters encoderParams = new EncoderParameters(); long[] quality = new long[1]; quality[0] = 100; EncoderParameter encoderParam = new EncoderParameter(System.Drawing.Imaging.Encoder.Quality, quality); encoderParams.Param[0] = encoderParam; ImageCodecInfo[] arrayICI = ImageCodecInfo.GetImageEncoders(); ImageCodecInfo jpegICI = null; for (int x = 0; x < arrayICI.Length; x ) if (arrayICI[x].FormatDescription.Equals("JPEG")) { jpegICI = arrayICI[x]; //设置JPEG编码 break; } img.Dispose(); if (jpegICI != null) outBmp.Save(newfile, System.Drawing.Imaging.ImageFormat.Jpeg); outBmp.Dispose(); return true; } catch { return false; } } #endregion #region 图片灰度化 /// <summary> /// 图片灰度化 /// </summary> /// <param name="c">颜色</param> /// <returns></returns> public Color Gray(Color c) { int rgb = Convert.ToInt32((double)(((0.3 * c.R) (0.59 * c.G)) (0.11 * c.B))); return Color.FromArgb(rgb, rgb, rgb); } #endregion #region 转换为黑白图片 /// <summary> /// 转换为黑白图片 /// </summary> /// <param name="mybm">要进行处理的图片</param> /// <param name="width">图片的长度</param> /// <param name="height">图片的高度</param> public Bitmap BWPic(Bitmap mybm, int width, int height) { Bitmap bm = new Bitmap(width, height); int x, y, result; //x,y是循环次数,result是记录处理后的像素值 Color pixel; for (x = 0; x < width; x ) { for (y = 0; y < height; y ) { pixel = mybm.GetPixel(x, y);//获取当前坐标的像素值 result = (pixel.R pixel.G pixel.B) / 3;//取红绿蓝三色的平均值 bm.SetPixel(x, y, Color.FromArgb(result, result, result)); } } return bm; } #endregion #region 获取图片中的各帧 /// <summary> /// 获取图片中的各帧 /// </summary> /// <param name="pPath">图片路径</param> /// <param name="pSavedPath">保存路径</param> public void GetFrames(string pPath, string pSavedPath) { Image gif = Image.FromFile(pPath); FrameDimension fd = new FrameDimension(gif.FrameDimensionsList[0]); int count = gif.GetFrameCount(fd); //获取帧数(gif图片可能包含多帧,其它格式图片一般仅一帧) for (int i = 0; i < count; i ) //以Jpeg格式保存各帧 { gif.SelectActiveFrame(fd, i); gif.Save(pSavedPath "\\frame_" i ".jpg", ImageFormat.Jpeg); } } #endregion } }
好例子网口号:伸出你的我的手 — 分享!
小贴士
感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。
- 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
- 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
- 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
- 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。
关于好例子网
本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明
网友评论
我要评论