resent-1.8/src/main/java/net/minecraft/client/model/ModelBase.java

79 lines
2.8 KiB
Java
Raw Normal View History

2022-12-27 10:59:46 -08:00
package net.minecraft.client.model;
2023-01-14 07:56:36 -08:00
import com.google.common.collect.Lists;
import com.google.common.collect.Maps;
2022-12-27 10:59:46 -08:00
import java.util.List;
import java.util.Map;
import net.lax1dude.eaglercraft.v1_8.EaglercraftRandom;
import net.minecraft.entity.Entity;
import net.minecraft.entity.EntityLivingBase;
public abstract class ModelBase {
2023-01-14 07:56:36 -08:00
public float swingProgress;
public boolean isRiding;
public boolean isChild = true;
/**+
* This is a list of all the boxes (ModelRenderer.class) in the
* current model.
*/
public List<ModelRenderer> boxList = Lists.newArrayList();
private Map<String, TextureOffset> modelTextureMap = Maps.newHashMap();
public int textureWidth = 64;
public int textureHeight = 32;
/**+
* Sets the models various rotation angles then renders the
* model.
*/
public void render(Entity var1, float var2, float var3, float var4, float var5, float var6, float var7) {}
2022-12-27 10:59:46 -08:00
2023-01-14 07:56:36 -08:00
/**+
* Sets the model's various rotation angles. For bipeds, par1
* and par2 are used for animating the movement of arms and
* legs, where par1 represents the time(so that arms and legs
* swing back and forth) and par2 represents how "far" arms and
* legs can swing at most.
*/
public void setRotationAngles(float var1, float var2, float var3, float var4, float var5, float var6, Entity var7) {}
2022-12-27 10:59:46 -08:00
2023-01-14 07:56:36 -08:00
/**+
* Used for easily adding entity-dependent animations. The
* second and third float params here are the same second and
* third as in the setRotationAngles method.
*/
public void setLivingAnimations(EntityLivingBase var1, float var2, float var3, float var4) {}
2022-12-27 10:59:46 -08:00
2023-01-14 07:56:36 -08:00
public ModelRenderer getRandomModelBox(EaglercraftRandom rand) {
return (ModelRenderer) this.boxList.get(rand.nextInt(this.boxList.size()));
}
2022-12-27 10:59:46 -08:00
2023-01-14 07:56:36 -08:00
protected void setTextureOffset(String partName, int x, int y) {
this.modelTextureMap.put(partName, new TextureOffset(x, y));
}
2022-12-27 10:59:46 -08:00
2023-01-14 07:56:36 -08:00
public TextureOffset getTextureOffset(String partName) {
return (TextureOffset) this.modelTextureMap.get(partName);
}
2022-12-27 10:59:46 -08:00
2023-01-14 07:56:36 -08:00
/**+
* Copies the angles from one object to another. This is used
* when objects should stay aligned with each other, like the
* hair over a players head.
*/
public static void copyModelAngles(ModelRenderer source, ModelRenderer dest) {
dest.rotateAngleX = source.rotateAngleX;
dest.rotateAngleY = source.rotateAngleY;
dest.rotateAngleZ = source.rotateAngleZ;
dest.rotationPointX = source.rotationPointX;
dest.rotationPointY = source.rotationPointY;
dest.rotationPointZ = source.rotationPointZ;
}
2022-12-27 10:59:46 -08:00
2023-01-14 07:56:36 -08:00
public void setModelAttributes(ModelBase modelbase) {
this.swingProgress = modelbase.swingProgress;
this.isRiding = modelbase.isRiding;
this.isChild = modelbase.isChild;
}
}