在BufferedImage(Java)中查找红色的平均值

时间:2013-01-30 10:35:10

标签: java rgb

我想找到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);
    }        
}

1 个答案:

答案 0 :(得分:1)

您将数组的元素指定为:

red[red.length - 1] = rCol;

在每种可能的情况下,这将只分配数组的最后一个元素。数组的length属性与集合的size()不同;它是一个静态值,它基于数组的初始化维度。

所以除了一个数组条目之外的所有条目都将为零。因此,最后,sum将介于0和255之间 - 当除以(可能)更大的数字时,它将归零。 (这里有一个可能的问题,你正在进行整数除法,但这可能并不重要)。

要解决此问题,您需要更改分配给哪个数组索引。您可以为数组索引保留一个单独的计数器 - 或者,使用现有的ij来执行:

red[i * width + j] = rCol;

无论哪种方式,这都会将每个像素的红色组件放入单独的阵列位置,从而使您能够正确地对它们求和。

Integer division是Java中潜在的问题,而这就是你最后在这里所做的。通过sum / (float)red.length获得小数平均值可能更好,但只要你知道发生了什么,并且你很乐意截断到最接近的整数,这可能没有必要。