C#生成影像金字塔的原理實例
這里首先先講一下金字塔的原理:
影像金字塔就是把一個原始圖像處理成一個類似于塔狀的影像結構(請不要糾結于這個概念)
在影像金字塔中最精細層的分辨率為16*16,下一層是8*8,依次為4*4,2*2,1*1
如下圖所示:
圖中網格頂點表示原始圖像16*16;紅色差號代表8*8;黑色圓圈代表4*4.
按照上述原理,那么編程實現(xiàn)不過就是隔點采樣,那么相鄰兩幅圖像在對應點上的灰度值應該相等,當然我是這么想的。
C#在Drawing命名空間下的Bitmap類里面有一個處理影像金字塔的函數(shù),
public void mipmaping()
{
Bitmap jpgsource =new Bitmap(@"E:\height512.jpg");
Bitmap jpgTarget = new Bitmap(jpgsource, jpgsource.Width>>1, jpgsource.Height>>1);
jpgTarget.Save(@"E:\height256.jpg");
}
但是經過我逐像素對比之后,發(fā)現(xiàn)這兩張圖上對應點的像素并不相等,這說明一個問題:C#里的這個方法肯定不是按照逐點采樣,而是采用某種方法把圖像拉伸的。這似乎不太符合金字塔的原理,所以我又重新寫了一個金字塔的函數(shù):
public void Rescale()
{
Bitmap myImage1024 = new Bitmap(@"E:\height.jpg");
int width = myImage1024.Height; ;
int height = myImage1024.Width; ;
Console.WriteLine(DateTime.Now.ToString());
for (int power = 1; power < 3; power++)
{
Bitmap myImage = new Bitmap(width >> power, height >> power);
int row = myImage.Height;
int column = myImage.Width;
for (int i = 0; i < row; i++)
for (int j = 0; j < column; j++)
{ //這里是精要,實際上就是按照采樣間距 踩點
int i1024 = getcoor(i, power); int j1024 = getcoor(j, power);
Color color1024 = myImage1024.GetPixel(i1024, j1024);
myImage.SetPixel(i, j, color1024);
}
myImage.Save(string.Format(@"E:\myjpg\height{0}.jpg", width >> power));
}
Console.WriteLine(DateTime.Now.ToString());
}
public int getcoor(int i,int power)
{
if (power > 1)
return 2 * getcoor(i,power-1) +1;
else
return 2 * i + 1;
}
按照我寫的這個函數(shù)來建造金字塔,此時相鄰圖層之間的對應點像素值就相等了。
相關文章
C# menuStrip控件實現(xiàn)鼠標滑過自動彈出功能
MenuStrip 控件是 Visual Studio 和 .NET Framework 中的功能。使用該控件,可以輕松創(chuàng)建 Microsoft Office 中那樣的菜單。本文給大家分享menuStrip鼠標滑過自動彈出效果2021-07-07在WinForm中發(fā)送HTTP請求的實現(xiàn)方法
下面小編就為大家?guī)硪黄赪inForm中發(fā)送HTTP請求的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-06-06C#微信公眾平臺開發(fā)之access_token的獲取存儲與更新
這篇文章主要介紹了C#微信公眾平臺開發(fā)之access_token的獲取存儲與更新的相關資料,需要的朋友可以參考下2016-03-03