1
0
Fork 0
mirror of https://github.com/haselkern/Minecraft-ArmorStand.git synced 2025-10-25 07:54:05 +00:00

Easy way to edit equipment

This commit is contained in:
haselkern 2014-08-19 19:16:53 +02:00
parent baa78e919f
commit 906eba120f
3 changed files with 115 additions and 10 deletions

View file

@ -36,20 +36,46 @@
<input type="checkbox" name="showarms">Show Arms<br> <input type="checkbox" name="showarms">Show Arms<br>
<input type="checkbox" name="small">Small<br> <input type="checkbox" name="small">Small<br>
Rotation: <input type="range" name="rotation" min="0" max="360" value="0"><br> Rotation: <input type="range" name="rotation" min="0" max="360" value="0">
Head: <input type="range" name="headX" min="0" max="360" value="0"><input type="range" name="headY" min="0" max="360" value="0"><input type="range" name="headZ" min="0" max="360" value="0"><br> <div class="evenly">
<span>Head:</span><input type="range" name="headX" min="0" max="360" value="0"><input type="range" name="headY" min="0" max="360" value="0"><input type="range" name="headZ" min="0" max="360" value="0">
</div>
Body: <input type="range" name="bodyX" min="0" max="360" value="0"><input type="range" name="bodyY" min="0" max="360" value="0"><input type="range" name="bodyZ" min="0" max="360" value="0"><br> <div class="evenly">
<span>Body:</span><input type="range" name="bodyX" min="0" max="360" value="0"><input type="range" name="bodyY" min="0" max="360" value="0"><input type="range" name="bodyZ" min="0" max="360" value="0">
</div>
Left Leg: <input type="range" name="leftLegX" min="0" max="360" value="0"><input type="range" name="leftLegY" min="0" max="360" value="0"><input type="range" name="leftLegZ" min="0" max="360" value="0"><br> <div class="evenly">
<span>Left Leg:</span><input type="range" name="leftLegX" min="0" max="360" value="0"><input type="range" name="leftLegY" min="0" max="360" value="0"><input type="range" name="leftLegZ" min="0" max="360" value="0">
</div>
Right Leg: <input type="range" name="rightLegX" min="0" max="360" value="0"><input type="range" name="rightLegY" min="0" max="360" value="0"><input type="range" name="rightLegZ" min="0" max="360" value="0"><br> <div class="evenly">
<span>Right Leg:</span><input type="range" name="rightLegX" min="0" max="360" value="0"><input type="range" name="rightLegY" min="0" max="360" value="0"><input type="range" name="rightLegZ" min="0" max="360" value="0">
</div>
<div id="inputarms"> <div id="inputarms">
Left Arm: <input type="range" name="leftArmX" min="0" max="360" value="0"><input type="range" name="leftArmY" min="0" max="360" value="0"><input type="range" name="leftArmZ" min="0" max="360" value="0"><br> <div class="evenly">
<span>Left Arm:</span><input type="range" name="leftArmX" min="0" max="360" value="0"><input type="range" name="leftArmY" min="0" max="360" value="0"><input type="range" name="leftArmZ" min="0" max="360" value="0">
</div>
Right Arm: <input type="range" name="rightArmX" min="0" max="360" value="0"><input type="range" name="rightArmY" min="0" max="360" value="0"><input type="range" name="rightArmZ" min="0" max="360" value="0"><br> <div class="evenly">
<span>Right Arm:</span><input type="range" name="rightArmX" min="0" max="360" value="0"><input type="range" name="rightArmY" min="0" max="360" value="0"><input type="range" name="rightArmZ" min="0" max="360" value="0">
</div>
</div>
<br>
<input type="checkbox" name="usecustomequipment">Use Custom Equipment
<div id="customequipment">
<div class="padding">
Enter the text id of an item (for example <i>stone</i> or <i>iron_sword</i>) into the appropriate slots. You can enter an arbitrary item for the head or hand, but the other slots must contain an appropriate item.
<input type="text" name="equipSword" placeholder="Item in hand">
<input type="text" name="equipShoes" placeholder="Shoes">
<input type="text" name="equipLeggings" placeholder="Leggings">
<input type="text" name="equipChestplate" placeholder="Chestplate">
<input type="text" name="equipHelmet" placeholder="Helmet">
<input type="checkbox" name="equipCustomHead">Use Helmet as player name for custom head
</div>
</div> </div>
</div> </div>
@ -73,6 +99,9 @@
/give @p command_block /give @p command_block
</div> </div>
<!-- We automated this.
<div class="padding"> <div class="padding">
<br> <br>
You can give the armor stand a <b>custom player head</b>! Just replace <i>Notch</i> with an username of your choice. You can give the armor stand a <b>custom player head</b>! Just replace <i>Notch</i> with an username of your choice.
@ -90,6 +119,8 @@
/entitydata @e[r=2,ArmorStand] {Equipment:[{id:"iron_sword",Count:1b},{id:"iron_boots",Count:1b},{id:"iron_leggings",Count:1b},{id:"iron_chestplate",Count:1b},{id:"iron_helmet",Count:1b}]} /entitydata @e[r=2,ArmorStand] {Equipment:[{id:"iron_sword",Count:1b},{id:"iron_boots",Count:1b},{id:"iron_leggings",Count:1b},{id:"iron_chestplate",Count:1b},{id:"iron_helmet",Count:1b}]}
</div> </div>
-->
<div class="padding"> <div class="padding">
<br> <br>
If you are a mapmaker you might not want players to take items out of the armor stand. If you want to lock all slots, replace n with 1 (or 0 if you want to unlock it).<br> If you are a mapmaker you might not want players to take items out of the armor stand. If you want to lock all slots, replace n with 1 (or 0 if you want to unlock it).<br>

67
main.js
View file

@ -31,6 +31,15 @@ var noBasePlate = false;
var noGravity = false; var noGravity = false;
var showArms = false; var showArms = false;
var small = false; var small = false;
var useCustomEquipment;
var equipSword;
var equipShoes;
var equipLeggings;
var equipChestplate;
var equipHelmet;
var equipCustomHead;
//The rotation values are all in degrees. //The rotation values are all in degrees.
var head = new THREE.Vector3(0,0,0); var head = new THREE.Vector3(0,0,0);
var body = new THREE.Vector3(0,0,0); var body = new THREE.Vector3(0,0,0);
@ -39,7 +48,6 @@ var rightLeg = new THREE.Vector3(0,0,0);
var leftArm = new THREE.Vector3(0,0,0); var leftArm = new THREE.Vector3(0,0,0);
var rightArm = new THREE.Vector3(0,0,0); var rightArm = new THREE.Vector3(0,0,0);
var rotation = 0; var rotation = 0;
var vec0 = new THREE.Vector3(0,0,0); // We use this to determine if we want a pose in the command.
//Stuff for mouse movements //Stuff for mouse movements
var mouseDownX; var mouseDownX;
@ -227,6 +235,15 @@ function handleInput(){
showArms = getCheckBoxInput("showarms"); showArms = getCheckBoxInput("showarms");
small = getCheckBoxInput("small"); small = getCheckBoxInput("small");
useCustomEquipment = getCheckBoxInput("usecustomequipment");
equipSword = getInput("equipSword");
equipShoes = getInput("equipShoes");
equipLeggings = getInput("equipLeggings");
equipChestplate = getInput("equipChestplate");
equipHelmet = getInput("equipHelmet");
equipCustomHead = getCheckBoxInput("equipCustomHead");
body.set(getRangeInput("bodyX"), getRangeInput("bodyY"), getRangeInput("bodyZ")); body.set(getRangeInput("bodyX"), getRangeInput("bodyY"), getRangeInput("bodyZ"));
head.set(getRangeInput("headX"), getRangeInput("headY"), getRangeInput("headZ")); head.set(getRangeInput("headX"), getRangeInput("headY"), getRangeInput("headZ"));
leftLeg.set(getRangeInput("leftLegX"), getRangeInput("leftLegY"), getRangeInput("leftLegZ")); leftLeg.set(getRangeInput("leftLegX"), getRangeInput("leftLegY"), getRangeInput("leftLegZ"));
@ -244,19 +261,27 @@ function getCheckBoxInput(name){
function getRangeInput(name){ function getRangeInput(name){
return $("input[name="+name+"]").val(); return $("input[name="+name+"]").val();
} }
function getInput(name){
return $("input[name="+name+"]").val();
}
/** Changes stuff according to our input values */ /** Changes stuff according to our input values */
function updateUI(){ function updateUI(){
//Hide/Show the arm section //Hide/Show different inputs
if(showArms) if(showArms)
$("#inputarms").show(); $("#inputarms").show();
else else
$("#inputarms").hide(); $("#inputarms").hide();
if(useCustomEquipment)
$("#customequipment").show();
else
$("#customequipment").hide();
$("#code").text(generateCode()); $("#code").text(generateCode());
if(generateCode().length > 100){ if(generateCode().length > 100){
$("#codeinfo").html("<b>Please note:</b> This command is too long to be executed from chat. You need to place it inside a command block. (See tips and tricks below.)"); $("#codeinfo").html("<b>Please note:</b> This command is too long to be executed from chat. You need to place it inside a command block. (See tips and tricks below.)");
} }
// Rotate 3D Stuff // Rotate 3D Stuff
// y and z rotation needs to be inverted // y and z rotation needs to be inverted
mBody.rotation.set(body.x * DEG2RAD, -body.y * DEG2RAD, -body.z * DEG2RAD); mBody.rotation.set(body.x * DEG2RAD, -body.y * DEG2RAD, -body.z * DEG2RAD);
@ -295,6 +320,44 @@ function generateCode(){
if(rotation != 0) if(rotation != 0)
tags.push("Rotation:["+rotation+"f]"); tags.push("Rotation:["+rotation+"f]");
//Equipment
if(useCustomEquipment){
var equip = [];
if(equipSword != "")
equip.push("{id:\""+equipSword+"\",Count:1b}");
else
equip.push("{}");
if(equipShoes != "")
equip.push("{id:\""+equipShoes+"\",Count:1b}");
else
equip.push("{}");
if(equipLeggings != "")
equip.push("{id:\""+equipLeggings+"\",Count:1b}");
else
equip.push("{}");
if(equipChestplate != "")
equip.push("{id:\""+equipChestplate+"\",Count:1b}");
else
equip.push("{}");
if(equipHelmet != ""){
if(equipCustomHead){
equip.push("{id:\"skull\",Count:1b,Damage:3b,tag:{SkullOwner:\""+equipHelmet+"\"}}");
}
else{
equip.push("{id:\""+equipHelmet+"\",Count:1b}");
}
}
else
equip.push("{}");
tags.push("Equipment:["+equip.join(",")+"]");
}
//Now the pose //Now the pose
var pose = []; var pose = [];
if(!isZero(body)) if(!isZero(body))

View file

@ -1,6 +1,6 @@
html, body{ html, body{
height: 100%; height: 100%;
font-family: Arial; font-family: Arial, sans-serif;
margin: 0; margin: 0;
padding: 0; padding: 0;
} }
@ -30,6 +30,13 @@ a{
color: #000000; color: #000000;
} }
/* We cheat a bit here to fit all the controls in one row.
I will add a proper workaround later.
*/
.evenly *{
width: 24%;
}
#gl{ #gl{
width: 60%; width: 60%;
height: 100%; height: 100%;
@ -55,3 +62,7 @@ a{
background-color: #37474f; background-color: #37474f;
color: #ffffff; color: #ffffff;
} }
#customequipment input[type=text]{
width: 100%;
}