答案 0 :(得分:49)
如果精灵区域读入BufferedImage
,则getSubimage
方法可用于获取精灵表的子图像。
getSubimage
方法将获取所需子图像的x
,y
以及width
和height
,因此可以获得所需的精灵。由于大多数精灵似乎都是相同的大小,我认为大多数精灵都可以通过嵌套的for
循环来检索以迭代大图像。
例如,如果使用ImageIO
类(例如read
方法)加载精灵图像,并且每个精灵的大小为10像素×10像素,则其中5行乘5精灵列,精灵可以通过以下方式获得:
BufferedImage bigImg = ImageIO.read(new File("sheet.png"));
// The above line throws an checked IOException which must be caught.
final int width = 10;
final int height = 10;
final int rows = 5;
final int cols = 5;
BufferedImage[] sprites = new BufferedImage[rows * cols];
for (int i = 0; i < rows; i++)
{
for (int j = 0; j < cols; j++)
{
sprites[(i * cols) + j] = bigImg.getSubimage(
j * width,
i * height,
width,
height
);
}
}
当然,上述代码仅在所有精灵的大小相同时才起作用,因此需要进行一些调整才能使用给定的精灵表。 (因为右上角的大小似乎与其他角落不同。)
答案 1 :(得分:12)
如果您只想绘制精灵,Java的Graphics类有一个drawImage方法,可以为您提取图像的特定区域。你只需要指定源图像,你想在你的Graphics对象上绘制精灵(x,y,width,height),以及精灵所在的图像的哪个帧(x,y,width,height)
假设精灵的宽度和高度与您想要在绘图区域上绘制的宽度和高度相同,您可以定义自己的方法来绘制精灵框架,如下所示
void drawSpriteFrame(Image source, Graphics2D g2d, int x, int y,
int columns, int frame, int width, int height)
{
int frameX = (frame % columns) * width;
int frameY = (frame / columns) * height;
g2d.drawImage(source, x, y, x+width, y+height,
frameX, frameY, frameX+width, frameY+height, this);
}
columns
是您的精灵表中有多少列。该方法的前两行计算工作表中精灵框架的x任意y位置。
您工作表中的那些大精灵需要特殊处理。您可以使用图块绘制它们(因此在这种情况下,您将为每个大图像绘制四个精灵),或者您可以手动确定用于这些精灵的x,y,宽度和高度。
如果您的精灵表是一张普通纸(所有精灵都是相同的尺寸)并且它的排列方式与您的5 x 15相同,那么您将使用以下方法调用绘制第20帧
Toolkit tk = Toolkit.getDefaultToolkit();
Image pacman = tk.getImage(getURL("pacman.png"));
...
drawFrame(pacman, g2d, x, y, 15, 19, 25, 25);
这里,x和y是你想在Graphics对象上绘制精灵的位置,15是精灵表中的列数,19是帧(编号从0开始),25是宽度和每个精灵的高度(我近似)。