zoukankan      html  css  js  c++  java
  • C#图片切割、图片压缩、缩略图生成

    C#图片切割、图片压缩、缩略图生成的实现代码
    /// 图片切割函数
     /// </summary>
     /// <param name="sourceFile">原始图片文件</param>
     /// <param name="xNum">在X轴上的切割数量</param>
     /// <param name="yNum">在Y轴上的切割数量</param>
     /// <param name="quality">质量压缩比</param>
     /// <param name="outputFile">输出文件名,不带后缀</param>
     /// <returns>成功返回true,失败则返回false</returns>
     public static bool imageCut(String sourceFile, int xNum, int yNum, long quality, String outputFile)
     {
      try
      {
       long imageQuality      = quality;
       Bitmap sourceImage      = new Bitmap(sourceFile);
       ImageCodecInfo myImageCodecInfo   = GetEncoderInfo("image/jpeg");
       Encoder myEncoder      = Encoder.Quality;
       EncoderParameters myEncoderParameters = new EncoderParameters(1);
       EncoderParameter myEncoderParameter  = new EncoderParameter(myEncoder, imageQuality);
       myEncoderParameters.Param[0]    = myEncoderParameter;
       float xWidth        = sourceImage.Width / xNum;
       float yWidth        = sourceImage.Height / yNum;
       String outputImage      = "";
         
       for (int countY = 0; countY < yNum; countY++)
        for (int countX = 0; countX < xNum; countX++)
        {
      
         RectangleF cloneRect    = new RectangleF(countX * xWidth, countY * yWidth, xWidth, yWidth);
         Bitmap newImage     = sourceImage.Clone(cloneRect, PixelFormat.Format24bppRgb);
         outputImage      = outputFile + countX + countY + ".jpg";
         newImage.Save(outputImage, myImageCodecInfo, myEncoderParameters);
      
        }
       return true;
      }
      catch
      {
       return false;
      }
      
     }
     #endregion imageCut
      
     imageCompress
    #region
    imageCompress
     /**//// <summary>
     /// 图片压缩函数
     /// </summary>
     /// <param name="sourceFile">原始图片文件</param>
     /// <param name="quality">质量压缩比</param>
     /// <param name="ouputFile">输出文件名,请用 .jpg 后缀 </param>
     /// <returns>成功返回true,失败则返回false</returns>
     public static bool imageCompress(String sourceFile,long quality,String outputFile)
     {
      try
      {
       long imageQuality      = quality;
       Bitmap sourceImage      = new Bitmap(sourceFile);
       ImageCodecInfo myImageCodecInfo  = GetEncoderInfo("image/jpeg");
       Encoder myEncoder      = Encoder.Quality;
       EncoderParameters myEncoderParameters = new EncoderParameters(1);
       EncoderParameter myEncoderParameter = new EncoderParameter(myEncoder, imageQuality);
       myEncoderParameters.Param[0]   = myEncoderParameter;
        
       sourceImage.Save(outputFile, myImageCodecInfo, myEncoderParameters);
       return true;
      
      }
      catch
      {
       return false;
      }
      
     }
     #endregion imageCompress
      
     getThumImage#region getThumImage
     /**//// <summary>
     /// 生成缩略图
     /// </summary>
     /// <param name="sourceFile">原始图片文件</param>
     /// <param name="quality">质量压缩比</param>
     /// <param name="multiple">收缩倍数</param>
     /// <param name="outputFile">输出文件名</param>
     /// <returns>成功返回true,失败则返回false</returns>
     public static bool getThumImage(String sourceFile, long quality, int multiple, String outputFile)
     {
      try
      {
       long imageQuality      = quality;
       Bitmap sourceImage      = new Bitmap(sourceFile);
       ImageCodecInfo myImageCodecInfo  = GetEncoderInfo("image/jpeg");
       Encoder myEncoder      = Encoder.Quality;
       EncoderParameters myEncoderParameters = new EncoderParameters(1);
       EncoderParameter myEncoderParameter = new EncoderParameter(myEncoder, imageQuality);
       myEncoderParameters.Param[0]   = myEncoderParameter;
       float xWidth       = sourceImage.Width;
       float yWidth       = sourceImage.Height;
       Bitmap newImage      = new Bitmap((int)(xWidth /multiple), (int)(yWidth /multiple));
       Graphics g        = Graphics.FromImage(newImage);
         
       g.DrawImage(sourceImage, 0, 0, xWidth / multiple, yWidth / multiple);
       g.Dispose();
       newImage.Save(outputFile,myImageCodecInfo,myEncoderParameters);
       return true;
      }
      catch
      {
       return false;
      }
     }
     #endregion getThumImage
      
     ImageCodecInfo#region ImageCodecInfo
     /**//// <summary>
     /// 获取图片编码信息
     /// </summary>
     private static ImageCodecInfo GetEncoderInfo(String mimeType)
     {
      int j;
      ImageCodecInfo[] encoders;
      encoders = ImageCodecInfo.GetImageEncoders();
      for (j = 0; j < encoders.Length; ++j)
      {
       if (encoders[j].MimeType == mimeType)
        return encoders[j];
      }
      return null;
     }
  • 相关阅读:
    Andrej Karpathy的char-rnn Python3版本
    【转载】各位设备爹 来说说不用效果器的牛逼乐队吧
    为什么原始人和小动物不需要艺术?
    子非我焉知我之怒?人与人的悲欢并不相通
    尼采喜欢跳舞?论“每一个不曾起舞的日子 都是对生命的辜负真的”的误译!
    Thinkpad已不是曾经的IBM Thinkpad,联想已不是曾经的联想
    简单二进制编码(SBE)
    挪威志愿消防员笑话
    挪威的概念消防车
    一些有意思的牛津辩题
  • 原文地址:https://www.cnblogs.com/1175429393wljblog/p/5871239.html
Copyright © 2011-2022 走看看