C#處理JPEG頭信息的方法
曾經(jīng)有人給我了一張jpg,是1024*1024大小,文件大小為99kb,做了個(gè)金字塔,各層影像大小如下:單位kb
我生成的jpg金字塔 為經(jīng)過任何加工
height256 46.2kb
height512 162kb
height1024 557kb
Photoshop生成的jpg金字塔 為經(jīng)過任何加工
height256 48kb
height512 90kb
height1024 163kb
可以看出這個(gè)圖像大小差異太大了,我可是百思不得其解,最終看了上面那篇博文后,通過獲取元數(shù)據(jù)的方式來看看原因:
獲取元數(shù)據(jù)函數(shù)
public void GetProperty()
{
Bitmap myImage1024 = new Bitmap(@"E:\myjpg\height.jpg");
foreach (PropertyItem property in myImage1024.PropertyItems)
{
StringBuilder sb=new StringBuilder();
Byte[] sbbyte = (Byte[])property.Value;
sb.AppendFormat("ID:{0},Length:{1},Type:{2};\n",
property.Id.ToString(), property.Len.ToString(), property.Type.ToString(),);
Console.Write(sb);
}
}
發(fā)現(xiàn)我生成的jpg和原始圖片的元數(shù)據(jù)是不同的
height1024:
ID:771,Length:1,Type:1; 頭信息Tag解釋:303 PropertyTagSRGBRenderingIntent
ID:769,Length:8,Type:5; 頭信息Tag解釋:301 PropertyTagGamma
ID:20752,Length:1,Type:1; 頭信息Tag解釋:5110 PropertyTagPixelUnit 分辨率
ID:20753,Length:4,Type:4; 頭信息Tag解釋:5111 PropertyTagPixelPerUnitX
ID:20754,Length:4,Type:4; 頭信息Tag解釋:5112 PropertyTagPixelPerUnitY
height:
ID:20625,Length:128,Type:3;頭信息Tag解釋:5091 PropertyTagChrominanceTable
ID:20624,Length:128,Type:3; 頭信息Tag解釋:5090 PropertyTagLuminanceTable
原來如此,這樣我們就知道為什么jpg竟然不一樣大小了,那好吧,我就修改了生成了影像金字塔的方法:在保存金字塔之前,把他們的頭信息去掉。之后驚奇的發(fā)現(xiàn):我生成的影像金字塔的最精細(xì)層和原始圖像一樣大小了!。
去除影像元數(shù)據(jù)的方法:
public void RemoveProperty()
{
Bitmap myImage1024 = new Bitmap(@"E:\myjpg\height.jpg");
foreach (PropertyItem property in myImage1024.PropertyItems)
{
myImage1024.RemovePropertyItem(property.Id);
}
myImage1024.Save(@"E:\myjpg\nopro.jpg");
}
相關(guān)文章
Winform使用DataGridView實(shí)現(xiàn)下拉篩選
這篇文章主要為大家詳細(xì)介紹了Winform如何使用原生DataGridView實(shí)現(xiàn)下拉篩選功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起了解一下2023-09-09automation服務(wù)器不能創(chuàng)建對象 解決方法
本文主要介紹如何解決“automation服務(wù)器不能創(chuàng)建對象”錯(cuò)誤,從而解決Visual Studio.Net不能正常使用的問題,需要的朋友可以參考下。2016-06-06C#常用數(shù)據(jù)結(jié)構(gòu)之?dāng)?shù)組Array
這篇文章介紹了C#常用數(shù)據(jù)結(jié)構(gòu)之?dāng)?shù)組Array,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-05-05詳解C#實(shí)現(xiàn)在Excel單元格中應(yīng)用多種字體格式
在Excel中,可對單元格中的字符串設(shè)置多種不同樣式。本文,將以C#及VB.NET代碼為例,介紹如何在Excel同一個(gè)單元格中應(yīng)用多種字體樣式,感興趣的可以了解一下2022-05-05