C#中图片切割,图片压缩,缩略图的生成

** <summary>
     /// 图片切割函数
    /// </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;
     }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值