在Java中将2D二进制矩阵转换为黑/白图像

Pet*_*xwl 6 java binary image matrix

我是java的新手.我现在有2D二进制矩阵只有1和0.我想将它保存为具有相同宽度和高度的jpg图像(黑白).我怎么能意识到这一点?我尝试了下面的代码,但失败了,说"java.lang.IllegalArgumentException:image == null!" 请帮助我,或者给我更好的解决方案.非常感谢你.

public static void main(String[] args) throws IOException {

    //result is double[25][33] binary matrix with only 1s and 0s;
    int height=result.length;
    int width=result[0].length;;
    byte[] data = new byte[height*width];
    int k=0;
    for(int i = 0;i < height;i++){
        for(int j = 0; j < width; j++){
            data[k]=(byte)result[i][j];
            k++;
        }
        System.out.print("\n");
    }
    InputStream input = new ByteArrayInputStream(data);
    BufferedImage output = ImageIO.read(input);
    ImageIO.write(ouput, "jpg", new File("c:/result.jpg"));

}
Run Code Online (Sandbox Code Playgroud)

bco*_*rso 4

这是一个创建 30x30 方格框的简单示例:

在此输入图像描述

public static void main(String... args) throws IOException {
    int w = 30, h = 30;

    // create the binary mapping
    byte BLACK = (byte)0, WHITE = (byte)255;
    byte[] map = {BLACK, WHITE};
    IndexColorModel icm = new IndexColorModel(1, map.length, map, map, map);

    // create checkered data
    int[] data = new int[w*h];
    for(int i=0; i<w; i++)
        for(int j=0; j<h; j++)
            data[i*h + j] = i%4<2 && j%4<2 || i%4>=2 && j%4>=2 ? BLACK:WHITE;

    // create image from color model and data
    WritableRaster raster = icm.createCompatibleWritableRaster(w, h);
    raster.setPixels(0, 0, w, h, data);
    BufferedImage bi = new BufferedImage(icm, raster, false, null);

    // output to a file
    ImageIO.write(bi, "jpg", new File("C:\\Users\\user\\Desktop\\test.jpg"));
}
Run Code Online (Sandbox Code Playgroud)

编辑:

对于您正在做的事情,您实际上不需要创建自己的 ImageColorModel,您可以使用内置类型:BufferedImage.TYPE_BYTE_GRAY 或 TYPE_BYTE_BINARY。这是一个更好的示例,展示了如何使用灰度来获得方格框:

在此输入图像描述

public static void main(String... args) throws IOException {
    int w = 40, h = 40, divs = 5;

    BufferedImage bi = new BufferedImage(w, h, BufferedImage.TYPE_BYTE_GRAY);
    WritableRaster raster = bi.getRaster();

    for(int i=0; i<w; i++)
        for(int j=0; j<h; j++)
            raster.setSample(i,j,0,128+(int)(127*Math.sin(Math.PI*i/w*divs)*Math.sin(Math.PI*j/h*divs)));

    ImageIO.write(bi, "jpg", new File("C:\\Users\\user\\Desktop\\test.jpg"));
}
Run Code Online (Sandbox Code Playgroud)