时间:2021-05-20
这里首先先讲一下金字塔的原理:
影像金字塔就是把一个原始图像处理成一个类似于塔状的影像结构(请不要纠结于这个概念)
在影像金字塔中最精细层的分辨率为16*16,下一层是8*8,依次为4*4,2*2,1*1
如下图所示:
图中网格顶点表示原始图像16*16;红色差号代表8*8;黑色圆圈代表4*4.
按照上述原理,那么编程实现不过就是隔点采样,那么相邻两幅图像在对应点上的灰度值应该相等,当然我是这么想的。
C#在Drawing命名空间下的Bitmap类里面有一个处理影像金字塔的函数,
复制代码 代码如下:
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");
}
但是经过我逐像素对比之后,发现这两张图上对应点的像素并不相等,这说明一个问题:C#里的这个方法肯定不是按照逐点采样,而是采用某种方法把图像拉伸的。这似乎不太符合金字塔的原理,所以我又重新写了一个金字塔的函数:
复制代码 代码如下:
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;
}
按照我写的这个函数来建造金字塔,此时相邻图层之间的对应点像素值就相等了。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例为大家分享了C#随机数生成字母金字塔的具体代码,供大家参考,具体内容如下1.代码实现:staticvoidMain(string[]args){show
前言上一篇文章,我们讲解了边缘梯度计算函数,这篇文章我们来了解图像金字塔。图像金字塔?图像金字塔被广泛用于计算机视觉应用中。图像金字塔是一个图像集合,集合中所有
  原理一:金字塔原理  所谓金字塔原理,就是从一个中心论点出发,这个论点由3-7个论据支撑,而每一个论据本身又可以成为
for循环语句打印金字塔完整的金字塔复制代码代码如下://打印金字塔$n=25;for($i=1;$icontinue语句:跳过本次循环后面的代码。可以指定跳出
  原理一:金字塔原理  所谓金字塔原理,就是从一个中心论点出发,这个论点由3-7个论据支撑,而每一个论据本身又可以成为