功能参数:输入图像,第一种颜色,第二种颜色
我正在拍摄一张图片,看着它的高度和宽度,然后迭代找到一个像素。如果像素颜色最接近第一种颜色(color1
),则将该像素颜色更改为color1
,如果像素颜色最接近color2
,则将其更改为color2
。在尝试比较两种参数颜色时,我的问题被认为是代码abs(color2-color1)/2
。
void Preprocessor(BMP pix, RGB color1, RGB color2) {
int height = pix.GetHeight();
int width = pix.GetWidth();
for (int i = 0; i < height; i++) {
for (int j = 0; j < width; j++) {
if (pix[i][j]->red + pix[i][j]->green + pix[i][j]->blue >
abs(color2 - color1) / 2) { // pixel color closest to color1
pix[i][j] = color1;
pix[i][j] = color1;
pix[i][j] = color1;
} else { // pixel color closest to color2
pix[i][j] = color2;
pix[i][j] = color2;
pix[i][j] = color2;
}
}
}
}
答案 0 :(得分:1)
哪个颜色更接近这个的问题是非常重要的问题。可以有几种方法来解决这个问题。您可能希望大致具有相同的亮度或色调或振动,或其他类似的东西。
所以你选择了abs(color2 - color1) / 2
,这没有任何直观的价值。你可以考虑解释你对这种确切方法的理由是什么。
我建议您从亮度开始(种类)。假设您要估计Taxicab指标中颜色与不同颜色的距离。然后选择较小的一个。
// Taxicab metric (Manhattan)
double distance(RGB c1, RGB c2) {
return
abs(c1->red - c2->red)
+ abs(c1->green - c2->green)
+ abs(c1->bule - c2->blue);
}
void Preprocessor(BMP pix, RGB color1, RGB color2) {
int height = pix.GetHeight();
int width = pix.GetWidth();
for (int i = 0; i < height; i++) {
for (int j = 0; j < width; j++) {
double d1 = distance(color1, pix[i][j]);
double d2 = distance(color2, pix[i][j]);
if (d1 < d2) { // pixel color closest to color1
pix[i][j] = color1;
} else { // pixel color closest to color2
pix[i][j] = color2;
}
}
}
}
您可能还希望尝试其他指标(Euclidean)以及其他更适合以这种方式进行comapre的配色方案HSV, HSL