【问题标题】:Read pattern from colored png layout image into array?将彩色 png 布局图像中的图案读入数组?
【发布时间】:2016-03-11 16:44:31
【问题描述】:

#FFFFFF = 0 = black background
#FF0000 = 1 = corner, rotated through 0° https://i.imgur.com/8H5PL63.png
#FF8000 = 2 = corner, rotated through 90°
#FFFF00 = 3 = corner, rotated through 180°
#80FF00 = 4 = corner, rotated through 270°
#00FF00 = 5 = pipe, rotated through 0° https://i.imgur.com/UA2z1QZ.png
#00FF80 = 6 = pipe, rotated through 90°

所以我想读取图像并用0-6 自动填充我的int[][] layout 数组。完整的图像是896(w) x 992(h),每个图块都是32x32 pixels big.

每个图块都有1px的边框,所以颜色是30x30 pixels大。

到目前为止,这是我的 java 代码(只有Grid.class):

public class Grid {
private static int[][] layout;

public Grid() {
    layout = new int[][]{ //28x31
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},//5
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},//10
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},//15
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},//20
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},//25
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},//30
            {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}
    };
}

}

【问题讨论】:

  • 您也可以将数组初始化为layout = new int[28][31];,而不需要大量的 0。确切的问题/问题是什么?

标签: java arrays bitmap


【解决方案1】:

这里是一步一步的解决方案:

  1. 研究以下commands

    javax.imageio.ImageIO.read(new File("filename.png")); java.awt.image.BufferedImage.getRGB(int x, int y);

  2. 加载并读取该图片。最好的办法是从每 16 个像素中获取一种颜色(具有 32x32 块 - 所以从块的中间读取是安全的)。

  3. 比较一种颜色是否与您的图案中的一种颜色匹配。
  4. 如果匹配,请写入您的 layout[i][j] 数组。
  5. 重复循环,直到到达图片的末尾。 (在循环结束时不要忘记i++;j++;
  6. 你有一个结果。只是循环遍历 28x31 数组是 868 次操作,所以不用担心速度。

【讨论】:

  • 太棒了!我搜索的正是这个getRGB(int x, int y)!!谢谢你:)
猜你喜欢
  • 1970-01-01
  • 2016-01-06
  • 2015-02-28
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2021-12-13
相关资源
最近更新 更多