C#图片无损压缩

//引用命名空间
using System.Drawing.Imaging;
using System.Drawing;
using System.Drawing.Drawing2D;
#region GetPicThumbnail
    /// <summary>
    /// 无损压缩图片
    /// </summary>
    /// <param name="sFile">原图片</param>
    /// <param name="dFile">压缩后保存位置</param>
    /// <param name="dHeight">高度</param>
    /// <param name="dWidth"></param>
    /// <param name="flag">压缩质量 1-100</param>
    /// <returns></returns>
 
    public bool GetPicThumbnail(string sFile, string dFile, int dHeight, int dWidth, int flag)
    {
        System.Drawing.Image iSource = System.Drawing.Image.FromFile(sFile);
 
        ImageFormat tFormat = iSource.RawFormat;
 
        int sW = 0, sH = 0;
 
        //按比例缩放
 
        Size tem_size = new Size(iSource.Width, iSource.Height);
 
 
 
        if (tem_size.Width > dHeight || tem_size.Width > dWidth) //将**改成c#中的或者操作符号
        {
 
            if ((tem_size.Width * dHeight) > (tem_size.Height * dWidth))
            {
 
                sW = dWidth;
 
                sH = (dWidth * tem_size.Height) / tem_size.Width;
 
            }
 
            else
            {
 
                sH = dHeight;
 
                sW = (tem_size.Width * dHeight) / tem_size.Height;
 
            }
 
        }
 
        else
        {
 
            sW = tem_size.Width;
 
            sH = tem_size.Height;
 
        }
 
        Bitmap ob = new Bitmap(dWidth, dHeight);
 
        Graphics g = Graphics.FromImage(ob);
 
        g.Clear(Color.WhiteSmoke);
 
        g.CompositingQuality = CompositingQuality.HighQuality;
 
        g.SmoothingMode = SmoothingMode.HighQuality;
 
        g.InterpolationMode = InterpolationMode.HighQualityBicubic;
 
        g.DrawImage(iSource, new Rectangle((dWidth - sW) / 2, (dHeight - sH) / 2, sW, sH), 0, 0, iSource.Width, iSource.Height, GraphicsUnit.Pixel);
 
        g.Dispose();
 
        //以下代码为保存图片时,设置压缩质量
 
        EncoderParameters ep = new EncoderParameters();
 
        long[] qy = new long[1];
 
        qy[0] = flag;//设置压缩的比例1-100
 
        EncoderParameter eParam = new EncoderParameter(System.Drawing.Imaging.Encoder.Quality, qy);
 
        ep.Param[0] = eParam;
 
        try
        {
 
            ImageCodecInfo[] arrayICI = ImageCodecInfo.GetImageEncoders();
 
            ImageCodecInfo jpegICIinfo = null;
 
            for (int x = 0; x < arrayICI.Length; x++)
            {
 
                if (arrayICI[x].FormatDescription.Equals("JPEG"))
                {
 
                    jpegICIinfo = arrayICI[x];
 
                    break;
 
                }
 
            }
 
            if (jpegICIinfo != null)
            {
 
                ob.Save(dFile, jpegICIinfo, ep);//dFile是压缩后的新路径
 
            }
 
            else
            {
 
                ob.Save(dFile, tFormat);
 
            }
 
            return true;
 
        }
 
        catch
        {
 
            return false;
 
        }
 
        finally
        {
 
            iSource.Dispose();
 
            ob.Dispose();
 
        }
 
 
 
    }
     #endregion
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值