c# 图片压缩类

    /// <summary>
    /// 无损压缩图片
    /// </summary>
    public class CompressPicture
    {
        /// <summary>
        /// 无损压缩图片
        /// </summary>
        /// <param name="imagePath">原始图片地址</param>
        /// <param name="zoomRate">尺寸缩放率</param>
        /// <param name="quality">压缩质量1-100</param>
        /// <returns>压缩图片</returns>
        public static byte[] Thumbnail(string imagePath, double zoomRate = 0.5, int quality = 50)
        {
            var originImageBytes = File.ReadAllBytes(imagePath);
            return Thumbnail(originImageBytes, zoomRate, quality);
        }

        /// <summary>
        /// 无损压缩图片
        /// </summary>
        /// <param name="originImageBytes">原始图片</param>
        /// <param name="zoomRate">尺寸缩放率</param>
        /// <param name="quality">压缩质量1-100</param>
        /// <returns>压缩图片</returns>
        public static byte[] Thumbnail(byte[] originImageBytes, double zoomRate = 0.5, int quality = 50)
        {
            int width = 0;
            int height = 0;
            using (MemoryStream ms = new MemoryStream(originImageBytes))
            {
                using (Image image = Image.FromStream(ms))
                {
                    width = (int)(zoomRate * image.Width);
                    height = (int)(zoomRate * image.Height);
                    if (width < 0)
                    {
                        width = 0;
                    }
                    if (height < 0)
                    {
                        height = 0;
                    }
                }
            }
            return Thumbnail(originImageBytes, width, height, quality);
        }

        /// <summary>
        /// 无损压缩图片
        /// </summary>
        /// <param name="imagePath">原始图片路径</param>
        /// <param name="width">目标宽度,0保持原图宽度</param>
        /// <param name="height">目标高度,0保持原图高度</param>
        /// <param name="quality">压缩质量1-100</param>
        /// <returns>压缩图片</returns>
        public static byte[] Thumbnail(string imagePath, int width = 0, int height = 0, int quality = 50)
        {
            var originImageBytes = File.ReadAllBytes(imagePath);
            return Thumbnail(originImageBytes, width, height, quality);
        }

        /// <summary>
        /// 无损压缩图片
        /// </summary>
        /// <param name="originImageBytes">原始图片</param>
        /// <param name="width">目标宽度,0保持原图宽度</param>
        /// <param name="height">目标高度,0保持原图高度</param>
        /// <param name="quality">压缩质量1-100</param>
        /// <returns>压缩图片</returns>
        public static byte[] Thumbnail(byte[] originImageBytes, int width = 0, int height = 0, int quality = 50)
        {
            using (MemoryStream ms = new MemoryStream(originImageBytes))
            {
                using (Image image = Image.FromStream(ms))
                {
                    if (width <= 0)
                    {
                        width = image.Width;
                    }
                    if (height <= 0)
                    {
                        height = image.Height;
                    }
                    return GetPicThumbnail(image, height, width, quality);
                }
            }
        }

        /// <summary>
        /// 无损压缩图片
        /// </summary>
        /// <param name="image">原图片</param>  
        /// <param name="dHeight">高度</param>  
        /// <param name="dWidth">宽度</param>  
        /// <param name="quality">压缩质量(数字越小压缩率越高) 1-100</param>  
        /// <returns></returns>  
        private static byte[] GetPicThumbnail(Image image, int dHeight, int dWidth, int quality)
        {
            if (quality > 100)
            {
                quality = 100;
            }
            if (quality < 1)
            {
                quality = 1;
            }

            //按比例缩放
            Size tem_size = new Size(image.Width, image.Height);
            int sW;
            int sH;
            if (tem_size.Width > dHeight || tem_size.Width > dWidth)
            {
                if ((tem_size.Width * dHeight) > (tem_size.Width * 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;
            }

            //以下代码为保存图片时,设置压缩质量  
            using (EncoderParameters ep = new EncoderParameters(3))
            {
                long[] qy = new long[1];
                qy[0] = quality;//设置压缩的比例1-100  
                ep.Param[0] = new EncoderParameter(Encoder.Quality, qy);
                ep.Param[1] = new EncoderParameter(Encoder.Compression, (long)EncoderValue.CompressionLZW);
                ep.Param[2] = new EncoderParameter(Encoder.ColorDepth, (long)EncoderValue.ColorTypeCMYK);

                if (dWidth == image.Width && dHeight == image.Height)
                {
                    try
                    {
                        ImageCodecInfo jpegICIinfo = GetEncoder(image.RawFormat);
                        if (jpegICIinfo != null && quality < 100)
                        {
                            using (MemoryStream m = new MemoryStream())
                            {
                                image.Save(m, jpegICIinfo, ep);
                                var data = m.ToArray();
                                return data;
                            }
                        }
                        else
                        {
                            using (MemoryStream m = new MemoryStream())
                            {
                                image.Save(m, image.RawFormat);
                                var data = m.ToArray();
                                return data;
                            }
                        }
                    }
                    catch
                    {
                        return null;
                    }
                }

                using (Bitmap ob = new Bitmap(dWidth, dHeight))
                {
                    using (Graphics g = Graphics.FromImage(ob))
                    {
                        g.Clear(Color.WhiteSmoke);
                        g.CompositingQuality = CompositingQuality.HighQuality;
                        g.SmoothingMode = SmoothingMode.HighQuality;
                        g.InterpolationMode = InterpolationMode.HighQualityBicubic;
                        g.DrawImage(image, new Rectangle((dWidth - sW) / 2, (dHeight - sH) / 2, sW, sH), 0, 0, image.Width, image.Height, GraphicsUnit.Pixel);
                    }
                    try
                    {
                        ImageCodecInfo imageCodecInfo = GetEncoder(image.RawFormat);
                        if (imageCodecInfo != null && quality < 100)
                        {
                            using (MemoryStream m = new MemoryStream())
                            {
                                ob.Save(m, imageCodecInfo, ep);
                                return m.ToArray();
                            }
                        }
                        else
                        {
                            using (MemoryStream m = new MemoryStream())
                            {
                                ob.Save(m, image.RawFormat);
                                return m.ToArray();
                            }
                        }
                    }
                    catch
                    {
                        return null;
                    }
                };
            };
        }

        /// <summary>
        /// GetEncoder
        /// </summary>
        /// <param name="format">ImageFormat</param>
        /// <returns>ImageCodecInfo</returns>
        private static ImageCodecInfo GetEncoder(ImageFormat format)
        {
            ImageCodecInfo[] codecs = ImageCodecInfo.GetImageEncoders();
            foreach (ImageCodecInfo codec in codecs)
            {
                if (codec.FormatID == format.Guid)
                { return codec; }
            }
            return null;
        }
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

deanZZZZZZ

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值