Pen Settings

HTML

CSS

CSS Base

Vendor Prefixing

Add External Stylesheets/Pens

Any URLs added here will be added as <link>s in order, and before the CSS in the editor. You can use the CSS from another Pen by using its URL and the proper URL extension.

+ add another resource

JavaScript

Babel includes JSX processing.

Add External Scripts/Pens

Any URL's added here will be added as <script>s in order, and run before the JavaScript in the editor. You can use the URL of any other Pen and it will include the JavaScript from that Pen.

+ add another resource

Packages

Add Packages

Search for and use JavaScript packages from npm here. By selecting a package, an import statement will be added to the top of the JavaScript editor for this package.

Behavior

Auto Save

If active, Pens will autosave every 30 seconds after being saved once.

Auto-Updating Preview

If enabled, the preview panel updates automatically as you code. If disabled, use the "Run" button to update.

Format on Save

If enabled, your code will be formatted when you actively save your Pen. Note: your code becomes un-folded during formatting.

Editor Settings

Code Indentation

Want to change your Syntax Highlighting theme, Fonts and more?

Visit your global Editor Settings.

HTML

              
                
	<input id="isAlex" type="checkbox"><label for="isAlex">Slim Model</label>
	<input id="size" type="checkbox"><label for="size">large</label><br>
	Pose:<select id="pose_select"></select><br>
	Texture:<input id="file" type="file" accept=".png"><div id="thumb"></div><br>
  <button id="rotate">rotate</button>
  <button id="reset">reset camera</button>
  <button id="execute">draw</button><br>
  <div id="background">
	<canvas id="myCanvas" ></canvas>
  </div>
	<img id="steve" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAMAAACdt4HsAAAAdVBMVEUAAACqclmbY0kApKQElZWQWT8FiIgAr6+BUzlBNZs6MYk3Nzc/KhUzJBErHg0kGAiPXj6zeV4Af38oKChGOqU/Pz9KSkoKvLwDenpqQDBJJRAAaGgAzMz///9CHQp3QjVSPYl2SzO3g2s0JRJVVVUmGgqUYD6FZw01AAAAAXRSTlMAQObYZgAAAsZJREFUeF7tlueS4jAQhHdGwTmQN4aL7/+I1z2WjoNiy4b9eduSrRFFfzUjGay7rL7v0Lu+TLq7Vn3XohPwDboFADNb+GYKVwPo7nDdDuinIsJUwvWAjmvYt20ZSiiM1wO4BtBYWrtlFzquY1+Oj1A5LjfSOfDeQiBg0nHoLOrnAfzi0HXo8LMNxKG3/LxdVHvPm66+r0R/2LzlhmIEdRZgGaMEldVKRNRcUxlWyIIS0IIO8vIu+v4igwY40QYDzQOY7KCQyMODCKPB8h8GQuYXceiHoGP5O4yPb2+vCMpRAz4koF8CKAP8SuPr4yv2P2CigY/jL2jhr7KGmmazyfNnAULluU7KhqIonIrIRcBm0zR/ARogvQgQwD/MYBZwAGA+g49LcCzhPIOqqqvtdltjqBDUHkKiquKKKXYYYIXZYVhDnBwB9RGwhXyMvii8CO+M6SyyH4CnpzXCIyAZqwyI9/fRwcIbYxI8u9mdJ4CwywD0eyibGDu6cK2TniCOJwCWQUIN0RSdAWICeEJUNbCZMDnNAJ0QXkw7OmeAVIIlJCKKJoCoQKcAKI8RYspY+JhjTukiwgDoRwCUAXkXItN2zjM2gCPAZIWcZFCbkRhEkI8e3VkSFiGAPzJ/A+gZYL+vk/YmuIwBo6fohj8y/0w4ATQ7uH7SumO442bYekbYGKAiBNsJoBNA/wU0zY7GXWNRkx5pbEuM07qAhTs8dNpeMrj7L/Wlw6TCQQWCc8OXvjT7suU7SUSU8U0HDgKCinwig0Mh0GcycEEXlZDPC1V+W1drKL/aqXlAdtYAQfY6zwTnlgFqAqojwCcz+vIMDIAonwey0v9B1hH40XkhUMpmCrMZ0AxZBozh0XQ0MF1XAkRAsmNQWb6IEAHBACYbFjxE6UlItVjtZp8FXD4vZD/tM4DL5wUDaAboPOD8vKAhH6vEhnPDH6nNQp4lz7TwAAAAAElFTkSuQmCC" style="display:none" />
  <img id="alex" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAMAAACdt4HsAAAAZlBMVEUAAACMvorrmD/ljT97snhkQSzr0LCGuYTv2r/fxKLUt4/egS5xq258Vz5YWFhyTjZPT09sRi7zqFhcOyc2NjaUyJKUlmsrVCiAglo/Pz9lZWUYOBYoKCj////vu7EjYiRvb291UDi5dsVVAAAAAXRSTlMAQObYZgAAAwBJREFUeF7tludy2zAQhHOo7E29uOT9XzK7AGiTGscGnZ/xUgApzux3h9NAuF+ztNI1Lq1VjY9Sv7ZKQXUN5/cB00RzzETpzQBdx8iYNZ+2ZzBBmCJHbwcwrMICyqoGg4DtRZw0CGVZVhUg2zNA/qxjWTqoLLONTJyhCdD4aExcCt5z6IzIwanDFGbmwbcqvMyp/hwO66ddYTAhYjIADKd0ILjCuUDQIXigfF1MrWNo9/RSFC9PLoZWwYxMvgYwNApfzCr1W03qSWUAuPuS//m5wCLKSU+1qpkARkYRdV1VpUsMxzrCrrkrkBsAOWqg/f5+n6HiWRmlm6TZICKI8RfA/b7fvwM895Rqmh20BrjqQ8But87gXJEAP5WRAeKsMjhjQ2EVCfB5Bl7E2L611jaNhwTyZxSzOjfvMl6S4sMCYI2xY9uOFtrtrBVjxB8L54oAMLPdc3D2HAtAP449/G0PAJ8AMN4cC/jp5jeRgxwOmDmFscygpRX+diQJAHgEBPq9wYCZ13mlBWCkHZQegB0GPMFBLwAh5AFyQWWQcwtA13V2hN120PXaIWcazMGLJ4XPRBRBRHDjLABXmLorzVEwMShNABjeDRFFItC/AgTja/B2l2G4wASLNDShHiKwy2cAmrpkHrpuuN1uJ9ZfGjEnfAGDV5MArMNDBjAlc8fRGNOc4ATnxGfcqVvyE7CuwUDX65V2ggbxBuWXcBkvlBHc590eCEvA/nIZuP7hctnvMYQ++xuy4AAiUW8liL9Cln6UzkhK628ReDqAA30vAx6s/6RJrQxH6px0zAHA/1/rRzzuV4etEln+iWxvOJSWym0B7B6O+0kjg62AZQaTbMjAUm0fj3sjkNdKknQ2oO2hcUQm3gsAXmJfkAcY+7FN6u2iM8CVAYhtAlaAGRof+4J4Pwbh+8cAetl2UCXlksqMDB76hSE2BEkuAxCOufd+oYuH6aycDOha9AubATQNi34BC8gHPPYLFAD5NXjsFyjWfl5Exq+Q+gVo7hfYEXyWwR/uMURd56PUtQAAAABJRU5ErkJggg==" style="display:none" />
	<img id="drawed">

              
            
!

CSS

              
                
		body {
			background-color: white;
		}

		#background {
			background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAACCAAAAABX3VL4AAAADklEQVQIHWPYXc9QvxsAB2ICdaBJUyUAAAAASUVORK5CYII=);
			background-size: 12px 12px;
			image-rendering: pixelated;
			-ms-interpolation-mode: nearest-neighbor;
			display: inline-block;
      line-height: 1px;
		}

#myCanvas {
  cursor: all-scroll;
  filter: drop-shadow(0 0 0.5rem rgba(0,0,0,0.6));
}
              
            
!

JS

              
                var main_object;
var models;
var camera;
var loader;
var controls;
var texture_changed = false
var tex_canvas

$(function () {

	const width = 400 * 1;
	const height = 636 * 1;
	const zoom = 0.91

	// initialize renderer -------------------------------------------------------------------------
	const renderer = new THREE.WebGLRenderer({
		canvas: document.querySelector('#myCanvas'),
		antialias: false,
		alpha: true,
		preserveDrawingBuffer: true
	});
	renderer.setClearColor(0xFF00FF, 0);
	renderer.setPixelRatio(window.devicePixelRatio);
	renderer.setSize(width, height);
  
	Object.keys(animations).forEach( key => {
		$("#pose_select").append(
			$("<option/>", {value: key, text: key})
		)
	})

	$("#pose_select option[value='default_pose']").prop("selected", true)

	$("#pose_select").change( function(){
		set_pose( $("#pose_select option:selected").val() )
	})

	$("#execute").on("click", function () {
		let img = document.querySelector("#drawed");
		img.src = renderer.domElement.toDataURL('image/png');
	});
  
	$("#reset").on("click", function(){
		controls.reset()
    main_object.rotation.y = 0
	});
  
  $("#rotate").on("click", function(){
    main_object.rotation.y = (main_object.rotation.y + 0.7853981633974483) % 6.283185307179586
  })

	$("#size").change(function () {

		let canvas = document.querySelector("#myCanvas");
		let pose = $("#animation option:selected").val() * 1;
		let mag = $("#size").prop("checked") ? 3.0 : 1.0;
		let w = Math.floor(400 * mag);
		let h = Math.floor(636 * mag);

		controls.reset();
		
		let aspectRatio = w / h, viewSize = 268.2;

		canvas.width = w;
		canvas.height = h;
		renderer.setSize(w, h);
		
		camera.left = -aspectRatio * viewSize / 2;
		camera.right = aspectRatio * viewSize / 2;
		camera.top = viewSize / 2;
		camera.bottom = -viewSize / 2;

		camera.updateProjectionMatrix();
		controls.saveState();
	})

	// Input Skin image
	$("#file").change( function(e) {
		let files = e.currentTarget.files

		let onload = async function(){
			//change texture
			let canvas = document.querySelector("#canvas");
			let context = canvas.getContext("2d")
			
			context.clearRect(0, 0, 64, 64);
			context.drawImage(this, 0, 0);
			if(this.height < 64){
				convert64(context, this)
			}

			loader.materials[0].map.image = canvas
			loader.materials[0].map.needsUpdate = true;

      // for translucent overlay
			let material2 = loader.materials[0].clone();
			let alpha = await createAlphaMap(canvas, 1, BBModelLoader.alphaByAlpha);
			material2.alphaMap = alpha;
			material2.transparent = true;
			loader.materials[1] = material2;
      
      texture_changed = true
		}
		
		if(files.length && files[0].type.match('image.*')){
			let fileRdr = new FileReader();
			fileRdr.self = this;
			fileRdr.onload = function(){
				let img = new Image()
				img.onload = onload;
				img.src = this.result
			}
			fileRdr.readAsDataURL(files[0])
		}
	})

	// Change model Steve or Alex
	$("#isAlex").change(function(){
    
    if(!texture_changed){
        let tex = document.querySelector($(this).prop("checked") ? "#alex": "#steve")
			  tex_canvas.context.clearRect(0, 0, 64, 64);
        tex_canvas.context.drawImage(tex, 0, 0)
        loader.materials[0].map.needsUpdate = true
    }

		// Pixel to UVworld mapping
		let setUVS = function (mesh, uvs, overlay){
			for(let i=0; i<mesh.geometry.faceVertexUvs[0].length; i++){
				let face = mesh.geometry.faceVertexUvs[0][i]
				for(let j=0; j<3; j++){
					face[j].x = (uvs[i][j].x + (overlay==2 ? 16: 0)) / 64
					face[j].y = (uvs[i][j].y - (overlay==1 ? 16: 0)) / 64
					face[j].z = (uvs[i][j].z + (overlay==2 ? 16: 0)) / 64
				}
			}
			mesh.geometry.uvsNeedUpdate = true
		}

		let checked = $("#isAlex").prop("checked")
		if(checked){
			// change arm models
			models.leftArm.children[0].children[0].geometry.vertices.forEach(vertex => {
				vertex.x = Math.sign(vertex.x) * 1.5
				vertex.y = Math.sign(vertex.y) * 6
				vertex.z = Math.sign(vertex.z) * 2
			})
			models.leftArm.children[0].children[0].geometry.verticesNeedUpdate = true

			models.leftArm.children[1].children[0].geometry.vertices.forEach(vertex => {
				vertex.x = Math.sign(vertex.x) * 1.7
				vertex.y = Math.sign(vertex.y) * 6.2
				vertex.z = Math.sign(vertex.z) * 2.2
			})
			models.leftArm.children[1].children[0].geometry.verticesNeedUpdate = true

			models.rightArm.children[0].children[0].geometry.vertices.forEach(vertex => {
				vertex.x = Math.sign(vertex.x) * 1.5
				vertex.y = Math.sign(vertex.y) * 6
				vertex.z = Math.sign(vertex.z) * 2
			})
			models.rightArm.children[0].children[0].geometry.verticesNeedUpdate = true

			models.rightArm.children[1].children[0].geometry.vertices.forEach(vertex => {
				vertex.x = Math.sign(vertex.x) * 1.7
				vertex.y = Math.sign(vertex.y) * 6.2
				vertex.z = Math.sign(vertex.z) * 2.2
			})
			models.rightArm.children[1].children[0].geometry.verticesNeedUpdate = true

			// adjust arm positions
			models.leftArm.children[0].children[0].position.set(-5.5, 18.5, 0)
			models.rightArm.children[0].children[0].position.set(5.5, 18.5, 0)

			models.leftArm.children[1].children[0].position.set(-5.5, 18.5, 0)
			models.rightArm.children[1].children[0].position.set(5.5, 18.5, 0)

			models.leftArm.children[0].position.y = -22.5
			models.rightArm.children[0].position.y = -22.5

			models.leftArm.children[1].position.y = -22.5
			models.rightArm.children[1].position.y = -22.5

			models.leftArm.position.y = 21.5
			models.rightArm.position.y = 21.5

			// Alex UV offsets
			let uvs = [
				[
					[{ x: 47, y: 32 }, { x: 51, y: 32 }, { x: 47, y: 44 }],
					[{ x: 51, y: 44 }, { x: 47, y: 44 }, { x: 51, y: 32 }],
					[{ x: 44, y: 44 }, { x: 40, y: 32 }, { x: 44, y: 32 }],
					[{ x: 40, y: 32 }, { x: 44, y: 44 }, { x: 40, y: 44 }],
					[{ x: 44, y: 44 }, { x: 47, y: 48 }, { x: 44, y: 48 }],
					[{ x: 47, y: 48 }, { x: 44, y: 44 }, { x: 47, y: 44 }],
					[{ x: 47, y: 48 }, { x: 50, y: 48 }, { x: 47, y: 44 }],
					[{ x: 50, y: 44 }, { x: 47, y: 44 }, { x: 50, y: 48 }],
					[{ x: 44, y: 32 }, { x: 47, y: 32 }, { x: 44, y: 44 }],
					[{ x: 47, y: 44 }, { x: 44, y: 44 }, { x: 47, y: 32 }],
					[{ x: 54, y: 44 }, { x: 51, y: 32 }, { x: 54, y: 32 }],
					[{ x: 51, y: 32 }, { x: 54, y: 44 }, { x: 51, y: 44 }],
				],
				[
					[{ x: 39, y: 0 }, { x: 43, y: 0 }, { x: 39, y: 12 }],
					[{ x: 43, y: 12 }, { x: 39, y: 12 }, { x: 43, y: 0 }],
					[{ x: 36, y: 12 }, { x: 32, y: 0 }, { x: 36, y: 0 }],
					[{ x: 32, y: 0 }, { x: 36, y: 12 }, { x: 32, y: 12 }],
					[{ x: 36, y: 12 }, { x: 39, y: 16 }, { x: 36, y: 16 }],
					[{ x: 39, y: 16 }, { x: 36, y: 12 }, { x: 39, y: 12 }],
					[{ x: 39, y: 16 }, { x: 42, y: 16 }, { x: 39, y: 12 }],
					[{ x: 42, y: 12 }, { x: 39, y: 12 }, { x: 42, y: 16 }],
					[{ x: 36, y: 0 }, { x: 39, y: 0 }, { x: 36, y: 12 }],
					[{ x: 39, y: 12 }, { x: 36, y: 12 }, { x: 39, y: 0 }],
					[{ x: 46, y: 12 }, { x: 43, y: 0 }, { x: 46, y: 0 }],
					[{ x: 43, y: 0 }, { x: 46, y: 12 }, { x: 43, y: 12 }],
				],
			]

			setUVS(models.leftArm.children[0].children[0], uvs[0])
			setUVS(models.leftArm.children[1].children[0], uvs[0], 1)

			setUVS(models.rightArm.children[0].children[0], uvs[1])
			setUVS(models.rightArm.children[1].children[0], uvs[1], 2)

		} else {
			// change arm models
			models.leftArm.children[0].children[0].geometry.vertices.forEach(vertex => {
				vertex.x = Math.sign(vertex.x) * 2
				vertex.y = Math.sign(vertex.y) * 6
				vertex.z = Math.sign(vertex.z) * 2
			})
			models.leftArm.children[0].children[0].geometry.verticesNeedUpdate = true

			models.leftArm.children[1].children[0].geometry.vertices.forEach(vertex => {
				vertex.x = Math.sign(vertex.x) * 2.2
				vertex.y = Math.sign(vertex.y) * 6.2
				vertex.z = Math.sign(vertex.z) * 2.2
			})
			models.leftArm.children[1].children[0].geometry.verticesNeedUpdate = true

			models.rightArm.children[0].children[0].geometry.vertices.forEach(vertex => {
				vertex.x = Math.sign(vertex.x) * 2
				vertex.y = Math.sign(vertex.y) * 6
				vertex.z = Math.sign(vertex.z) * 2
			})
			models.rightArm.children[0].children[0].geometry.verticesNeedUpdate = true

			models.rightArm.children[1].children[0].geometry.vertices.forEach(vertex => {
				vertex.x = Math.sign(vertex.x) * 2.2
				vertex.y = Math.sign(vertex.y) * 6.2
				vertex.z = Math.sign(vertex.z) * 2.2
			})
			models.rightArm.children[1].children[0].geometry.verticesNeedUpdate = true

			// adjust arm positions
			models.leftArm.children[0].children[0].position.set(-6, 18, 0)
			models.rightArm.children[0].children[0].position.set(6, 18, 0)

			models.leftArm.children[1].children[0].position.set(-6, 18, 0)
			models.rightArm.children[1].children[0].position.set(6, 18, 0)

			models.leftArm.children[0].position.y = -22
			models.rightArm.children[0].position.y = -22

			models.leftArm.children[1].position.y = -22
			models.rightArm.children[1].position.y = -22

			models.leftArm.position.y = 22
			models.rightArm.position.y = 22

			// Steve UV offsets
			let uvs = [
				[
					[{ x: 48, y: 32 }, { x: 52, y: 32 }, { x: 48, y: 44 },],
					[{ x: 52, y: 44 }, { x: 48, y: 44 }, { x: 52, y: 32 },],
					[{ x: 44, y: 44 }, { x: 40, y: 32 }, { x: 44, y: 32 },],
					[{ x: 40, y: 32 }, { x: 44, y: 44 }, { x: 40, y: 44 },],
					[{ x: 44, y: 44 }, { x: 48, y: 48 }, { x: 44, y: 48 },],
					[{ x: 48, y: 48 }, { x: 44, y: 44 }, { x: 48, y: 44 },],
					[{ x: 48, y: 48 }, { x: 52, y: 48 }, { x: 48, y: 44 },],
					[{ x: 52, y: 44 }, { x: 48, y: 44 }, { x: 52, y: 48 },],
					[{ x: 44, y: 32 }, { x: 48, y: 32 }, { x: 44, y: 44 },],
					[{ x: 48, y: 44 }, { x: 44, y: 44 }, { x: 48, y: 32 },],
					[{ x: 56, y: 44 }, { x: 52, y: 32 }, { x: 56, y: 32 },],
					[{ x: 52, y: 32 }, { x: 56, y: 44 }, { x: 52, y: 44 },],
				],
				[
					[{ x: 40, y: 0 }, { x: 44, y: 0 }, { x: 40, y: 12 },],
					[{ x: 44, y: 12 }, { x: 40, y: 12 }, { x: 44, y: 0 },],
					[{ x: 36, y: 12 }, { x: 32, y: 0 }, { x: 36, y: 0 },],
					[{ x: 32, y: 0 }, { x: 36, y: 12 }, { x: 32, y: 12 },],
					[{ x: 36, y: 12 }, { x: 40, y: 16 }, { x: 36, y: 16 },],
					[{ x: 40, y: 16 }, { x: 36, y: 12 }, { x: 40, y: 12 },],
					[{ x: 40, y: 16 }, { x: 44, y: 16 }, { x: 40, y: 12 },],
					[{ x: 44, y: 12 }, { x: 40, y: 12 }, { x: 44, y: 16 },],
					[{ x: 36, y: 0 }, { x: 40, y: 0 }, { x: 36, y: 12 },],
					[{ x: 40, y: 12 }, { x: 36, y: 12 }, { x: 40, y: 0 },],
					[{ x: 48, y: 12 }, { x: 44, y: 0 }, { x: 48, y: 0 },],
					[{ x: 44, y: 0 }, { x: 48, y: 12 }, { x: 44, y: 12 },],
				]
			]

			setUVS(models.leftArm.children[0].children[0], uvs[0])
			setUVS(models.leftArm.children[1].children[0], uvs[0], 1)

			setUVS(models.rightArm.children[0].children[0], uvs[1])
			setUVS(models.rightArm.children[1].children[0], uvs[1], 2)
		}
	});
  
  
  // convert 64x32 to 64x64
  let convert64 = function(context, img){
    let m = val => Math.floor(val * (img.width / 64))
    
    context.translate(img.width, 0);
    context.scale(-1, 1);
    context.drawImage(img, m(4), m(16), m(4), m(4), m(40), m(48), m(4), m(4))
    context.drawImage(img, m(8), m(16), m(4), m(4), m(36), m(48), m(4), m(4))
    context.drawImage(img, m(0), m(20), m(4),  m(12), m(44), m(52), m(4), m(12))
    context.drawImage(img, m(4), m(20), m(4),  m(12), m(40), m(52), m(4), m(12))
    context.drawImage(img, m(8), m(20), m(4),  m(12), m(36), m(52), m(4), m(12))
    context.drawImage(img, m(12), m(20), m(4), m(12), m(32), m(52), m(4), m(12))

    context.drawImage(img, m(44), m(16), m(4), m(4), m(24), m(48), m(4), m(4))
    context.drawImage(img, m(48), m(16), m(4), m(4), m(20), m(48), m(4), m(4))
    context.drawImage(img, m(40), m(20), m(4), m(12), m(28), m(52), m(4), m(12))
    context.drawImage(img, m(44), m(20), m(4), m(12), m(24), m(52), m(4), m(12))
    context.drawImage(img, m(48), m(20), m(4), m(12), m(20), m(52), m(4), m(12))
    context.drawImage(img, m(52), m(20), m(4), m(12), m(16), m(52), m(4), m(12))

    context.restore(0, 0);
    context.resetTransform();
  }

	// initilaize scene
	const scene = new THREE.Scene();

	let pos_x = 0, pos_y = -144, pos_z = 0;
	

	let img = document.querySelector("#steve")
  
  let temp = img.src
  img.src = ""
  img.src = temp
  img.onload = function(){
    
	  let canvas = createCanvas(64, 64);
    canvas.context.drawImage(img, 0, 0)
    canvas.canvas.setAttribute("id", "canvas")
    $(canvas.canvas).appendTo("#thumb")
    tex_canvas = canvas


    if(img.height < 64){
      convert64(canvas.context, img)
    }

    loader = new BBModelLoader({
      filename: json_url,
      texture_name: ["#canvas"],
      side: THREE.DoubleSide,
    }).loadEntity(function(object, parts){
      main_object = object;
      models = parts;

      /// for translucent overlay
			let material2 = loader.materials[0].clone();
			loader.materials[1] = material2;
			Object.keys(loader.parts).forEach(key => {
				let mesh = loader.parts[key].children[1].children[0];
				let geo = loader.parts[key].children[1].children[0].geometry;
				mesh.material = loader.materials;
				geo.faces.forEach( face => {
					face.materialIndex = 1;
				});
			});
      
      object.scale.set(8.5, 8.5, 8.5);
      object.position.set(pos_x, pos_y, pos_z);

      scene.add(object);
      Render(scene);
    });
  }
	
	function Render(scene) {

		// initilalize camera
		var viewSize = 268.2;

		var aspectRatio = width / height;
		camera = new THREE.OrthographicCamera(
			-aspectRatio * viewSize / 2,
			aspectRatio * viewSize / 2,
			viewSize / 2,
			-viewSize / 2,
			-1000,
			1000
		);

		camera.position.set(viewSize, viewSize * 0.8168, viewSize); // Isometric position
		camera.lookAt(scene.position);
		camera.zoom = zoom;
		camera.updateProjectionMatrix();
		controls = new THREE.OrbitControls(camera, renderer.domElement);
		controls.enableKeys = false;

		// Lighting -------------------------------------------------------------------------------------

		const dirLight = new THREE.DirectionalLight(0xFFFFFF);
		//dirLight.intensity = 0.435;
		dirLight.intensity = 0.45;
		dirLight.position.set(-1.25, 4.25, 1.24).normalize();
		dirLight.castShadow = true;
		dirLight.shadow.mapSize.width = 2048;
		dirLight.shadow.mapSize.height = 2048;
		var d = 50;
		dirLight.shadow.camera.left = -d;
		dirLight.shadow.camera.right = d;
		dirLight.shadow.camera.top = d;
		dirLight.shadow.camera.bottom = -d;
		dirLight.shadow.camera.far = 3500;
		dirLight.shadow.bias = -0.0001;
		scene.add(dirLight);
		var ambientLight = new THREE.AmbientLight(0xFCFCFF);
		ambientLight.intensity = 0.618;
		scene.add(ambientLight);

		// Run tick -------------------------------------------------------------------------------------
		
		tick();

		function tick() {

			// Rendering
			renderer.render(scene, camera);
			requestAnimationFrame(tick);
		}
	}
});


function set_pose(pose_name){

	let setrotation = (parts, values) => {
		parts.rotation.set(0, 0, 0)
		let axis = new THREE.Vector3(1, 0, 0);
		parts.rotateOnWorldAxis(axis, deg2rad(values[0]));
		axis.set(0, 1, 0);
		parts.rotateOnWorldAxis(axis, deg2rad(values[1]));
		axis.set(0, 0, 1);
		parts.rotateOnWorldAxis(axis, deg2rad(values[2]));
	}

	if(animations.hasOwnProperty(pose_name)){

		pose = animations[pose_name]

		setrotation(models.head, pose.bones.head.rotation)
		setrotation(models.body, pose.bones.body.rotation)
		setrotation(models.rightArm, pose.bones.leftarm.rotation)
		setrotation(models.leftArm, pose.bones.rightarm.rotation)
		setrotation(models.rightLeg, pose.bones.leftleg.rotation)
		setrotation(models.leftLeg, pose.bones.rightleg.rotation)
	}
	
}

let animations = 
{
	"default_pose" : {
		"loop" : true,
		"bones" : {
			"body" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"head" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"leftarm" : {
				"rotation" : [ 0, 0, 5 ]
			},
			"leftleg" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"rightarm" : {
				"rotation" : [ 0, 0, -5 ]
			},
			"rightitem" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"rightleg" : {
				"rotation" : [ 0, 0, 0 ]
			}
		}
	},
	"no_pose" : {
		"loop" : true,
		"bones" : {
			"body" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"head" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"leftarm" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"leftleg" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"rightarm" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"rightitem" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"rightleg" : {
				"rotation" : [ 0, 0, 0 ]
			}
		}
	},
	"default_armor_stand_pose" : {
		"loop" : true,
		"bones" : {
			"body" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"head" : {
				"rotation" : [ -1, -7, 0 ]
			},
			"leftarm" : {
				"rotation" : [ -10, 0, 10 ]
			},
			"leftleg" : {
				"rotation" : [ -1, 0, 1 ]
			},
			"rightarm" : {
				"rotation" : [ -15, 0, -10 ]
			},
			"rightitem" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"rightleg" : {
				"rotation" : [ 1, 0, -1 ]
			}
		}
	},
	"solemn_pose" : {
		"loop" : true,
		"bones" : {
			"body" : {
				"rotation" : [ 0, 0, -2 ]
			},
			"head" : {
				"rotation" : [ 15, 0, 0 ]
			},
			"leftarm" : {
				"rotation" : [ -30, -15, -15 ]
			},
			"leftleg" : {
				"rotation" : [ -1, 0, 1 ]
			},
			"rightarm" : {
				"rotation" : [ -60, 20, 10 ]
			},
			"rightitem" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"rightleg" : {
				"rotation" : [ 1, 0, -1 ]
			}
		}
	},
	"athena_pose" : {
		"loop" : true,
		"bones" : {
			"body" : {
				"rotation" : [ 0, 0, -2 ]
			},
			"head" : {
				"rotation" : [ -5, 0, 0 ]
			},
			"leftarm" : {
				"rotation" : [ 10, 0, 5 ]
			},
			"leftleg" : {
				"rotation" : [ -3, 3, 3 ]
			},
			"rightarm" : {
				"rotation" : [ -60, -20, 10 ]
			},
			"rightitem" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"rightleg" : {
				"rotation" : [ 3, -3, -3 ]
			}
		}
	},
	"brandish_pose" : {
		"loop" : true,
		"bones" : {
			"body" : {
				"rotation" : [ 0, 0, 2 ]
			},
			"head" : {
				"rotation" : [ -15, 0, 0 ]
			},
			"leftarm" : {
				"rotation" : [ 20, 0, 10 ]
			},
			"leftleg" : {
				"rotation" : [ 5, 3, 3 ]
			},
			"rightarm" : {
				"rotation" : [ -110, -50, 0 ]
			},
			"rightitem" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"rightleg" : {
				"rotation" : [ -5, -3, -3 ]
			}
		}
	},
	"honor_pose" : {
		"loop" : true,
		"bones" : {
			"body" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"head" : {
				"rotation" : [ -15, 0, 0 ]
			},
			"leftarm" : {
				"rotation" : [ -110, -35, 0 ]
			},
			"leftleg" : {
				"rotation" : [ 5, 3, 3 ]
			},
			"rightarm" : {
				"rotation" : [ -110, 35, 0 ]
			},
			"rightitem" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"rightleg" : {
				"rotation" : [ -5, -3, -3 ]
			}
		}
	},
	"entertain_pose" : {
		"loop" : true,
		"bones" : {
			"body" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"head" : {
				"rotation" : [ -15, 0, 0 ]
			},
			"leftarm" : {
				"rotation" : [ -110, 35, 0 ]
			},
			"leftleg" : {
				"rotation" : [ 5, 3, 3 ]
			},
			"rightarm" : {
				"rotation" : [ -110, -35, 0 ]
			},
			"rightitem" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"rightleg" : {
				"rotation" : [ -5, -3, -3 ]
			}
		}
	},
	"salute_pose" : {
		"loop" : true,
		"bones" : {
			"body" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"head" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"leftarm" : {
				"rotation" : [ 10, 0, 5 ]
			},
			"leftleg" : {
				"rotation" : [ -1, 0, 1 ]
			},
			"rightarm" : {
				"rotation" : [ -70, 40, 0 ]
			},
			"rightitem" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"rightleg" : {
				"rotation" : [ 1, 0, -1 ]
			}
		}
	},
	"hero_pose" : {
		"loop" : true,
		"bones" : {
			"body" : {
				"rotation" : [ 0, -8, 0 ]
			},
			"head" : {
				"rotation" : [ -4, -67, 0 ]
			},
			"leftarm" : {
				"rotation" : [ 16, -32, 8 ]
			},
			"leftleg" : {
				"rotation" : [ 0, 75, 8 ]
			},
			"rightarm" : {
				"rotation" : [ -99, -63, 0 ]
			},
			"rightitem" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"rightleg" : {
				"rotation" : [ 4, -63, -8 ]
			}
		}
	},
	"riposte_pose" : {
		"loop" : true,
		"bones" : {
			"body" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"head" : {
				"rotation" : [ 16, -20, 0 ]
			},
			"leftarm" : {
				"rotation" : [ 4, -8, -237 ]
			},
			"leftleg" : {
				"rotation" : [ -14, 18, 16 ]
			},
			"rightarm" : {
				"rotation" : [ 246, 0, -89 ]
			},
			"rightitem" : {
				"rotation" : [ 0, -180, 0 ]
			},
			"rightleg" : {
				"rotation" : [ 8, -20, -4 ]
			}
		}
	},
	/*
	"wiggle" : {
		"loop" : true,
		"bones" : {
			"baseplate" : {
				"rotation" : [ 0.0, "math.sin((variable.armor_stand.hurt_time query.frame_alpha) * 120) * 3", 0.0 ]
			}
		}
	},*/
	"zombie_pose" : {
		"loop" : true,
		"bones" : {
			"body" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"head" : {
				"rotation" : [ -10, 0, 5 ]
			},
			"leftarm" : {
				"rotation" : [ -105, 0, 0 ]
			},
			"leftleg" : {
				"rotation" : [ 7, 0, 0 ]
			},
			"rightarm" : {
				"rotation" : [ -100, 0, 0 ]
			},
			"rightitem" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"rightleg" : {
				"rotation" : [ -46, 0, 0 ]
			}
		}
	},
	"cancan_a_pose" : {
		"loop" : true,
		"bones" : {
			"body" : {
				"rotation" : [ 0, -22, 0 ]
			},
			"head" : {
				"rotation" : [ -5, -18, 0 ]
			},
			"leftarm" : {
				"rotation" : [ 8, 0, 114 ]
			},
			"leftleg" : {
				"rotation" : [ -111, -55, 0 ]
			},
			"rightarm" : {
				"rotation" : [ 0, -84, -111 ]
			},
			"rightitem" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"rightleg" : {
				"rotation" : [ 0, -23, 13 ]
			}
		}
	},
	"cancan_b_pose" : {
		"loop" : true,
		"bones" : {
			"body" : {
				"rotation" : [ 0, 18, 0 ]
			},
			"head" : {
				"rotation" : [ -10, 20, 0 ]
			},
			"leftarm" : {
				"rotation" : [ 0, 0, 112 ]
			},
			"leftleg" : {
				"rotation" : [ 0, 0, -13 ]
			},
			"rightarm" : {
				"rotation" : [ 8, -90, -111 ]
			},
			"rightitem" : {
				"rotation" : [ 0, 0, 0 ]
			},
			"rightleg" : {
				"rotation" : [ -119, 42, 0 ]
			}
		}
	},
}

var json_url = "data:application/json;base64,{"meta":{"format_version":"4.0","model_format":"bedrock","box_uv":true},"name":"humanoid","visible_box":[1,1,0],"resolution":{"width":64,"height":64},"elements":[{"name":"head","from":[-4,24,-4],"to":[4,32,4],"autouv":0,"color":6,"origin":[0,0,0],"faces":{"north":{"uv":[8,8,16,16],"texture":0},"east":{"uv":[0,8,8,16],"texture":0},"south":{"uv":[24,8,32,16],"texture":0},"west":{"uv":[16,8,24,16],"texture":0},"up":{"uv":[16,8,8,0],"texture":0},"down":{"uv":[24,0,16,8],"texture":0}},"type":"cube","uuid":"9355bcb7-3d4b-3c5a-28e8-c3b7e5d907f8"},{"name":"body","from":[-4,12,-2],"to":[4,24,2],"autouv":0,"color":5,"origin":[0,0,0],"uv_offset":[16,16],"faces":{"north":{"uv":[20,20,28,32],"texture":0},"east":{"uv":[16,20,20,32],"texture":0},"south":{"uv":[32,20,40,32],"texture":0},"west":{"uv":[28,20,32,32],"texture":0},"up":{"uv":[28,20,20,16],"texture":0},"down":{"uv":[36,16,28,20],"texture":0}},"type":"cube","uuid":"f8713750-1fd0-68b7-a164-78a3de122aee"},{"name":"leftArm","from":[4,12,-2],"to":[8,24,2],"autouv":0,"color":3,"origin":[0,0,0],"uv_offset":[40,16],"faces":{"north":{"uv":[44,20,48,32],"texture":0},"east":{"uv":[40,20,44,32],"texture":0},"south":{"uv":[52,20,56,32],"texture":0},"west":{"uv":[48,20,52,32],"texture":0},"up":{"uv":[48,20,44,16],"texture":0},"down":{"uv":[52,16,48,20],"texture":0}},"type":"cube","uuid":"46f21d6d-fe28-44b6-eb93-f1912737ca30"},{"name":"rightArm","from":[-8,12,-2],"to":[-4,24,2],"autouv":0,"color":5,"origin":[0,0,0],"uv_offset":[32,48],"faces":{"north":{"uv":[36,52,40,64],"texture":0},"east":{"uv":[32,52,36,64],"texture":0},"south":{"uv":[44,52,48,64],"texture":0},"west":{"uv":[40,52,44,64],"texture":0},"up":{"uv":[40,52,36,48],"texture":0},"down":{"uv":[44,48,40,52],"texture":0}},"type":"cube","uuid":"7e86ecd5-a67b-01f7-4e03-9f9038a00918"},{"name":"leftLeg","from":[-0.1,0,-2],"to":[3.9,12,2],"autouv":0,"color":4,"origin":[0,0,0],"uv_offset":[0,16],"faces":{"north":{"uv":[4,20,8,32],"texture":0},"east":{"uv":[0,20,4,32],"texture":0},"south":{"uv":[12,20,16,32],"texture":0},"west":{"uv":[8,20,12,32],"texture":0},"up":{"uv":[8,20,4,16],"texture":0},"down":{"uv":[12,16,8,20],"texture":0}},"type":"cube","uuid":"e8f74b08-510b-22f1-cec1-dc6fc764190f"},{"name":"rightLeg","from":[-3.9,0,-2],"to":[0.1,12,2],"origin":[0,0,0],"uv_offset":[16,48],"faces":{"north":{"uv":[20,52,24,64],"texture":0},"east":{"uv":[16,52,20,64],"texture":0},"south":{"uv":[28,52,32,64],"texture":0},"west":{"uv":[24,52,28,64],"texture":0},"up":{"uv":[24,52,20,48],"texture":0},"down":{"uv":[28,48,24,52],"texture":0}},"type":"cube","uuid":"6be7a56a-4fb0-67c8-13c5-4d2d4fbe5070"},{"name":"head","from":[-4,24,-4],"to":[4,32,4],"inflate":0.4,"origin":[0,0,0],"uv_offset":[32,0],"faces":{"north":{"uv":[40,8,48,16],"texture":0},"east":{"uv":[32,8,40,16],"texture":0},"south":{"uv":[56,8,64,16],"texture":0},"west":{"uv":[48,8,56,16],"texture":0},"up":{"uv":[48,8,40,0],"texture":0},"down":{"uv":[56,0,48,8],"texture":0}},"type":"cube","uuid":"f1a6e264-0fc7-782f-e001-de4febd17d25"},{"name":"body","from":[-4,12,-2],"to":[4,24,2],"inflate":0.4,"origin":[0,0,0],"uv_offset":[16,32],"faces":{"north":{"uv":[20,36,28,48],"texture":0},"east":{"uv":[16,36,20,48],"texture":0},"south":{"uv":[32,36,40,48],"texture":0},"west":{"uv":[28,36,32,48],"texture":0},"up":{"uv":[28,36,20,32],"texture":0},"down":{"uv":[36,32,28,36],"texture":0}},"type":"cube","uuid":"4d0917ba-4212-a64b-d4e3-1392c68f32b3"},{"name":"leftArm","from":[4,12,-2],"to":[8,24,2],"inflate":0.4,"origin":[0,0,0],"uv_offset":[40,32],"faces":{"north":{"uv":[44,36,48,48],"texture":0},"east":{"uv":[40,36,44,48],"texture":0},"south":{"uv":[52,36,56,48],"texture":0},"west":{"uv":[48,36,52,48],"texture":0},"up":{"uv":[48,36,44,32],"texture":0},"down":{"uv":[52,32,48,36],"texture":0}},"type":"cube","uuid":"c862b4bc-c316-86e4-b23d-36c99563d248"},{"name":"rightArm","from":[-8,12,-2],"to":[-4,24,2],"inflate":0.4,"origin":[0,0,0],"uv_offset":[48,48],"faces":{"north":{"uv":[52,52,56,64],"texture":0},"east":{"uv":[48,52,52,64],"texture":0},"south":{"uv":[60,52,64,64],"texture":0},"west":{"uv":[56,52,60,64],"texture":0},"up":{"uv":[56,52,52,48],"texture":0},"down":{"uv":[60,48,56,52],"texture":0}},"type":"cube","uuid":"4a6e9b85-d667-e0a8-c047-affb71ec43bf"},{"name":"leftLeg","from":[-0.1,0,-2],"to":[3.9,12,2],"inflate":0.4,"origin":[0,0,0],"uv_offset":[0,32],"faces":{"north":{"uv":[4,36,8,48],"texture":0},"east":{"uv":[0,36,4,48],"texture":0},"south":{"uv":[12,36,16,48],"texture":0},"west":{"uv":[8,36,12,48],"texture":0},"up":{"uv":[8,36,4,32],"texture":0},"down":{"uv":[12,32,8,36],"texture":0}},"type":"cube","uuid":"a055a226-e44f-504b-8709-59ba93deb331"},{"name":"rightLeg","from":[-3.9,0,-2],"to":[0.1,12,2],"inflate":0.4,"origin":[0,0,0],"uv_offset":[0,48],"faces":{"north":{"uv":[4,52,8,64],"texture":0},"east":{"uv":[0,52,4,64],"texture":0},"south":{"uv":[12,52,16,64],"texture":0},"west":{"uv":[8,52,12,64],"texture":0},"up":{"uv":[8,52,4,48],"texture":0},"down":{"uv":[12,48,8,52],"texture":0}},"type":"cube","uuid":"5ee48641-6890-86ab-e491-47c921f317eb"}],"outliner":[{"name":"head","origin":[0,24,0],"uuid":"70971dfa-cd93-563b-d625-8d9c2b742f75","children":["9355bcb7-3d4b-3c5a-28e8-c3b7e5d907f8","f1a6e264-0fc7-782f-e001-de4febd17d25"]},{"name":"body","origin":[0,24,0],"uuid":"8deaa1d0-de1a-6d1e-9b7a-120da12f9211","children":["f8713750-1fd0-68b7-a164-78a3de122aee","4d0917ba-4212-a64b-d4e3-1392c68f32b3"]},{"name":"leftArm","origin":[5,22,0],"rotation":[0,0,5],"uuid":"7c3e97b5-9722-b8e0-9089-6ab68b10f1c8","children":["46f21d6d-fe28-44b6-eb93-f1912737ca30","c862b4bc-c316-86e4-b23d-36c99563d248"]},{"name":"rightArm","origin":[-5,22,0],"rotation":[0,0,-5],"uuid":"23cfce97-f8fe-a140-fe8b-e95af05866a9","children":["7e86ecd5-a67b-01f7-4e03-9f9038a00918","4a6e9b85-d667-e0a8-c047-affb71ec43bf"]},{"name":"leftLeg","origin":[1.9,12,0],"uuid":"b3df6e69-de00-74f7-9a7a-85e7d65b1dc3","children":["e8f74b08-510b-22f1-cec1-dc6fc764190f","a055a226-e44f-504b-8709-59ba93deb331"]},{"name":"rightLeg","origin":[-1.9,12,0],"uuid":"00400214-c426-ebdf-794f-897ae0b1993f","children":["6be7a56a-4fb0-67c8-13c5-4d2d4fbe5070","5ee48641-6890-86ab-e491-47c921f317eb"]}],"textures":[{"name":"steve.png","folder":"entity","namespace":"minecraft","id":"0","uuid":"a8b6bfbb-13f7-67d0-6769-a83a8d73e21c"}]}"
              
            
!
999px

Console