欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#圖片處理類分享

 更新時間:2017年06月29日 09:44:10   作者:孤者自清  
這篇文章主要為大家分享了C#圖片處理類的相關(guān)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了C#圖片處理類的具體代碼,供大家參考,具體內(nèi)容如下

using System;
using System.Collections;
using System.IO;
using System.Drawing;
using System.Drawing.Imaging;
using System.Drawing.Drawing2D;

namespace DotNet.Utilities
{
 public class ImageClass
 {
  public ImageClass()
  { }

  #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);

   //設(shè)置高質(zhì)量插值法
   g.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.High;

   //設(shè)置高質(zhì)量,低速度呈現(xiàn)平滑程度
   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
   {
    //以jpg格式保存縮略圖
    bitmap.Save(thumbnailPath, System.Drawing.Imaging.ImageFormat.Jpeg);
   }
   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")
   {
    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">寬(當(dāng)水印類型為文字時,傳過來的就是字體的大小)</param>
  /// <param name="height">高(當(dāng)水印類型為文字時,傳過來的就是字符的長度)</param>
  private static ArrayList GetLocation(string location, Image img, int width, int height)
  {
   #region

   ArrayList loca = new ArrayList(); //定義數(shù)組存儲位置
   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 調(diào)整光暗
  /// <summary>
  /// 調(diào)整光暗
  /// </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);//初始化一個記錄經(jīng)過處理后的圖片對象
   int x, y, resultR, resultG, resultB;//x、y是循環(huán)次數(shù),后面三個是記錄紅綠藍三個值的
   Color pixel;
   for (x = 0; x < width; x++)
   {
    for (y = 0; y < height; y++)
    {
     pixel = mybm.GetPixel(x, y);//獲取當(dāng)前像素的值
     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);//獲取當(dāng)前坐標(biāo)的像素值
     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);//獲取當(dāng)前坐標(biāo)的像素值
     bm.SetPixel(x, y, Color.FromArgb(0, pixel.G, pixel.B));//繪圖
    }
   }
   return bm;
  }
  #endregion

  #region 左右翻轉(zhuǎn)
  /// <summary>
  /// 左右翻轉(zhuǎn)
  /// </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是循環(huán)次數(shù),z是用來記錄像素點的x坐標(biāo)的變化的
   Color pixel;
   for (y = height - 1; y >= 0; y--)
   {
    for (x = width - 1, z = 0; x >= 0; x--)
    {
     pixel = mybm.GetPixel(x, y);//獲取當(dāng)前像素的值
     bm.SetPixel(z++, y, Color.FromArgb(pixel.R, pixel.G, pixel.B));//繪圖
    }
   }
   return bm;
  }
  #endregion

  #region 上下翻轉(zhuǎn)
  /// <summary>
  /// 上下翻轉(zhuǎn)
  /// </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);//獲取當(dāng)前像素的值
     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]; //設(shè)置JPEG編碼
      break;
     }
    img.Dispose();
    if (jpegICI != null) outBmp.Save(newfile, System.Drawing.Imaging.ImageFormat.Jpeg);
    outBmp.Dispose();
    return true;
   }
   catch
   {
    return false;
   }
  }
  #endregion

  #region 圖片灰度化
  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 轉(zhuǎn)換為黑白圖片
  /// <summary>
  /// 轉(zhuǎn)換為黑白圖片
  /// </summary>
  /// <param name="mybt">要進行處理的圖片</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是循環(huán)次數(shù),result是記錄處理后的像素值
   Color pixel;
   for (x = 0; x < width; x++)
   {
    for (y = 0; y < height; y++)
    {
     pixel = mybm.GetPixel(x, y);//獲取當(dāng)前坐標(biāo)的像素值
     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="pSavePath">保存路徑</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); //獲取幀數(shù)(gif圖片可能包含多幀,其它格式圖片一般僅一幀)
   for (int i = 0; i < count; i++) //以Jpeg格式保存各幀
   {
    gif.SelectActiveFrame(fd, i);
    gif.Save(pSavedPath + "\\frame_" + i + ".jpg", ImageFormat.Jpeg);
   }
  }
  #endregion
 }
}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C#使用SqlBulkCopy批量復(fù)制數(shù)據(jù)到數(shù)據(jù)表

    C#使用SqlBulkCopy批量復(fù)制數(shù)據(jù)到數(shù)據(jù)表

    這篇文章主要介紹了C#使用SqlBulkCopy批量復(fù)制數(shù)據(jù)到數(shù)據(jù)表的方法,較為詳細的講述了SqlBulkCopy批量復(fù)制數(shù)據(jù)到數(shù)據(jù)表的原理與實現(xiàn)技巧,需要的朋友可以參考下
    2014-10-10
  • 基于C#解決庫存扣減及訂單創(chuàng)建時防止并發(fā)死鎖的問題

    基于C#解決庫存扣減及訂單創(chuàng)建時防止并發(fā)死鎖的問題

    這篇文章主要介紹了基于C#解決庫存扣減及訂單創(chuàng)建時防止并發(fā)死鎖的問題,很多開發(fā)人員對于這個問題的排查起來是比較困難的,而生產(chǎn)生的原因多種多樣,很多人認是因為表中的數(shù)據(jù)太多了同時操作的人多人才會產(chǎn)生這種錯誤,下面我們來還原一下死鎖的過程
    2022-05-05
  • VMS中解協(xié)議常用方法備忘(小結(jié))

    VMS中解協(xié)議常用方法備忘(小結(jié))

    這篇文章主要介紹了VMS中解協(xié)議常用方法備忘(小結(jié)),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • 深入理解C#表達式樹的使用

    深入理解C#表達式樹的使用

    表達式樹是C#編程語言中一個強大的特性,本文將深入探討表達式樹的基本概念、創(chuàng)建方法、節(jié)點類型、遍歷技巧以及在C#中的應(yīng)用示例,感興趣的可以了解一下
    2024-03-03
  • C# 復(fù)制與刪除文件的實現(xiàn)方法

    C# 復(fù)制與刪除文件的實現(xiàn)方法

    這篇文章主要介紹了C# 復(fù)制與刪除文件的實現(xiàn)方法的相關(guān)資料,希望通過本文能幫助到大家,讓大家理解掌握這部分內(nèi)容,需要的朋友可以參考下
    2017-10-10
  • C#中Attribute特性的用法

    C#中Attribute特性的用法

    這篇文章介紹了C#中Attribute特性的用法,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-07-07
  • C# PLINQ 內(nèi)存列表查詢優(yōu)化歷程

    C# PLINQ 內(nèi)存列表查詢優(yōu)化歷程

    這篇文章主要介紹了C# PLINQ 內(nèi)存列表查詢優(yōu)化歷程的相關(guān)資料,需要的朋友可以參考下
    2016-03-03
  • C# Onnx實現(xiàn)特征匹配DeDoDe檢測

    C# Onnx實現(xiàn)特征匹配DeDoDe檢測

    這篇文章主要為大家詳細介紹了C# Onnx如何實現(xiàn)特征匹配DeDoDe檢測,文中的示例代碼講解詳細,具有一定的借鑒價值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-11-11
  • C#函數(shù)式編程中的遞歸調(diào)用之尾遞歸詳解

    C#函數(shù)式編程中的遞歸調(diào)用之尾遞歸詳解

    這篇文章主要介紹了C#函數(shù)式編程中的遞歸調(diào)用詳解,本文講解了什么是尾遞歸、尾遞歸的多種方式、尾遞歸的代碼實例等內(nèi)容,需要的朋友可以參考下
    2015-01-01
  • C#設(shè)計模式之裝飾器模式實例詳解

    C#設(shè)計模式之裝飾器模式實例詳解

    本文詳細講解了C#設(shè)計模式之裝飾器模式,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-10-10

最新評論