【发布时间】:2015-05-24 20:19:41
【问题描述】:
我正在尝试应用模糊效果,但我得到完全错误的颜色 我正在使用 Easy_BMP 库将 BMP 文件加载到像素阵列中。 我尝试参考this topic 来实现高斯模糊算法。怎么了?
void blur3x3(int i, int j, RGBApixel** pixelArray, BMP &Image) {
double blurValue = 0.111;
int avgR = 0;
int avgG= 0 ;
int avgB = 0;
int b = 0;
for(int w = i-1 ; w <= i+1 ; w++) {
for(int z = i-1 ; z<=j+1 ; z++) {
avgR = avgR + blurValue*( pixelArray[w][z].Red );
avgG = avgG + blurValue*( pixelArray[w][z].Green );
avgB = avgB + blurValue*( pixelArray[w][z].Blue );
}
}
Image(i,j)->Red = (BYTE) avgR ;
Image(i,j)->Green = (BYTE) avgG;
Image(i,j)->Blue = (BYTE) avgB;
}
bool blur() {
BMP Image;
Image.ReadFromFile(fullFilePath);
int w = Image.TellWidth();
int h = Image.TellHeight();
RGBApixel** pixelArray = new RGBApixel*[w];
for(int i = 0; i < w; ++i)
pixelArray[i] = new RGBApixel[h];
for( int i=0 ; i < Image.TellWidth() ; i++) {
for( int j=0 ; j < Image.TellHeight() ; j++) {
pixelArray[i][j] = Image.GetPixel(i,j);
}
}
for( int i=1 ; i < Image.TellWidth()-1 ; i++) {
for( int j=1 ; j < Image.TellHeight()-1 ; j++) {
blur3x3(i,j, pixelArray, Image);
}
}
Image.SetBitDepth( 32 );
Image.WriteToFile( "/home/kxyz/BMP/gray.bmp" );
}
【问题讨论】:
标签: c++ image image-processing bmp