c# 无损高质量压缩图片代码

博客分享了C#无损高质量压缩图片的代码。提到在优快云上看到一个压缩算法,经测试,将原始图像大小对半处理,迭代跳转压缩质量参数效果不错,并给出了具体的压缩图片代码,包含相关参数设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

c# 无损高质量压缩图片代码
在优快云上看到了一个压缩算法:http://blog.youkuaiyun.com/qq_16542775/article/details/51792149

进过测试这个算法,发现,将原始图像的大小进行对半处理,然后迭代跳转压缩质量参数,可以得到不错的效果。

代码如下:

///
/// 无损压缩图片
///
/// 原图片地址
/// 压缩后保存图片地址
/// 压缩质量(数字越小压缩率越高)1-100
/// 压缩后图片的最大大小
/// 是否是第一次调用
///

public static bool CompressImage(string sFile, string dFile, int flag = 90, int size = 300, bool sfsc = true)

{

//如果是第一次调用,原始图像的大小小于要压缩的大小,则直接复制文件,并且返回true

FileInfo firstFileInfo = new FileInfo(sFile);

if (sfsc == true && firstFileInfo.Length < size * 1024)

{

    firstFileInfo.CopyTo(dFile);
    
    return true;
    
}

Image iSource = Image.FromFile(sFile);

ImageFormat tFormat = iSource.RawFormat;

int dHeight = iSource.Height / 2;

int dWidth = iSource.Width / 2;

int sW = 0, sH = 0;

//按比例缩放
Size tem_size = new Size(iSource.Width, iSource.Height);

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;
}

Bitmap ob = new Bitmap(dWidth, dHeight);
Graphics g = Graphics.FromImage(ob);

g.Clear(Color.WhiteSmoke);
g.CompositingQuality = System.Drawing.Drawing2D.CompositingQuality.HighQuality;
g.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.HighQuality;
g.InterpolationMode = System.Drawing.Drawing2D.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是压缩后的新路径
        FileInfo fi = new FileInfo(dFile);
        if (fi.Length > 1024 * size)
        {
            flag = flag - 10;
            CompressImage(sFile, dFile, flag, size, false);
        }
    }
    else
    {
        ob.Save(dFile, tFormat);
    }
    return true;
}
catch
{
    return false;
}
finally
{
    iSource.Dispose();
    ob.Dispose();
}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值