JS required. Should be able to copy-paste an image or upload a file to change the image below. Dragging and dropping onto the file input thing appears to work...
With a function from rgba to a palette index (4 colours), we can create pixels hex strings from the image. Can turn a piece of the image into a link ("0812" being the palette we will use):
(() => {
const x = 3;
const y = 0;
link(hex((r, g, b, a) => r === 0 ? 0 : 1, x * 8, y * 8), "0812");
})();Can also create a bunch of pixel-hexes from an image:
(() => {
const gfx = (f) => {
const rows = Math.trunc(img.height / 8);
const columns = Math.trunc(img.width / 8);
const res = [];
for (let y = 0; y < rows; y++) {
for (let x = 0; x < columns; x++) {
res.push('"' + hex(f, x * 8, y * 8) + '"')
}
}
return res;
};
console.log(gfx((r, g, b, a) => r === 0 ? 0 : 1).join(",\n"));
})();const canvas = document.querySelector("#canvas");
const ctx = canvas.getContext("2d", { willReadFrequently: true });
ctx.imageSmoothingEnabled = false
const img = new Image();
img.onload = function(){
canvas.width = img.width;
canvas.height = img.height;
ctx.drawImage(img,0,0);
};
img.src = "";
const input = document.querySelector("#file");
document.onpaste = e => {
for (const item of e.clipboardData.items) {
if (item.kind === 'file') {
const blob = item.getAsFile();
const fr = new FileReader();
fr.onload = ev => img.src = ev.target.result;
fr.readAsDataURL(blob);
}
}
};
input.onchange = () => {
for (const file of input.files) {
const fr = new FileReader();
fr.onload = () => img.src = fr.result;
fr.readAsDataURL(file);
}
};
const px = (f, x, y) => {
const a = ctx.getImageData(x, y, 1, 1).data;
return f(a[0], a[1], a[2], a[3]);
};
const hexdata = (data) => {
const res = new Uint8Array(8 * 8 / 4);
let i = 0;
data.forEach((row) => {
for (let x = 0; x < row.length; x += 4) {
res[i] = (row[x] << 6) | (row[x + 1] << 4) | (row[x + 2] << 2) | row[x + 3];
i++;
}
});
return res.toHex();
};
const hex = (f, startx, starty) => {
const res = [];
for (let y = starty; y < starty + 8; y++) {
const row = [];
res.push(row);
for (let x = startx; x < startx + 8; x++) {
row.push(px(f, x, y));
}
}
return hexdata(res);
};
const link = (sprite, pal) => {
const li = document.createElement("p");
const a = li.appendChild(document.createElement("a"));
const href = `./pixels.html?sprite=${sprite}&palette=${pal}`;
a.innerText = href;
a.href = href;
lastli.before(li);
};