我想找到MyImage的平均红色RGB值(扩展BufferedImage)。我将图像中每个像素的红色值保存为数组red []。最后,我想总结这些以找到红色的平均值。但是,当我在MyImage上运行此代码时,它只打印0.如何使此方法正常工作? (此处未包含的代码可以正常工作)
public class MyImage extends BufferedImage {
public MyImage(int width, int height, int imageType) {
super(width, height, imageType);
}
public void findAverageRedValue(){
int height = this.getHeight();
int width = this.getWidth();
int[] red = new int[height*width];
Map m = new HashMap();
for(int i=0; i < width ; i++)
{
for(int j=0; j < height ; j++)
{
ColorModel colorModel = this.getColorModel();
int rCol = colorModel.getRed(j*i);
red[red.length - 1] = rCol;
}
}
int sum = 0;
for(int i = 0; i < red.length; i++)
sum += red[i];
int averageRed = sum/red.length;
System.out.println(averageRed);
}
}
答案 0 :(得分:1)
您将数组的元素指定为:
red[red.length - 1] = rCol;
在每种可能的情况下,这将只分配数组的最后一个元素。数组的length属性与集合的size()
不同;它是一个静态值,它基于数组的初始化维度。
所以除了一个数组条目之外的所有条目都将为零。因此,最后,sum
将介于0和255之间 - 当除以(可能)更大的数字时,它将归零。 (这里有一个可能的问题,你正在进行整数除法,但这可能并不重要)。
要解决此问题,您需要更改分配给哪个数组索引。您可以为数组索引保留一个单独的计数器 - 或者,使用现有的i
和j
来执行:
red[i * width + j] = rCol;
无论哪种方式,这都会将每个像素的红色组件放入单独的阵列位置,从而使您能够正确地对它们求和。
Integer division是Java中潜在的问题,而这就是你最后在这里所做的。通过sum / (float)red.length
获得小数平均值可能更好,但只要你知道发生了什么,并且你很乐意截断到最接近的整数,这可能没有必要。