Skip to content

Instantly share code, notes, and snippets.

@adrianmgg
Created July 28, 2022 02:18
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save adrianmgg/9bf0c72bea454e6dc9e42b450c2e61fd to your computer and use it in GitHub Desktop.
Save adrianmgg/9bf0c72bea454e6dc9e42b450c2e61fd to your computer and use it in GitHub Desktop.
oNqGRWK
<svg viewBox="0 0 512 512" width="256" height="256" xmlns="http://www.w3.org/2000/svg" style="position:absolute;top:0px;left:0px;width:100vw;height:100vh;">
<style>
:root {
--grass-dark: #7ebe54;
--grass-light: #97c667;
--dirt-dark: #79553a;
--dirt-light: #b9855c;
--face-size: 32px;
--face-size-half: calc(var(--face-size) / 2);
--grass-dark: #7ebe54;
--grass-light: #97c667;
--dirt-dark: #79553a;
--dirt-light: #b9855c;
--chest-fill: #a26b23;
--chest-stroke: #362f25;
--checkerboard:
linear-gradient(black 2%, transparent 2%, transparent 98%, black 98%),
linear-gradient(90deg, black 2%, transparent 2%, transparent 98%, black 98%);
}
.root_container {
display: flex;
width: 512px;
height: 512px;
background-color: skyblue;
overflow: hidden;
align-items: center;
justify-content: center;
perspective: 300px;
/* perspective-origin: 50% 50%; */
/* perspective-origin: 50% 30%; */
perspective-origin: 50% 20%;
}
.root {
/* perspective: 60px; */
transform-style: preserve-3d;
width: var(--face-size);
height: var(--face-size);
animation: root-spin 4s linear infinite;
}
@keyframes root-spin {
0% { transform: rotateY(0turn); }
100% { transform: rotateY(1turn); }
}
.face {
position: absolute;
background-color: #F002;
box-sizing: border-box;
--background-size-scale: 1;
background-size: calc(var(--background-size-scale) * var(--face-size)) calc(var(--background-size-scale) * var(--face-size));
image-rendering: pixelated;
/* opacity: 0.5; */
/* transform-origin: top left; */
}
.grass-side {
background-image: url("");
}
.grass-top {
background-image: url("");
}
.dirt {
background-image: url("");
}
.chest-side {
/* --background-size-scale: 0.875; */
background-image: url("");
}
.chest-top {
background-image: url("");
}
.chest-front {
background-image: url("");
}
</style>
<foreignObject x="0%" y="0%" width="100%" height="100%">
<div class="root_container" xmlns="http://www.w3.org/1999/xhtml">
<div class="root">
</div>
</div>
</foreignObject>
</svg>
import { create, createNS } from "https://cdn.skypack.dev/@amgg/elhelper@2.0.5";
const createSVG = (...args) => createNS('http://www.w3.org/2000/svg', ...args);
const root = document.querySelector('.root');
const face_size = 32;
const faces = [
// [[x, y, z], [rx, ry], [w, h], [classes]]
// [[0, 1, 0], [0, 0], [1, 1], []],
// [[0, 1, 0], [1, 0], [1, 1], []],
// [[0, 1, 0], [0, 1], [1, 1], []],
[[.5, .5, -1.5], [1, 0], [3, 3], ['grass-top'], []],
[[-2.5, .5, 1.5], [1, 0], [6, 3], ['grass-top'], []],
[[0.5, 3, 0], [0, 1], [6, 2], ['dirt'], []],
[[0.5, 2, 0], [0, 1], [6, 1], ['grass-side'], []],
[[-2.5, 3, 3], [0, 0], [6, 2], ['dirt'], []],
[[-2.5, 2, 3], [0, 0], [6, 1], ['grass-side'], []],
[[-2.5, 3, 0], [0, 0], [3, 2], ['dirt'], []],
[[-2.5, 2, 0], [0, 0], [3, 1], ['grass-side'], []],
[[-1, 3, -1.5], [0, 1], [3, 2], ['dirt'], []],
[[-1, 2, -1.5], [0, 1], [3, 1], ['grass-side'], []],
[[.5, 3, -3], [0, 0], [3, 2], ['dirt'], []],
[[.5, 2, -3], [0, 0], [3, 1], ['grass-side'], []],
[[-4, 3, 1.5], [0, 1], [3, 2], ['dirt'], []],
[[-4, 2, 1.5], [0, 1], [3, 1], ['grass-side'], []],
// TODO fix chest size (shouldn't be full block)
// TODO add chest latch thing
[[1, 1, -1.5], [0, 1], [1, 1], ['chest-side'], []],
[[2, 1, -1.5], [0, 1], [1, 1], ['chest-side'], []],
[[1.5, 1, -1], [0, 0], [1, 1], ['chest-side'], []],
[[1.5, 1, -2], [0, 0], [1, 1], ['chest-front'], []],
[[1.5, .5, -1.5], [1, 0], [1, 1], ['chest-top'], []],
// [[0, 2, 1], [0, 0], ['grass-side']],
// [[1, 2, 1], [0, 0], ['grass-side']],
// [[-1, 2, 1], [0, 0], ['grass-side']],
// [[0, 3, 1], [0, 0], ['dirt']],
// [[1, 3, 1], [0, 0], ['dirt']],
// [[-1, 3, 1], [0, 0], ['dirt']],
// [[0, 4, 1], [0, 0], ['dirt']],
// [[1, 4, 1], [0, 0], ['dirt']],
// [[-1, 4, 1], [0, 0], ['dirt']],
// [[1.5, 2, 1.5], [0, 1], ['grass-side']],
// [[1.5, 2, 2.5], [0, 1], ['grass-side']],
// [[1.5, 2, 3.5], [0, 1], ['grass-side']],
// [[1.5, 3, 1.5], [0, 1], ['dirt']],
// [[1.5, 3, 2.5], [0, 1], ['dirt']],
// [[1.5, 3, 3.5], [0, 1], ['dirt']],
// [[1.5, 4, 1.5], [0, 1], ['dirt']],
// [[1.5, 4, 2.5], [0, 1], ['dirt']],
// [[1.5, 4, 3.5], [0, 1], ['dirt']],
// [[-1.5, 2, 1.5], [0, 1], ['grass-side']],
// [[-1.5, 2, 2.5], [0, 1], ['grass-side']],
// [[-1.5, 2, 3.5], [0, 1], ['grass-side']],
// [[-1.5, 3, 1.5], [0, 1], ['dirt']],
// [[-1.5, 3, 2.5], [0, 1], ['dirt']],
// [[-1.5, 3, 3.5], [0, 1], ['dirt']],
// [[-1.5, 4, 1.5], [0, 1], ['dirt']],
// [[-1.5, 4, 2.5], [0, 1], ['dirt']],
// [[-1.5, 4, 3.5], [0, 1], ['dirt']],
];
console.log('----------------------------------------------------------------');
const identity_mat = new DOMMatrixReadOnly([
1, 0, 0, 0,
0, 1, 0, 0,
0, 0, 1, 0,
0, 0, 0, 1,
]);
for(const [[x, y, z], [rx, ry], [w, h], classes, mat_funcs] of faces) {
let mat = identity_mat
// .translate(-w*face_size/2, -h*face_size/2, -h*face_size/2)
// .translate(-w*face_size/2, 0, -h*face_size/2)
.translate(x*face_size, y*face_size, z*face_size)
.translate(0,-2*face_size, 0)
.rotate(rx*90, ry*90, 0)
// .scale(w, h, 1, -x*face_size, -y*face_size, -z*face_size)
;
for(const f of mat_funcs) mat = f(mat);
create('div', {
parent: root,
classList: ['face', ...classes],
style: {
transform: mat.toString(),
width: `${w * face_size}px`,
height: `${h * face_size}px`,
},
});
console.log([w, h], classes, `((${mat.m11}, ${mat.m12}, ${mat.m13}, ${mat.m14}), (${mat.m21}, ${mat.m22}, ${mat.m23}, ${mat.m24}), (${mat.m31}, ${mat.m32}, ${mat.m33}, ${mat.m34}), (${mat.m41}, ${mat.m42}, ${mat.m43}, ${mat.m44}))`);
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment