C#圖片切割、圖片壓縮、縮略圖生成代碼匯總
更新時間:2021年09月01日 15:08:21 作者:李朝強(qiáng)
這篇文章主要為大家匯總了C#圖片切割、圖片壓縮、縮略圖生成代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文為大家整理了C#圖片切割、圖片壓縮、縮略圖生成的實現(xiàn)代碼,大家可以收藏,方便以后使用,具體內(nèi)容如下
/// 圖片切割函數(shù)
/// </summary>
/// <param name="sourceFile">原始圖片文件</param>
/// <param name="xNum">在X軸上的切割數(shù)量</param>
/// <param name="yNum">在Y軸上的切割數(shù)量</param>
/// <param name="quality">質(zhì)量壓縮比</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>
/// 圖片壓縮函數(shù)
/// </summary>
/// <param name="sourceFile">原始圖片文件</param>
/// <param name="quality">質(zhì)量壓縮比</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">質(zhì)量壓縮比</param>
/// <param name="multiple">收縮倍數(shù)</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;
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
算法練習(xí)之從String.indexOf的模擬實現(xiàn)開始
這篇文章主要介紹了算法練習(xí)從String.indexOf的模擬實現(xiàn)開始,需要的朋友可以參考下2014-12-12

