/// <summary>
/// 无损压缩图片
/// </summary>
/// <param name="OldFile">原图片地址</param>
/// <param name="NewFile">压缩后保存图片地址</param>
/// <param name="Flag">压缩质量(数字越小压缩率越高)1-100</param>
/// <param name="Size">压缩后图片的最大大小</param>
/// <param name="Sfsc">是否是第一次调用</param>
/// <returns></returns>
private bool CompressImage(string OldFile, string NewFile, int Flag = 90, int Size = 5, bool Sfsc = true)
{
//如果是第一次调用,原始图像的大小小于要压缩的大小,则直接复制文件,并且返回true
FileInfo firstFileInfo = new FileInfo(OldFile);
if (Sfsc == true && firstFileInfo.Length < Size * 1024)
{
firstFileInfo.CopyTo(NewFile);
return true;
}
System.Drawing.Image iSource = System.Drawing.Image.FromFile(OldFile);//从原始图片路径创建新图片
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);//新建一个bmp图片
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(NewFile, jpegICIinfo, ep);//NewFile是压缩后的新路径
FileInfo fi = new FileInfo(NewFile);
if (fi.Length > 1024 * Size)
{
Flag = Flag - 10;
CompressImage(OldFile, NewFile, Flag, Size, false);
}
}
else
{
ob.Save(NewFile, tFormat);
}
return true;
}
catch
{
return false;
}
finally
{
iSource.Dispose();
ob.Dispose();
}
}
C#实现图片的无损压缩
于 2023-10-13 09:48:25 首次发布