从java中的[0,255]灰度值数组创建灰度位图

时间:2016-05-21 12:12:22

标签: java image-processing bitmap bmp

我有一个数组int[] shadesOfGray大小n*n,其中包含[0,255]的值。是否可以从该阵列创建8位灰度位图?

例如,如果 int[] shadesOfGray = {255, 255, 255, 128, 128, 128, 0, 0, 0}

然后位图中相应像素的强度为:

255 255 255
128 128 128
0    0   0 

我尝试过这样的事情:

   private static void generateBMPwithDistribution(int[] shadesOfGray, int sum, String path) throws IOException {

        int dim = 100;  
        byte[] buffer = new byte[dim * dim];    

        for (int x = 0, i = 0; x < dim; x++)        
            for (int y = 0; y < dim; y++)                                              
                buffer[(x * dim) + y] = (byte) (shadesOfGray[i]); // problem  

        try {
            ImageIO.write(getGrayscale(dim, buffer), "bmp", new File(path));
        } catch (IOException e) {
            ...
        }

    }

    public static BufferedImage getGrayscale(int width, byte[] buffer) {
        int height = buffer.length / width;
        ColorSpace cs = ColorSpace.getInstance(ColorSpace.CS_GRAY);
        int[] nBits = { 8 };
        ColorModel cm = new ComponentColorModel(cs, nBits, false, true,
                Transparency.OPAQUE, DataBuffer.TYPE_BYTE);
        SampleModel sm = cm.createCompatibleSampleModel(width, height);
        DataBufferByte db = new DataBufferByte(buffer, buffer.length);
        WritableRaster raster = Raster.createWritableRaster(sm, db, null);
        BufferedImage result = new BufferedImage(cm, raster, false, null);

        return result;
    }

由于我想要8位.bmp,我在缓冲区中复制值,然后将缓冲区写入文件。问题是值> = 128;字节被认为具有负值。 Java有没有办法克服这个问题?

1 个答案:

答案 0 :(得分:0)

您的程序可能如下所示:

private static void generateBMPwithDistribution(int[] shadesOfGray, int sum, String path) throws IOException {

    int dim1 = (int)Math.sqrt(shadesOfGray.length), dim=100*dim1;
    int[] buffer = new int[dim * dim];    

    int howManyTimes=dim/dim1;
    for (int x = 0; x < dim; x++)        
        for (int y = 0; y < dim; y++) {                                             
            int valueToReplicate=shadesOfGray[(x + y*dim)/howManyTimes];
            buffer[x + y*dim] = 0xff000000|(valueToReplicate<<16)|(valueToReplicate<<8)|valueToReplicate;
        }

    BufferedImage result=new BufferedImage(dim, dim, BufferedImage.TYPE_INT_RGB);

    try {
        ImageIO.write(result, "bmp", new File(path));
    } catch (IOException e) {
        ...
    }

}