67 lines
1.7 KiB
Java
67 lines
1.7 KiB
Java
package org.warp.picalculator.gui.graphicengine.headless24bit;
|
|
|
|
import java.awt.geom.AffineTransform;
|
|
import java.awt.image.AffineTransformOp;
|
|
import java.awt.image.BufferedImage;
|
|
import java.io.IOException;
|
|
|
|
import javax.imageio.ImageIO;
|
|
|
|
import org.warp.picalculator.gui.graphicengine.GraphicEngine;
|
|
import org.warp.picalculator.gui.graphicengine.Skin;
|
|
|
|
public class Headless24bitSkin implements Skin {
|
|
|
|
public int[][] skinData;
|
|
public int[] skinSize;
|
|
|
|
Headless24bitSkin(String file) throws IOException {
|
|
load(file);
|
|
}
|
|
|
|
@Override
|
|
public void load(String file) throws IOException {
|
|
final BufferedImage img = ImageIO.read(this.getClass().getResource("/" + file));
|
|
skinData = getMatrixOfImage(img);
|
|
skinSize = new int[] { img.getWidth(), img.getHeight() };
|
|
}
|
|
|
|
public static int[][] getMatrixOfImage(BufferedImage bufferedImage) {
|
|
|
|
|
|
final int width = bufferedImage.getWidth(null);
|
|
final int height = bufferedImage.getHeight(null);
|
|
final int[][] pixels = new int[width * height][];
|
|
for (int i = 0; i < width; i++) {
|
|
for (int j = 0; j < height; j++) {
|
|
int rgb = bufferedImage.getRGB(i, j);
|
|
int r = (rgb >> 16) &0xFF;
|
|
int g = (rgb >> 8) &0xFF;
|
|
int b = rgb &0xFF;
|
|
boolean transparent = ((rgb >> 24) & 0xFF) <= 128;
|
|
int[] curCol = Headless24bitRenderer.rgbToIntArray(r, g, b);
|
|
pixels[i + j * width] = new int[] {curCol[0], curCol[1], curCol[2], transparent?1:0};
|
|
}
|
|
}
|
|
|
|
return pixels;
|
|
}
|
|
|
|
@Override
|
|
public void initialize(GraphicEngine d) {
|
|
|
|
}
|
|
|
|
@Override
|
|
public void use(GraphicEngine d) {
|
|
((Headless24bitRenderer) d.getRenderer()).currentSkin = this;
|
|
}
|
|
|
|
@Override
|
|
public boolean isInitialized() {
|
|
return true;
|
|
}
|
|
|
|
|
|
}
|