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 type="checkbox" id="play" checked><label for="play">Play</label><button id="animate">▶▶</button>
	<button id="reset">Reset Camera</button>
	<button id="execute">📷</button>
	<button id="create_apng">Create APNG</button>
	<button id="export">Export OBJ/MTL</button><br>
	<span id="camera_stats"></span><br>
  <div id="background">
	<canvas id="myCanvas" ></canvas>
  </div>
<img id="texture" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAQAAAAEACAMAAABrrFhUAAAABGdBTUEAALGPC/xhBQAAAwBQTFRFAAAAAwMDCAgICQkJCgoKCwsLDAwMDQ0NDg4ODw8PEBAQERERFhYWFxcXGBgYGhoaGxsbHBwcICAgISEhIiIiIyMjR0dHS0tLTU1NV1dXXV1dYmJiaWlpcHBwdHR0dnZ2e3t7fX19lgC8zAD64Hn6hYWFioqKAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAfg9AhwAAAQB0Uk5T////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////AFP3ByUAABPNSURBVHja7V0Ll5s6Dk63cDeZsaHMdjIvyG3aJv//H97FD2z5Ib9IGLoL5/gAwSLJF1mfJMtk9w/fjseXoziihJBQy+3vk9f30VuqbGzLld3JL/Ty8iJvQEnXday13XhMQWOvU6Q/7zPKUHhOaSuOu1a9JmWo88GZnJBh/dX7ys/BryUBAD6r2ne47ATA6+urOGqaln950Uhjn4f7Y3KmfNNM99Gb3Z/18cnGNnCfpkmQlQC8HI9SpQn51rbt1JjymOdO/xZex+RMeaaU9gdx+hPqlY1tBH6GBFkJwPv7Uao0MX4HoUTwPNwfyFHsdd2MD273lQMHtKQhQPyfITYEfvw4vvo+yKiI1nmgP+hry4E+DVPu5uu/mqYJAUCAAk+yeQB0cBDhQ4Ap88swDH+z/dhMxSPEPsf7M8XG5LRio8bLHUSWbCoLgEFE4rK7l/e39/eXt3exP75QWxGp8btQvD8BfYmrwPJ+uPWODaJUFvB99gALvL4ePz5e3z5eP95Gy358jbGA09/b16PA0jInWO95LNBlsgBT5Lfj+9vxjSv3McYCTn9vX1eBY9bYZgE4oGRLYwF9H/gZYiwAbkBTWCBudTF2QD+4o/CFLDC5Up12iULvuwtY0QALgP6NV2kdBcbk3fvMZAHBMk5LBiDMAi3Bra6htK4CR6yx3d/jSpFc/z8lLnABCCsixa0uZAGbPeLW2OmfwQJclgqfX8YNMD6ZYoxu6hcEgCvMZEUbbdmFgod8eIMxgrFACgt0DUmX9Vr+FmEl8z6uDYgoEG51DaUNxgKoD394YP0OBx0LiGP+ekTWY/n9rGTeZ2cEvEUNYQGayQLs+sMD6/dw0INIHPPXkxiEEi+DmccmAEw5uLJoizkpEjEGgTpXVl6c57AAbsn5B3x8ZH0eD1qBxTF/PYlBsHjEeN0AwLS+tvsRO29Nyx8IZpNiAUPhuQIbgyLOIJC1iPl5kLhgZ/v6YRYgtnVHrH2bHwt0tsJzxTYGRZxBrHgEYSgDgCbofnjOm7TMT1EsYCg8V2wwKJIYBGEik6FMG2D52yQYlHrOEWvvjwW+hWMBoPBysKWxgJ99CMZQJgC2+xHJCIX7o/2i/ryt8NKlmQaFk0FCWcB7bLJVCIBm5nk0IxS05IbCc8Z5PLD942PQn/ezj8VQaSzgWG8SvY5Ye//rIRfLZYH05rf2GENlsEDrWn3c2mPHNotQ5bvrvL/j9gjfHqRSjZTqNMiYPDHfF4tNOowFwlbdPUetvRULdDnsIF8HLBAYXLaL1TSZx6YNIBYLZJ2bPnZKLICxgycWIImDi5DMYysWCAahkXPL306IBXSWRiqvVOqn79+/Pz08fB/3Dwd2/J31MyfIWjDhpd+PJvj/XYAFGjtvH7H66PW0jBCWsXl6fn5+enx8HvePB3b8jPd1Wue39hg7mEawzbLyAVYgmAWOZJRuMCMc/TyhWKBLtvIRViibF6C2tVfZHHGeBADGRAlzBFYs0EZigTbAEmXzAmGWafPnApDZYTQj5Fj5sNUOsELKvIAbCxD9noR47p89F+CdFwhmhFKtvNf3R1ggPRYg0JpT9/3T5gIQ/x9hhAwWcOcF8HPM9w7HAjqrZFv08DxCUiyAZIfCsQAJzw7j52Wzw9qXl5Y/MYOUxAJIdigcC9Dw7DCeMUphAeJnAe3iOO9fzgIEjVPuFAu0WFwQzO03qq9MxzZzWIAglr9NzQjReCyQmhFKnBcgqi/fO6yTxwJJsUkoI+Sx+jTCAjSvRsiTDp/uSYknI5XHApj/3wXmBcKZnNzYAA9asdnlYIYplwXQeAStF9rFZoMzzyOxgKdCtA3PQ6TWBYkGmEQcqwEAB1peRigvQxSdLwjPChOHdTKqQ5NbmAWSff/QLDD+un82misonJhrsNlor/zU9l9//R63X1/3SUPHEwvE8v7Bc2RmNhILZM5Ge+RbMn0WDQBJB0BnaKjlikznSqnt8zZ7drijc2ejg3HA/uvPEYFfP7/uaToATUbmxdsQC4xXinbS5xcz0iz7I2Wfnp9lPNCA2Wc+mPj9fHMDxvvvv375NW5fcobAPzM3fxYIjwXc2eaxPbHjpycrx5/ECsZ7jgB8+fnzy5ecITAbgMyMkIdFWEq0675PKdJwLBKcGWYAsC1nCMwFILdSVJViqPjh96/fzQjAMxkPWqM+ycc6wWyQBmC5IZBXKQrYQSj32O/3r1+/xwFD2F4wCRhA0djAeP/9V7ktOARyM0KZs83OeTAO0ADQTwAgcV5Arxlo/PME2vqTpEpVHUwDAJx+epHPIiyAV4rS6GxxuL8vozQNQBoYAnqRz60ByKwUdWuO7JZbqQpmmAND4OVlWuRzaxZoimaHp76ua2X0w1atmbGASqnu1eb0Y2sb7mMDSDQucGIHw8oT+hd34EcX9i8C2GNiCRKPJdRg0gA4/fRSz1sD4F8jQBNXkzHF/bcCgNLo7LTv/dUg0AA4/fRSz1sDgFSEJpY3cMVVADS+6ynzCvH1AQuwQEaN0GS1sZohfr0lklnknqjMTklbgAWC8wsBq5/b3ODaOqZ6HfI0gAi9IwsQe22BGShb6w9uF3sE64Cca3dkgTxlvAXrqHQn+QZYxXajqBF3vL0hLHALpfwT2vA3wgKGLw0aEuTa7oo8tgZAZ/r6/johJI3qcYta8D6ORoBEqM0CR760k7cfw48fr+D8FZsdzmx4/v8+9/XMLoNEKOXKLtiCu79vb2/vovGlnu/TOWCEHZK5SWwk0ee/1X09sQBIhNozwHx9s2gv7+/H6ZivecZqhHI/KJ75uct9PbEASITCwSr9/4+PjzfWXj8+9DFkhB2ZoajRys/ylrz2mIBEKIxLJv9/bFzpRxaQyi/WPGPl8pktkPmhc+6bvvaYgESoXQ3K/H/epgX/0zmIC2YCEMr/z7xv6uwySISSzHXGvkrR3IaXNJN73Jf4WEBlgWjmrPINWCCwaoze476EBgBIemKEAwAyi5vacmeH0++bWmkKEqE2CxTMDhdY66waofns4rEBaghA3z9jdnimtc6qEZrPLgEA9HtSmjM7fB9rPY9dMipNQSKUgAG4EAsQPPMzl11SK01BIhSmWhdiAbwidDa7pK43AIlQ9ZSILBZYZSyQWWPkaek2YK2xAMouZQ0HoLsHC2C+/I3ZBaZJ9TGFq9FiFafzY4Fm2VhAzR7zAaGeZNG52SeQdQo9R+g+PvsNYgH0/coGAQ4AvVNGiN6DXVr6z423HUg9gtIFb9rSSmeCZYvWPEAHF7809vOF7LSr+3gWVTEK7pNaOZoNQPlk0+e0mwPwzydt/TAMSzYUgL70C8wF4HQ69dfrqT9dr2djfzrJa9cz3J9O4/WTun5mr4PzXvVR95vO+TUUgKHwCwwzARj68/lyzm19XyqHA3DYl32BQjklfzlfLtltVOYiuTM+BE6FX+Q0EwClrHntVCqH24B92TcplVPyfb4ij63vz2VyOAD14VD0BQrlTBbgCjpIRRX78fVpLy34pPxDf9Hn4jUhp/fa6lsDZwgCsC8EYD+XBRZsuBGs9kXKXCzXM0v+ec0B4DLsDyW/ZakcU2RHWcGeKS3vYyiwPB+mY/UaGDCiP3R/xPlZDBo+eHpnKOyuJ/5FssdzqZxwYbQrk9eUXLG8A8C5r/dMmXN/y1K5frLmRSww9PPkXTbYnYf6IH7LvB+zVE4pc4k7o+SGYnkXgJP6IlkjulSun3z1EndGxQynYnnXCPYVU2TVko1goZxQYm6Rp73bTNdnek1eH/dKnveZ4gPrtR7KozHByALV9Dtm/Z6lcssGwW7zsIDzRXirT32EBcrksHz+3H7+sumEhIiy5mar+j6RBTLlQMWnXtROIs8LBYvfA1XLLVhEL6tIUwAYas/veKj7IZkFsuTUFzPz/HRuP76EU5VJp5dJmCwAFPlcH9JZIEPOWmegUp5p/UK1PzKNCuYUUlKoDguI1p9HXz+LBVLloMLq/H/0fwemeQISHVRgTiElhepjAabIl6He57JAkhxQWJj/jz01Wv1fWXBQTf8xkPEIFoMFlFKP7kYd8fNL5YDCglLs2H8H6PLsIADT4vyMR7BAFqgmRa56oeCJLJAlh60zQPu1D217YLPQYh8cVLxUWtcn5bJArS15PNgtlct/QsRD1z4w6872QRbgzyA1H8KbxwL6i1xPdRSAQjn9uJQOzOg2YkLNuzb4sWsf2TWxT3et0sokAAtUQJH7ih8nsUCenGn97b3vOUOH9tuBXRd7lyVmzg5ra672g34thQXy5KhZA2TtPZWg3aHrHth1sfcovlkOQc0H78YGA2CBSimyfi2FBfLkGqOGCCy0Qax8x774I7sm9n42gYV1kAXiLpFmgUq6M9UYbFbKtYmzQKYcMWqIlMVW53b/llt/dk3skfuBkgxdtwQW3pAACwzCmNWS1VnqsD5Esz2lcuD5oYaPT5BK0FZY/27a+2MFWF4Nqkx1mQUNsIC03PLDV6dRkfUXOeAsUCanrb9RC6T2LgDc+nfTHgPAKPNwi/WaAAsIxa2VIluBLsoCZXJ6sbuhuGBvWu9vwvq3sf8WcBbeG8V2QRYQiitZvWaKbMZ5GAuUyennh1osAIvdQK1QJ6y/VT5tPoHaKqyDgyEaGI8sAL8IU2QwkgOprlI5MwZorSdKOA/WbZ6fD8/Pj+xR675nn9pLN1W9Umf8DVQTYoEzn+SS/nzdj4pc2UGu1wYUyimrb1j/b/BRKEZ7enp4ejr85+letUW7MwtgJ3d2VGRvpscHQKGcXuxuWGx1vnSt0u7M/fdJkU9XeyRjE2ClcqQzM0EmCzTN4gBcuPtSCUveS8V2052uESyUo8Z6ApcNlgdAuy+YInt/y1I5OxOkrf99KkHjGaFrr1wZTJF9vl2pnBkLwEXz6U+Svq0NmJQ3pMieya9SOb/1x2OB+wMgrDlT5GFU5Br5HR3XplTO9v3N809jAaHI/ly/f0SXymExAMlc83tjFkAUucIVulTO8f0T5wfuzAIVq6OZAlw33e1R6FI5MxYgKhOUu9rrxizALbmlyFV9CFj2UjmwDkAvfgF+/OewgE+RK8yqi2C3VG7p9QApLDApMrTkdRU0aodDqRwvk1nJWgHFArzuxlDkmFUfASiU4wDYawVUDQ9YK6DLo0/j6961ArpuyJbh16NrBSYWEDU5vVbiOuDWTK1UTtQJOQVszjoAWQ+kr5t1QWddFwTvYfaZ7mPPH9gsICoqpVtTR5VYtFK5z6gTmtiHytljmwW4Ip/qfdIXmFqp3LIl0ro12t1qbBbgilJFlddspXL9WRfEGcpsFbQJpebX1TWg5FOlqDEoXHnOUvwaUe6W9V9j5+FiW/KkVioXqfmHdf/2YhlQAm1Vjw4XT19YXToMsnSCOv8yI6xmfcgGoFDucwbA6YQVz5WuG/ys1XYFW9jlKgRgPywrNwsACv/BsrMGQhkAYwywqNw8AHQGqoHHMwBg8wBLys3bqMo4qb9gAunXMgAO9bCk3EwAVOZJBt/y4bvFAIiK0OXk5m4NfPKEnosoHgKyHmgxufk2QM0/UKKPvxUOAVUPtJDc3VigKxkCwJ25LiF3IwD0v9WAgeBhgaEPrwKDPv1wni+3PAvof7bxs8BgzfAD6227tMPlBnLLsoCegJPHLgCnwASX2erT9QZyC7KAcoHA/5a5AFTJwW3Vn28gtyALtOrx69NA8MUC9TAEUtrWuoAbyC3IAi1ggRaNBdiKr9Qvcr2B3IIsAEqy1bGHBqvqkqbMlWnNS+UWMoLEVn7xnwQeAPapylyb1rxUbiEAqKpFMtwhLwCJymxZ81K5RWOBzh4IHgD0ohdXeUPWvFRu0VhAV5PisYAod/Dm9+uQNS+VWzAhQg13qENiAaGkXmWuQ9a8VG51GSG48itY8mBZ81K5T4gFwhkhufDl4vstqxALFMotygJOUIwAwJTZl++vQixQKLcQCwQfvLtzA9eqNxa/yFYHWaBMbg3bzk1cVN7KzzrMAkVyKwWAzeBORXDoF7neQm51AIA1wGfnCRFVmAVK5NYGgGGtVemDj9FNa14qt2IAWIB7PVmPSakxa14qtzoALJfl3JsFcBVmzUvl1qcBxu82sAdWVX5lNq15qdy6ARBrgQ3frsYyQoVyawPAzd7YNUCV15qXyq0PANuFEY8+hCnv2mfNS+VWD8CBV4L2J7AYovZZ81K51QHgZnNq+cS32lZmw5qXyq0NAN9zoereLoYTv+UArHmp3J8AwKGu5OPJdc6Xj+zR558ttzoAvLn8uhIVmUNlZHvG12bLrQ0ALJVdyYfSwrw/y/7MlftzAKinB+FqWqtGKz9XbnUA4BNaVSXKmXW2px7P58qtDYDgfE4tn+ZcA39/ptwfBQCjNbFIpVaPTbzOlFsbANp6+2d1hWszZXsqZc1L5dYGgGG8fOuApWtzGfjCGGXNS+XWDAD2ZSbXRiyXlNa8VG5tAPhdmcp5YK5YpFJVkzUvlVsbALgVr03XRi5IqaU1L5VbGwChkgaj7qOGz/Yvl1sdAOG6ngosh1SuDbfmpXJrAyChwLGasjvMtRFW/VIs9ycC4Al0r8VyawMgb9mjDnRL5dYHQO7Kv1oEuqVya54X+L/cNgA2ADYANgA2ADYANgA2ADYANgA2ADYANgA2ADYANgA2ADYANgA2ADYANgA2ADYANgA2ADYANgA2ADYANgA2ADYANgA2ADYANgA2ADYANgA2ADYANgA2ADYANgA2ADYANgA2ADYANgA2ADYA/oe2/wIOLytER3X0nQAAAABJRU5ErkJggg==" alt="" style="display:none" />
	<img id="drawed"><br>
<footer>Image and model are copyright <a href="https://www.mojang.com">Mojang Studios</a></footer>
              
            
!

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: 0px;
		}

#myCanvas {
  cursor: all-scroll;
}
              
            
!

JS

              
                var main_object;
var models;
var objcamera;
var controls;

var positions = [];
var posPointer = 0;
var neck = [];

$(function () {

	const mag = 1.0

	const width = Math.floor(500 * mag);
	const height = Math.floor(500 * mag);

	const Zoom = 0.0795;

	const night = false;

	// 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);

	$("#execute").on("click", function () {
		let img = document.querySelector("#drawed");
		img.src = renderer.domElement.toDataURL('image/png');
	});

	$("#export").on("click", function () {
    
    $("#obj_file,#mtl_file").remove();
		
		let filename = "dragon.png";//$("#texture").attr("src").match(".+/(.+?)([\?#;].*)?$")[1]
		let name = filename.match(/(.*)(?:\.([^.]+$))/)[1]

		var exporter = new THREE.OBJExporter();
		let result = "mtllib " + name + ".mtl" + "\n" + exporter.parse(scene);
		var data = "application/x-msdownload;charset=utf-8," + encodeURIComponent(result);
		$('<a id="obj_file" href="data:' + data + '" download="' + name + '.obj">' + name + '.obj</a>').css("margin-right", "8px").appendTo('body');

		let material_setting = exporter.generate_mtl();
		data = "application/x-msdownload;charset=utf-8," + encodeURIComponent(material_setting);
		$('<a id="mtl_file" href="data:' + data + '" download="' + name + '.mtl">' + name + '.mtl</a>').appendTo('body');

	});
  
	$("#reset").on("click", function(){
		controls.reset();
	});

	let pos_x = 0, pos_y = -5.5, pos_z = 40;

	for (let i = 0; i < 64; i++) {
		positions.push([0, 0, 0])
	}

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


	let loader = new BBModelLoader({
		filename: json_url,
		texture_name: ["#texture"],
		side: THREE.DoubleSide,
	}).loadEntity(function (object, parts) {
		main_object = object;
		models = parts;
		main_object.position.set(pos_x, pos_y, pos_z);
		main_object.rotation.set(0, 0, 0);
		scene.add(main_object);
    
    loader.materials[0].map.name = "dragon.png";

		neck.push(
			models.neck5,
			models.neck4,
			models.neck3,
			models.neck2,
			models.neck,
			models.head,
			models.body,
			models.tail,
			models.tail2,
			models.tail3,
			models.tail4,
			models.tail5,
			models.tail6,
			models.tail7,
			models.tail8,
			models.tail9,
			models.tail10,
			models.tail11,
			models.tail12,
		)

		for(let i=1; i<5; i++){
			neck[i].position.z = neck[0].position.z;
		}

		for(let i=8; i<12; i++){
			neck[i].position.z = neck[7].position.z;
		}

		Render(scene);
	});

	function Render(scene) {

		// initilalize camera
		var viewSize = 16;

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

		camera.position.set(viewSize, viewSize * Math.tan(deg2rad(39.23)), viewSize); // Isometric position
		camera.lookAt(scene.position);

		camera.zoom = Zoom;
		camera.updateProjectionMatrix();

		controls = new THREE.OrbitControls(camera, renderer.domElement);
		controls.enableKeys = false;

		objcamera = camera;

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

		const dirLight = new THREE.DirectionalLight(night ? 0x9999cc : 0xFFFFFF);
		//dirLight.intensity = 0.435;
		dirLight.intensity = 0.68;
		dirLight.position.set(1.2, 4.85, 3.5).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(night ? 0x333333 : 0xFCFCFF);
		ambientLight.intensity = 0.45;
		scene.add(ambientLight);

		// Animate setting ------------------------------------------------------------------------------
		timeline = new TimeLineControl()

		timeline.addEvent({
			start: 0,
			interval: 4,
      reverse: true,
			process: dragon,
		})

		// APNG writer ----------------------------------------------------------------------------------
		var encoder = new APNGencoder(document.querySelector("#myCanvas"));
		encoder.setRepeat(0);
		encoder.setBlend(0);

		$("#create_apng").on("click", function () {

			$("#play").prop("checked", false);

			let img = document.querySelector("#drawed")
			img.src = ""

			anim_capture = {}
			anim_capture.delay = 0.01
			anim_capture.max = Math.floor(1 / anim_capture.delay)
			anim_capture.lifetime = 0
			anim_capture.count = 0
			timeline.process(0.001)
			//renderer.compile(scene, camera);

			encoder.setDelay(4);
			encoder.start();

			anim_capture.timer = setTimeout(create_frame, 100)

		});

		function create_frame() {

			clearTimeout(anim_capture.timer)

			if (anim_capture.count < anim_capture.max) {
				anim_capture.count++;

				anim_capture.lifetime = anim_capture.lifetime + anim_capture.delay < 1 ? anim_capture.lifetime + anim_capture.delay : 0
				timeline.process(anim_capture.lifetime)
				encoder.addFrame();

				console.log(anim_capture.lifetime)
				anim_capture.timer = setTimeout(create_frame, 100 + anim_capture.count * 1.5)

			} else {

				anim_capture = undefined
				encoder.finish();

				var base64Out = bytesToBase64(encoder.stream().bin);
				let apng = document.querySelector("#drawed");
				apng.src = "data:image/png;base64," + base64Out;
			}
		}

		// Run tick -------------------------------------------------------------------------------------

		let lifetime = 0
		let begin_sec = new Date().getTime();

		$("#animate").on("click", function () {

			lifetime = lifetime + 0.0025 < 1 ? lifetime + 0.0025 : 0
			timeline.process(lifetime)
		});

		tick();

		function tick() {

			if($("#play").prop("checked")){
				timeline.process(lifetime);
				let now = (new Date().getTime() - begin_sec) * 0.001;
				let tick = (now % timeline.total) / timeline.total;
				lifetime = tick; //lifetime + capture_setting.preview_speed < 1 ? lifetime + capture_setting.preview_speed : 0
			}

			$("#camera_stats").html(
				"position:(" + objcamera.position.x + ", " + objcamera.position.y + ", " + objcamera.position.y + ")<br>" +
				"rotation:(" + objcamera.rotation.x + ", " + objcamera.rotation.y + ", " + objcamera.rotation.z + ")<br>" +
				"zoom:" + objcamera.zoom
			);

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

    // From EnderDragonRenderer.java -------------------------------------------------------
		function dragon(tick) {
			let distance = 0.1
			let oFlapTime = 0, flapTime = 0.2 / (distance * 1.0);
			let f1 = lerp(1-tick, oFlapTime, flapTime);
			let f1b = lerp(tick, oFlapTime, flapTime);
			models.jaw.rotation.x = (Math.sin((f1 * 6.2831855)) + 1.0) * 0.2;

			let f2 = (Math.sin((f1b * 6.2831855 - 1.0)) + 1.0);
			f2 = (f2 * f2 + f2 * 2.0) * 0.05;

			let f3 = 0.0;
			let f4 = -4.0;
			let f5 = models.neck5.position.z;

			let f6 = 1.5;

			//// neck --------------------------
			let arrayOfDouble1 = getLatencyPos(6, tick);

			let f7 = rotWrap(getLatencyPos(5, tick)[0] - getLatencyPos(10, tick)[0]);
			let f8 = rotWrap(getLatencyPos(5, tick)[0] + (f7 / 2.0));

			let f9 = f1 * 6.2831855;
			for (let b1 = 0; b1 < 5; b1++) {
				let arrayOfDouble = getLatencyPos(5 - b1, tick);
				let f = Math.cos((b1 * 0.45 + f9)) * 0.15;

				neck[b1].rotation.y = rotWrap(arrayOfDouble[0] - arrayOfDouble1[0]) * 0.017453292 * 1.5;
				neck[b1].rotation.x = (f + getHeadPartYOffset(b1, arrayOfDouble1, arrayOfDouble) * 0.017453292 * 1.5 * 5.0);
				neck[b1].rotation.z = rotWrap(arrayOfDouble[0] - f8) * 0.017453292 * 1.5;

				neck[b1].position.y = -f4;
				neck[b1].position.z = f5;
				neck[b1].userData.x = f3;
				f4 = f4 + Math.sin(neck[b1].rotation.x) * 10.0;
				f5 = f5 + Math.cos(neck[b1].rotation.y) * Math.cos(neck[b1].rotation.x) * 10;
				f3 = f3 - Math.sin(neck[b1].rotation.y) * Math.cos(neck[b1].rotation.x) * 10;
			}
			
			/// head & body --------------------------
			models.head.position.y = -f4;
			models.head.position.z = f5;
			//this.head.x = f3;
			let arrayOfDouble2 = getLatencyPos(0, tick);
			models.head.rotation.y = rotWrap(arrayOfDouble2[0] - arrayOfDouble1[0]) * 0.017453292;
			models.head.rotation.x = rotWrap(getHeadPartYOffset(6, arrayOfDouble1, arrayOfDouble2)) * 0.017453292 * 1.5 * 5.0;
			models.head.rotation.z = -rotWrap(arrayOfDouble2[0] - f8) * 0.017453292;
			
			f4 = Math.sin(neck[1].rotation.x) * 16;
			models.dragon.position.y = f4
			models.body.rotation.z = 0.0;

			/// wings --------------------------
			let f10 = f1b * 6.2831855;
			models.leftWing.rotation.x = 0.125 - Math.cos(f10) * 0.2;
			models.leftWing.rotation.y = -0.25;
			models.leftWing.rotation.z = (Math.sin(f10) + 0.125) * 0.8;
			models.leftWingTip.rotation.z = (Math.sin(f10 + 2.0) + 0.5) * 0.75;

			models.rightWing.rotation.x = models.leftWing.rotation.x;
			models.rightWing.rotation.y = -models.leftWing.rotation.y;
			models.rightWing.rotation.z = -models.leftWing.rotation.z + deg2rad(180);
			models.rightWingTip.rotation.z = -models.leftWingTip.rotation.z;

			/// legs --------------------------
			renderSide(f2, models.leftFrontLeg, models.leftFrontLegTip, models.leftFrontFoot, models.leftRearLeg, models.leftRearLegTip, models.leftRearFoot)
			renderSide(f2, models.rightFrontLeg, models.rightFrontLegTip, models.rightFrontFoot, models.rightRearLeg, models.rightRearLegTip, models.rightRearFoot)

			
			/// tail -------------------------
			let f11 = -Math.sin(f1 * 6.2831855) * 0.0;
			f9 = f1 * 6.2831855;
			f4 = models.tail.position.y;
			f5 = models.tail.position.z;
			f3 = 0.0;
			arrayOfDouble1 = getLatencyPos(11, tick);
			for (let b2 = 0; b2 < 12; b2++) {
				arrayOfDouble2 = getLatencyPos(12 + b2, tick);
				f11 = (f11 + Math.sin((b2 * 0.45 + f9)) * 0.05000000074505806);
				neck[7 + b2].rotation.y = (rotWrap(arrayOfDouble2[0] - arrayOfDouble1[0]) * 1.5 + 180.0) * 0.017453292;
				neck[7 + b2].rotation.x = (f11 + (arrayOfDouble2[1] - arrayOfDouble1[1]) * 0.017453292 * 1.5 * 5.0);
				neck[7 + b2].rotation.z = rotWrap(arrayOfDouble2[0] - f8) * 0.017453292 * 1.5;
				neck[7 + b2].position.y = f4;
				neck[7 + b2].position.z = f5;
				//this.neck.x = f3;
				f4 = (f4 + Math.sin(neck[7 + b2].rotation.x) * 10.0);
				f5 = (f5 + Math.cos(neck[7 + b2].rotation.y) * Math.cos(neck[7 + b2].rotation.x) * 10);
				f3 = (f3 - Math.sin(neck[7 + b2].rotation.y) * Math.cos(neck[7 + b2].rotation.x) * 10);
			}

		}

		function renderSide(param1Float, paramFrontLeg, paramFrontLegTip, paramFrontFoot, paramRearLeg, paramRearLegTip, paramRearFoot) {
			paramRearLeg.rotation.x = 1.0 + param1Float * 0.1;
			paramRearLegTip.rotation.x = 0.5 + param1Float * 0.1;
			paramRearFoot.rotation.x = 0.75 + param1Float * 0.1;

			paramFrontLeg.rotation.x = 1.3 + param1Float * 0.1;
			paramFrontLegTip.rotation.x = -0.5 - param1Float * 0.1;
			paramFrontFoot.rotation.x = 0.75 + param1Float * 0.1;
		}

		function getLatencyPos(index, tick) {
			tick = tick;
			let i = posPointer - index & 0x3F;
			let j = posPointer - (index - 1) & 0x3F;
			let arrayOfDouble = new Array(3);
			let d1 = positions[i][0];
			let d2 = wrapDegrees(positions[j][0] - d1);
			arrayOfDouble[0] = d1 + d2 * tick;
			d1 = positions[i][1];
			d2 = positions[j][1] - d1;
			arrayOfDouble[1] = d1 + d2 * tick;
			arrayOfDouble[2] = lerp(tick, positions[i][2], positions[j][2]);
			return arrayOfDouble;
		}


		function getHeadPartYOffset(index, paramArrayOfdouble1, paramArrayOfdouble2) {
			let d;
			if (index == 6) {
				d = 0.0
			} else {
				d = paramArrayOfdouble2[1] - paramArrayOfdouble1[1];
			}
			return d;
		}

	}
});

function rotWrap(paramDouble) {
	while (paramDouble >= 180.0)
		paramDouble -= 360.0;
	while (paramDouble < -180.0)
		paramDouble += 360.0;
	return paramDouble;
}

function wrapDegrees(paramDouble) {
	let d = paramDouble % 360.0;
	if (d >= 180.0)
		d -= 360.0;
	if (d < -180.0)
		d += 360.0;
	return d;
}


var json_url = "data:application/json;base64,{"meta":{"format_version":"3.0","model_format":"bedrock","box_uv":true},"name":"ender_dragon","geo_name":"geometry.dragon","resolution":{"width":256,"height":256},"elements":[{"name":"upperlip","from":[-6,-1,-88],"to":[6,4,-72],"autouv":0,"color":0,"origin":[0,-21,-64],"uv_offset":[176,44],"uuid":"21ec5bc9-2a3c-fb3c-2691-775718081827"},{"name":"upperhead","from":[-8,-5,-74],"to":[8,11,-58],"autouv":0,"color":7,"origin":[0,3,-66],"uv_offset":[112,30],"uuid":"aafdee87-3510-a35d-309a-23999f163d54"},{"name":"scaleL","from":[3,11,-68],"to":[5,15,-62],"autouv":0,"color":5,"origin":[0,-21,-64],"uuid":"8c14c318-b19c-79c2-75c7-001296058a37"},{"name":"nostrilL","from":[3,4,-86],"to":[5,6,-82],"autouv":0,"color":7,"origin":[0,-21,-64],"uv_offset":[112,0],"uuid":"25725fc7-8c4a-c81b-2764-4ffb318d4439"},{"name":"scaleR","from":[-5,11,-68],"to":[-3,15,-62],"autouv":0,"color":7,"origin":[0,-21,-64],"uuid":"15eb3f75-f43a-7772-3f0f-84e7f079c432"},{"name":"nostrilR","from":[-5,4,-86],"to":[-3,6,-82],"autouv":0,"color":0,"origin":[0,-21,-64],"uv_offset":[112,0],"uuid":"4e50142a-f737-93d6-2bd7-5c23ecd70284"},{"name":"jaw","from":[-6,-5,-88],"to":[6,-1,-72],"autouv":0,"color":6,"origin":[0,-21,-64],"uv_offset":[176,65],"uuid":"4fe2e595-0f66-f6fb-8156-84629e3412ba"},{"name":"box","from":[-5,-2,-58],"to":[5,8,-48],"autouv":0,"color":3,"origin":[0,-21,-53],"uv_offset":[192,104],"uuid":"b2d3fca7-5550-3ac7-f6aa-4d62423e2d21"},{"name":"scale","from":[-1,8,-56],"to":[1,12,-50],"autouv":0,"color":7,"origin":[0,-21,-53],"uv_offset":[48,0],"uuid":"b71e3f26-cf21-1ff8-bb90-563628f2b142"},{"name":"body","from":[-12,-4,-8],"to":[12,20,56],"autouv":0,"color":6,"origin":[0,8,24],"uuid":"cffe2d0e-a03a-d3ae-d727-06ea949e1d2e"},{"name":"scale2","from":[-1,20,-2],"to":[1,26,10],"autouv":0,"color":6,"origin":[0,0,0],"uv_offset":[220,53],"uuid":"b4c1c793-c466-c40c-9ebe-f25f16c2c570"},{"name":"scale3","from":[-1,20,18],"to":[1,26,30],"autouv":0,"color":1,"origin":[0,0,0],"uv_offset":[220,53],"uuid":"54dc7caa-4259-350c-f479-f7816a3d83b9"},{"name":"scale4","from":[-1,20,38],"to":[1,26,50],"autouv":0,"color":3,"origin":[0,0,0],"uv_offset":[220,53],"uuid":"76962bc1-ddbf-256e-5d99-d3d286d04be3"},{"name":"bone","from":[12,15,-2],"to":[68,23,6],"autouv":0,"color":1,"origin":[12,19,2],"uv_offset":[112,88],"uuid":"9405f09e-75d6-1df9-e7a5-56ca51e81f88"},{"name":"skin","from":[12,19,4],"to":[68,19,60],"autouv":0,"color":1,"origin":[38,19,0],"uv_offset":[-56,88],"uuid":"94bae27d-9e66-dc4d-d25e-d731f7b1598b"},{"name":"bone2","from":[68,17,0],"to":[124,21,4],"autouv":0,"color":0,"origin":[68,19,2],"uv_offset":[112,136],"uuid":"a6e77403-46da-997e-f1ef-9329897539d9"},{"name":"skin2","from":[68,19,2],"to":[124,19,58],"autouv":0,"color":7,"origin":[94,19,0],"uv_offset":[-56,144],"uuid":"48a4e824-fb64-58d2-9c71-a24c65816c40"},{"name":"bone3","from":[-12,15,-2],"to":[44,23,6],"autouv":0,"color":2,"origin":[-12,18.999999999999996,2],"uv_offset":[112,88],"uuid":"afd0d599-4f1a-f607-8d6f-82b417fc5034"},{"name":"skin3","from":[-12,19,4],"to":[44,19,60],"autouv":0,"color":3,"origin":[21,18.999999999999996,3],"uv_offset":[-56,88],"uuid":"21bff2e1-1927-2039-ce9f-33fea019d72b"},{"name":"bone4","from":[44,17,0],"to":[100,21,4],"autouv":0,"color":2,"origin":[44,19.000000000000007,2],"uv_offset":[112,136],"uuid":"0fb04584-62e2-4d99-4c47-b5fb80182114"},{"name":"skin4","from":[44,19,2],"to":[100,19,58],"autouv":0,"color":4,"origin":[59,19,2],"uv_offset":[-56,144],"uuid":"7a2149ab-b305-ee44-160a-d441b0ec3849"},{"name":"rearleg","from":[8,-22,34],"to":[24,10,50],"autouv":0,"color":7,"origin":[16,-4,42],"uuid":"fd248e1d-8f00-011a-42a7-1bb6f13675dc"},{"name":"rearleg1","from":[-25,-22,34],"to":[-9,10,50],"autouv":0,"color":3,"origin":[-17,-6,42],"uuid":"f0cea2ed-5396-06d9-5425-f02a072643c7"},{"name":"frontleg","from":[9,-16,-2],"to":[17,8,6],"autouv":0,"color":0,"origin":[12,5,3],"uv_offset":[112,104],"uuid":"531df5f8-c996-8fb3-87be-f9eb08c700bc"},{"name":"frontleg1","from":[-17,-16,-2],"to":[-9,8,6],"autouv":0,"color":3,"origin":[-12,3,2],"uv_offset":[112,104],"uuid":"f2c06035-1d60-ce34-e4b3-677bd52dc83d"},{"name":"rearlegtip","from":[10,-54,36],"to":[22,-22,48],"autouv":0,"color":4,"origin":[16,-38,42],"uv_offset":[196,0],"uuid":"6885fac0-cd63-f77f-53b6-1a113f3e9c93"},{"name":"rearlegtip1","from":[-23,-54,36],"to":[-11,-22,48],"autouv":0,"color":1,"origin":[-16,-38,42],"uv_offset":[196,0],"uuid":"b7204ab9-1da4-26aa-2ec4-f9540e219af3"},{"name":"frontlegtip","from":[10,-40,-1],"to":[16,-16,5],"autouv":0,"color":1,"origin":[12,-16,2],"uv_offset":[226,138],"uuid":"798564bc-82cd-fb52-0a0b-51266ecd7d00"},{"name":"frontlegtip1","from":[-16,-40,-1],"to":[-10,-16,5],"autouv":0,"color":0,"origin":[-14,-1,0],"uv_offset":[226,138],"uuid":"0387a663-e431-8166-a00c-de4081746523"},{"name":"rearfoot","from":[7,-60,27],"to":[25,-54,51],"autouv":0,"color":5,"origin":[16,-57,39],"uv_offset":[112,0],"uuid":"802021b3-ff13-bfb3-2c99-8fdbf89954e6"},{"name":"rearfoot1","from":[-26,-60,26],"to":[-8,-54,50],"autouv":0,"color":4,"origin":[-16,-57,38],"uv_offset":[112,0],"uuid":"49825205-07bd-0e33-054e-f0afc4b7e16a"},{"name":"frontfoot","from":[9,-44,-10],"to":[17,-40,6],"autouv":0,"color":5,"origin":[12,-40,-2],"uv_offset":[144,104],"uuid":"002ae695-d5c3-e611-66fc-585351998b9e"},{"name":"frontfoot1","from":[-17,-44,-10],"to":[-9,-40,6],"autouv":0,"color":2,"origin":[-14,-40,0],"uv_offset":[144,104],"uuid":"e1f09333-2424-7fde-618e-82e5d7ba2797"},{"name":"box","from":[-5,-2,-48],"to":[5,8,-38],"autouv":0,"color":3,"origin":[0,-21,-43],"uv_offset":[192,104],"uuid":"a4dc32e6-be3b-70e4-6ff4-74e01c832fd5"},{"name":"scale","from":[-1,8,-46],"to":[1,12,-40],"autouv":0,"color":7,"origin":[0,-21,-43],"uv_offset":[48,0],"uuid":"abcfa406-4e20-017e-1f58-f4c76aea79f6"},{"name":"box","from":[-5,-2,-38],"to":[5,8,-28],"autouv":0,"color":3,"origin":[0,-21,-33],"uv_offset":[192,104],"uuid":"53e80a93-61f5-7832-d1b6-4cc9b02a1305"},{"name":"scale","from":[-1,8,-36],"to":[1,12,-30],"autouv":0,"color":7,"origin":[0,-21,-33],"uv_offset":[48,0],"uuid":"5123e8b1-3a41-9a57-898d-ffee5aa3c341"},{"name":"box","from":[-5,-2,-28],"to":[5,8,-18],"autouv":0,"color":3,"origin":[0,-21,-23],"uv_offset":[192,104],"uuid":"3bd70942-ec7f-5c38-e775-ca7f7028f57b"},{"name":"scale","from":[-1,8,-26],"to":[1,12,-20],"autouv":0,"color":7,"origin":[0,-21,-23],"uv_offset":[48,0],"uuid":"a14c618e-f383-83a2-ab4f-9f7f13717844"},{"name":"box","from":[-5,-2,-18],"to":[5,8,-8],"autouv":0,"color":3,"origin":[0,-21,-13],"uv_offset":[192,104],"uuid":"b687f135-e3e9-7b85-14b8-7459bfe22e80"},{"name":"scale","from":[-1,8,-16],"to":[1,12,-10],"autouv":0,"color":7,"origin":[0,-21,-13],"uv_offset":[48,0],"uuid":"d7abf5d1-247d-38fd-eed1-9c80a2cffbc3"},{"name":"box","from":[-5,9,56],"to":[5,19,66],"autouv":0,"color":3,"origin":[0,-10,61],"uv_offset":[192,104],"uuid":"7d6ab833-2a1d-037f-308f-52077ef3c8f5"},{"name":"scale","from":[-1,19,58],"to":[1,23,64],"autouv":0,"color":7,"origin":[0,-10,61],"uv_offset":[48,0],"uuid":"229d12f4-1d75-84cf-0a76-302fbf366971"},{"name":"box","from":[-5,9,66],"to":[5,19,76],"autouv":0,"color":3,"origin":[0,-10,71],"uv_offset":[192,104],"uuid":"c3b4cbea-88e3-7c1e-f358-7366a40cc968"},{"name":"scale","from":[-1,19,68],"to":[1,23,74],"autouv":0,"color":7,"origin":[0,-10,71],"uv_offset":[48,0],"uuid":"55918d67-96c0-2582-3636-dfbd9b9fcd64"},{"name":"box","from":[-5,9,76],"to":[5,19,86],"autouv":0,"color":3,"origin":[0,-10,81],"uv_offset":[192,104],"uuid":"e0f67e21-b96c-3fee-8a54-c0b81641c001"},{"name":"scale","from":[-1,19,78],"to":[1,23,84],"autouv":0,"color":7,"origin":[0,-10,81],"uv_offset":[48,0],"uuid":"6af0d546-9ba2-b490-3ef5-6ff6144b70ef"},{"name":"box","from":[-5,9,86],"to":[5,19,96],"autouv":0,"color":3,"origin":[0,-10,91],"uv_offset":[192,104],"uuid":"993fb277-2d13-cc3a-3f98-98a0e2fdd6ca"},{"name":"scale","from":[-1,19,88],"to":[1,23,94],"autouv":0,"color":7,"origin":[0,-10,91],"uv_offset":[48,0],"uuid":"9a00f4ee-6c1a-7a47-7261-e14c5f880b56"},{"name":"box","from":[-5,9,96],"to":[5,19,106],"autouv":0,"color":3,"origin":[0,-10,101],"uv_offset":[192,104],"uuid":"7404a9d6-a0dc-d3cd-cc2b-ffc400077e65"},{"name":"scale","from":[-1,19,98],"to":[1,23,104],"autouv":0,"color":7,"origin":[0,-10,101],"uv_offset":[48,0],"uuid":"2ce6f692-89f1-ec59-4d48-11d7c5d20227"},{"name":"box","from":[-5,9,106],"to":[5,19,116],"autouv":0,"color":3,"origin":[0,-10,111],"uv_offset":[192,104],"uuid":"e9a79399-e68c-df6b-e3ec-63163bad23d9"},{"name":"scale","from":[-1,19,108],"to":[1,23,114],"autouv":0,"color":7,"origin":[0,-10,111],"uv_offset":[48,0],"uuid":"32a81500-64cf-592c-6a47-a5472ec4b5f7"},{"name":"box","from":[-5,9,116],"to":[5,19,126],"autouv":0,"color":3,"origin":[0,-10,121],"uv_offset":[192,104],"uuid":"ec3ac4eb-e780-ebb7-f495-ff8dd183cbac"},{"name":"scale","from":[-1,19,118],"to":[1,23,124],"autouv":0,"color":7,"origin":[0,-10,121],"uv_offset":[48,0],"uuid":"a983771e-f254-3e04-cc6f-9c3e511e8b9b"},{"name":"box","from":[-5,9,126],"to":[5,19,136],"autouv":0,"color":3,"origin":[0,-10,131],"uv_offset":[192,104],"uuid":"12aebfe8-1753-64b2-10cc-4698a28516de"},{"name":"scale","from":[-1,19,128],"to":[1,23,134],"autouv":0,"color":7,"origin":[0,-10,131],"uv_offset":[48,0],"uuid":"9a21b685-5e68-d0f2-e45c-8f8845e850fa"},{"name":"box","from":[-5,9,136],"to":[5,19,146],"autouv":0,"color":3,"origin":[0,-10,141],"uv_offset":[192,104],"uuid":"ee0d9615-b865-913e-c0d9-fcd3b9ca0604"},{"name":"scale","from":[-1,19,138],"to":[1,23,144],"autouv":0,"color":7,"origin":[0,-10,141],"uv_offset":[48,0],"uuid":"3f9d7c56-4b87-c376-7b83-ebb8ee30509b"},{"name":"box","from":[-5,9,146],"to":[5,19,156],"autouv":0,"color":3,"origin":[0,-10,151],"uv_offset":[192,104],"uuid":"e365326a-2c1f-f77a-d9e9-2227d630cf83"},{"name":"scale","from":[-1,19,148],"to":[1,23,154],"autouv":0,"color":7,"origin":[0,-10,151],"uv_offset":[48,0],"uuid":"8993621c-82e5-f278-4362-4296c8dbb70f"},{"name":"box","from":[-5,9,156],"to":[5,19,166],"autouv":0,"color":3,"origin":[0,-10,161],"uv_offset":[192,104],"uuid":"a8eb97c7-c264-da5a-93b5-6645b0aa6380"},{"name":"scale","from":[-1,19,158],"to":[1,23,164],"autouv":0,"color":7,"origin":[0,-10,161],"uv_offset":[48,0],"uuid":"549a054c-397d-efec-4b72-236f4a38d08f"},{"name":"box","from":[-5,9,166],"to":[5,19,176],"autouv":0,"color":3,"origin":[0,-10,171],"uv_offset":[192,104],"uuid":"7e40c805-b993-8b9c-6e96-84170593dad5"},{"name":"scale","from":[-1,19,168],"to":[1,23,174],"autouv":0,"color":7,"origin":[0,-10,171],"uv_offset":[48,0],"uuid":"8d6ab6ad-e0da-f8b4-ce03-436db97ecb7e"}],"outliner":[{"name":"dragon","uuid":"c577c59e-fbf7-2069-096a-fdd8b084ec56","export":true,"isOpen":true,"visibility":true,"autouv":0,"origin":[0,0,0],"children":[{"name":"head","shade":false,"uuid":"fda23345-842f-8158-f98e-eebf95255098","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[0,3,-66],"children":["21ec5bc9-2a3c-fb3c-2691-775718081827","aafdee87-3510-a35d-309a-23999f163d54","8c14c318-b19c-79c2-75c7-001296058a37","25725fc7-8c4a-c81b-2764-4ffb318d4439","15eb3f75-f43a-7772-3f0f-84e7f079c432","4e50142a-f737-93d6-2bd7-5c23ecd70284",{"name":"jaw","shade":false,"uuid":"20f20e4c-e961-fa4d-3bb9-6fccac4f0ed0","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[0,-1,-72],"children":["4fe2e595-0f66-f6fb-8156-84629e3412ba"]}]},{"name":"neck","shade":false,"uuid":"44147023-b2bd-8a62-0e7a-dfbd71815ba0","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[0,3,-53],"children":["b2d3fca7-5550-3ac7-f6aa-4d62423e2d21","b71e3f26-cf21-1ff8-bb90-563628f2b142"]},{"name":"neck2","shade":false,"uuid":"20de3b8f-61ce-021a-a6fc-93bc6fa40bee","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[0,3,-43],"children":["a4dc32e6-be3b-70e4-6ff4-74e01c832fd5","abcfa406-4e20-017e-1f58-f4c76aea79f6"]},{"name":"neck3","shade":false,"uuid":"0051cb1f-924b-902f-2d1e-32a6bfdc887b","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[0,3,-33],"children":["53e80a93-61f5-7832-d1b6-4cc9b02a1305","5123e8b1-3a41-9a57-898d-ffee5aa3c341"]},{"name":"neck4","shade":false,"uuid":"67d4c6e7-e375-1987-2b8e-de6a0b6635e3","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[0,3,-23],"children":["3bd70942-ec7f-5c38-e775-ca7f7028f57b","a14c618e-f383-83a2-ab4f-9f7f13717844"]},{"name":"neck5","shade":false,"uuid":"59b7325f-c20b-60b6-e666-08e98da6e727","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[0,3,-13],"children":["b687f135-e3e9-7b85-14b8-7459bfe22e80","d7abf5d1-247d-38fd-eed1-9c80a2cffbc3"]},{"name":"body","shade":false,"uuid":"9dd7013f-66f5-1e0d-f8db-3227d154b910","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[0,8,24],"children":["cffe2d0e-a03a-d3ae-d727-06ea949e1d2e","b4c1c793-c466-c40c-9ebe-f25f16c2c570","54dc7caa-4259-350c-f479-f7816a3d83b9","76962bc1-ddbf-256e-5d99-d3d286d04be3"]},{"name":"leftWing","shade":false,"uuid":"ee6484f3-d796-42bd-a258-754581469752","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[12,19,2],"children":["9405f09e-75d6-1df9-e7a5-56ca51e81f88","94bae27d-9e66-dc4d-d25e-d731f7b1598b",{"name":"leftWingTip","shade":false,"uuid":"6f26741e-fcfa-a533-f85b-72740bea6c7a","export":true,"isOpen":true,"visibility":true,"autouv":0,"origin":[68,19,2],"children":["a6e77403-46da-997e-f1ef-9329897539d9","48a4e824-fb64-58d2-9c71-a24c65816c40"]}]},{"name":"rightWing","shade":false,"uuid":"667c8617-6d00-5d8b-94a6-7b2236a53675","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[-12,19,2],"rotation":[0,0,-180],"children":["afd0d599-4f1a-f607-8d6f-82b417fc5034","21bff2e1-1927-2039-ce9f-33fea019d72b",{"name":"rightWingTip","shade":false,"uuid":"8aeae58a-8d8b-4f57-4c83-74a7d3252058","export":true,"isOpen":true,"visibility":true,"autouv":0,"origin":[44,19,2],"children":["0fb04584-62e2-4d99-4c47-b5fb80182114","7a2149ab-b305-ee44-160a-d441b0ec3849"]}]},{"name":"leftRearLeg","shade":false,"uuid":"587c5479-d207-0045-4929-732b8947dc99","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[16,8,42],"children":["fd248e1d-8f00-011a-42a7-1bb6f13675dc",{"name":"leftRearLegTip","shade":false,"uuid":"68d2e400-e573-9569-5fef-f8a68e6d8881","export":true,"isOpen":true,"visibility":true,"autouv":0,"origin":[16,-22,38],"children":["6885fac0-cd63-f77f-53b6-1a113f3e9c93",{"name":"leftRearFoot","shade":false,"uuid":"7a8fe139-5087-b05d-5943-0f2d2d331943","export":true,"isOpen":true,"visibility":true,"autouv":0,"origin":[16,-54,42],"children":["802021b3-ff13-bfb3-2c99-8fdbf89954e6"]}]}]},{"name":"rightRearLeg","shade":false,"uuid":"f9618e24-5d11-25e8-37b7-6d4303b02c5d","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[-16,8,42],"children":["f0cea2ed-5396-06d9-5425-f02a072643c7",{"name":"rightRearLegTip","shade":false,"uuid":"fe67109b-c764-18c1-0e43-31999c044a59","export":true,"isOpen":true,"visibility":true,"autouv":0,"origin":[-16,-22,38],"children":["b7204ab9-1da4-26aa-2ec4-f9540e219af3",{"name":"rightRearFoot","shade":false,"uuid":"ba59e71a-005f-1f90-c61f-0ede40d86666","export":true,"isOpen":true,"visibility":true,"autouv":0,"origin":[-16,-54,42],"children":["49825205-07bd-0e33-054e-f0afc4b7e16a"]}]}]},{"name":"leftFrontLeg","shade":false,"uuid":"f7273abb-ad80-bd0e-3841-d6acd5cd47d4","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[12,4,2],"children":["531df5f8-c996-8fb3-87be-f9eb08c700bc",{"name":"leftFrontLegTip","shade":false,"uuid":"cd810fec-644d-d8e3-977f-e8a5be24a93a","export":true,"isOpen":true,"visibility":true,"autouv":0,"origin":[12,-16,2],"children":["798564bc-82cd-fb52-0a0b-51266ecd7d00",{"name":"leftFrontFoot","shade":false,"uuid":"0ec7d303-8c0b-98dc-e01d-112f5e6f2789","export":true,"isOpen":true,"visibility":true,"autouv":0,"origin":[12,-40,2],"children":["002ae695-d5c3-e611-66fc-585351998b9e"]}]}]},{"name":"rightFrontLeg","shade":false,"uuid":"6e132c7f-f39d-4bc0-6052-5a8b0f1f4e38","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[-12,3,2],"children":["f2c06035-1d60-ce34-e4b3-677bd52dc83d",{"name":"rightFrontLegTip","shade":false,"uuid":"a3f24cd2-0e98-e759-c0f9-37a9d6875174","export":true,"isOpen":true,"visibility":true,"autouv":0,"origin":[-12,-16,2],"children":["0387a663-e431-8166-a00c-de4081746523",{"name":"rightFrontFoot","shade":false,"uuid":"20a6498e-7ae4-b0db-afa4-2bd854715c7e","export":true,"isOpen":true,"visibility":true,"autouv":0,"origin":[-12,-40,0],"children":["e1f09333-2424-7fde-618e-82e5d7ba2797"]}]}]},{"name":"tail","shade":false,"uuid":"7b2fc7a0-0ead-0af6-cbbd-6af58fd2281c","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[0,14,61],"children":["7d6ab833-2a1d-037f-308f-52077ef3c8f5","229d12f4-1d75-84cf-0a76-302fbf366971"]},{"name":"tail2","shade":false,"uuid":"f32f4f39-cd43-97ac-e248-41b9b990b0b4","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[0,14,71],"children":["c3b4cbea-88e3-7c1e-f358-7366a40cc968","55918d67-96c0-2582-3636-dfbd9b9fcd64"]},{"name":"tail3","shade":false,"uuid":"979c3d4f-ccea-062d-33da-4448d11173ff","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[0,14,81],"children":["e0f67e21-b96c-3fee-8a54-c0b81641c001","6af0d546-9ba2-b490-3ef5-6ff6144b70ef"]},{"name":"tail4","shade":false,"uuid":"46480590-5ff9-d61f-d801-bf0beff4354f","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[0,14,91],"children":["993fb277-2d13-cc3a-3f98-98a0e2fdd6ca","9a00f4ee-6c1a-7a47-7261-e14c5f880b56"]},{"name":"tail5","shade":false,"uuid":"f916ac81-9f41-12ad-6299-88322f06a57b","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[0,14,101],"children":["7404a9d6-a0dc-d3cd-cc2b-ffc400077e65","2ce6f692-89f1-ec59-4d48-11d7c5d20227"]},{"name":"tail6","shade":false,"uuid":"7f405c98-b4c3-be2a-bfab-943e66f95e41","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[0,14,111],"children":["e9a79399-e68c-df6b-e3ec-63163bad23d9","32a81500-64cf-592c-6a47-a5472ec4b5f7"]},{"name":"tail7","shade":false,"uuid":"0e559282-27e6-4400-2133-6aa5d883ebae","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[0,14,121],"children":["ec3ac4eb-e780-ebb7-f495-ff8dd183cbac","a983771e-f254-3e04-cc6f-9c3e511e8b9b"]},{"name":"tail8","shade":false,"uuid":"58504cf8-f0b2-6b8c-126c-b2bb1ce1f562","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[0,14,131],"children":["12aebfe8-1753-64b2-10cc-4698a28516de","9a21b685-5e68-d0f2-e45c-8f8845e850fa"]},{"name":"tail9","shade":false,"uuid":"ff1d89fc-9ba6-2a75-0a63-3d0e741e645b","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[0,14,141],"children":["ee0d9615-b865-913e-c0d9-fcd3b9ca0604","3f9d7c56-4b87-c376-7b83-ebb8ee30509b"]},{"name":"tail10","shade":false,"uuid":"e499f6d3-4e53-503f-f883-69c7b51774bb","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[0,14,151],"children":["e365326a-2c1f-f77a-d9e9-2227d630cf83","8993621c-82e5-f278-4362-4296c8dbb70f"]},{"name":"tail11","shade":false,"uuid":"a7eb98a7-b48d-10c4-ffc5-54fac5ab2d31","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[0,14,161],"children":["a8eb97c7-c264-da5a-93b5-6645b0aa6380","549a054c-397d-efec-4b72-236f4a38d08f"]},{"name":"tail12","shade":false,"uuid":"0f2490fd-9bb0-450b-9e8c-139cf247b68b","export":true,"isOpen":false,"visibility":true,"autouv":0,"origin":[0,14,171],"children":["7e40c805-b993-8b9c-6e96-84170593dad5","8d6ab6ad-e0da-f8b4-ce03-436db97ecb7e"]}]}],"textures":[{"path":"dragon.png","name":"dragon.png","folder":"textures/entity/enderdragon","namespace":"minecraft","id":"0","particle":false,"mode":"link","saved":true,"uuid":"700fd673-b046-5015-5385-215f8eb4c3b2"}]}"
              
            
!
999px

Console