From 26cad1e42e4f0308fc7e9d8246a9bda06c9c1b75 Mon Sep 17 00:00:00 2001
From: Justin Barker <46458276+JustinTimeCuber@users.noreply.github.com>
Date: Thu, 26 Oct 2023 18:04:59 -0500
Subject: [PATCH] Add 22w42a (crafter) and 22w43a (copper & tuff additions)
blocks (#1657)
* 22w42a (crafter) and 22w43a (copper & tuff additions)
* code cleanup
---
.../chunky/block/MinecraftBlockProvider.java | 47 +++++++-
.../chunky/block/SolidNonOpaqueBlock.java | 12 ++
.../chunky/block/minecraft/CopperBulb.java | 44 +++++++
.../llbit/chunky/block/minecraft/Crafter.java | 100 ++++++++++++++++
.../chunky/block/minecraft/RedstoneLamp.java | 10 +-
.../se/llbit/chunky/chunk/BlockPalette.java | 81 ++++++++-----
.../src/java/se/llbit/chunky/model/Model.java | 12 ++
.../chunky/model/RotatableBlockModel.java | 111 ++++++++++++++++++
.../se/llbit/chunky/resources/Texture.java | 108 +++++++++++++++++
9 files changed, 493 insertions(+), 32 deletions(-)
create mode 100644 chunky/src/java/se/llbit/chunky/block/SolidNonOpaqueBlock.java
create mode 100644 chunky/src/java/se/llbit/chunky/block/minecraft/CopperBulb.java
create mode 100644 chunky/src/java/se/llbit/chunky/block/minecraft/Crafter.java
create mode 100644 chunky/src/java/se/llbit/chunky/model/RotatableBlockModel.java
diff --git a/chunky/src/java/se/llbit/chunky/block/MinecraftBlockProvider.java b/chunky/src/java/se/llbit/chunky/block/MinecraftBlockProvider.java
index 87b9f53145..f5421d9c7c 100644
--- a/chunky/src/java/se/llbit/chunky/block/MinecraftBlockProvider.java
+++ b/chunky/src/java/se/llbit/chunky/block/MinecraftBlockProvider.java
@@ -7,7 +7,6 @@
import se.llbit.chunky.entity.SkullEntity;
import se.llbit.chunky.model.minecraft.FlowerPotModel;
import se.llbit.chunky.model.minecraft.FlowerPotModel.Kind;
-import se.llbit.chunky.resources.EntityTexture;
import se.llbit.chunky.resources.ShulkerTexture;
import se.llbit.chunky.resources.Texture;
import se.llbit.chunky.world.BlockData;
@@ -1005,7 +1004,6 @@ private static void addBlocks(Texture texture, String... names) {
addBlock("bamboo_mosaic_slab", (name, tag) -> slab(tag, Texture.bambooMosaic));
addBlock("bamboo_mosaic_stairs", (name, tag) -> stairs(tag, Texture.bambooMosaic));
addBlock("bamboo_trapdoor", (name, tag) -> trapdoor(tag, Texture.bambooTrapdoor));
-
addBlock("cherry_button", (name, tag) -> button(tag, Texture.cherryPlanks));
addBlock("cherry_door", (name, tag) -> door(tag, Texture.cherryDoorTop, Texture.cherryDoorBottom));
addBlock("cherry_fence", (name, tag) -> fence(tag, Texture.cherryPlanks));
@@ -1074,6 +1072,51 @@ private static void addBlocks(Texture texture, String... names) {
addBlock("bamboo_wall_hanging_sign", (name, tag) -> wallHangingSign(tag, "bamboo"));
addBlock("cherry_hanging_sign", (name, tag) -> hangingSign(tag, "cherry"));
addBlock("cherry_wall_hanging_sign", (name, tag) -> wallHangingSign(tag, "cherry"));
+
+ //1.21
+ addBlock("tuff_slab", (name, tag) -> slab(tag, Texture.tuff));
+ addBlock("tuff_stairs", (name, tag) -> stairs(tag, Texture.tuff));
+ addBlock("tuff_wall", (name, tag) -> wall(tag, Texture.tuff));
+ addBlock("polished_tuff", Texture.polishedTuff);
+ addBlock("polished_tuff_slab", (name, tag) -> slab(tag, Texture.polishedTuff));
+ addBlock("polished_tuff_stairs", (name, tag) -> stairs(tag, Texture.polishedTuff));
+ addBlock("polished_tuff_wall", (name, tag) -> wall(tag, Texture.polishedTuff));
+ addBlock("tuff_bricks", Texture.tuffBricks);
+ addBlock("tuff_brick_slab", (name, tag) -> slab(tag, Texture.tuffBricks));
+ addBlock("tuff_brick_stairs", (name, tag) -> stairs(tag, Texture.tuffBricks));
+ addBlock("tuff_brick_wall", (name, tag) -> wall(tag, Texture.tuffBricks));
+ addBlock("chiseled_tuff", Texture.chiseledTuff);
+ addBlock("chiseled_tuff_bricks", Texture.chiseledTuffBricks);
+ for(String s : new String[]{"", "waxed_"}) {
+ addBlock(s + "chiseled_copper", Texture.chiseledCopper);
+ addBlock(s + "copper_grate", (name, tag) -> new SolidNonOpaqueBlock(name, Texture.copperGrate));
+ addBlock(s + "copper_bulb", (name, tag) -> new CopperBulb(name, tag.get("Properties").get("lit").stringValue().equals("true"), tag.get("Properties").get("powered").stringValue().equals("true"),
+ Texture.copperBulbLitPowered, Texture.copperBulbLit, Texture.copperBulbPowered, Texture.copperBulb));
+ addBlock(s + "copper_door", (name, tag) -> door(tag, Texture.copperDoorTop, Texture.copperDoorBottom));
+ addBlock(s + "copper_trapdoor", (name, tag) -> trapdoor(tag, Texture.copperTrapdoor));
+ addBlock(s + "exposed_chiseled_copper", Texture.exposedChiseledCopper);
+ addBlock(s + "exposed_copper_grate", Texture.exposedCopperGrate);
+ addBlock(s + "exposed_copper_bulb", (name, tag) -> new CopperBulb(name, tag.get("Properties").get("lit").stringValue().equals("true"), tag.get("Properties").get("powered").stringValue().equals("true"),
+ Texture.exposedCopperBulbLitPowered, Texture.exposedCopperBulbLit, Texture.exposedCopperBulbPowered, Texture.exposedCopperBulb));
+ addBlock(s + "exposed_copper_door", (name, tag) -> door(tag, Texture.exposedCopperDoorTop, Texture.exposedCopperDoorBottom));
+ addBlock(s + "exposed_copper_trapdoor", (name, tag) -> trapdoor(tag, Texture.exposedCopperTrapdoor));
+ addBlock(s + "weathered_chiseled_copper", Texture.weatheredChiseledCopper);
+ addBlock(s + "weathered_copper_grate", Texture.weatheredCopperGrate);
+ addBlock(s + "weathered_copper_bulb", (name, tag) -> new CopperBulb(name, tag.get("Properties").get("lit").stringValue().equals("true"), tag.get("Properties").get("powered").stringValue().equals("true"),
+ Texture.weatheredCopperBulbLitPowered, Texture.weatheredCopperBulbLit, Texture.weatheredCopperBulbPowered, Texture.weatheredCopperBulb));
+ addBlock(s + "weathered_copper_door", (name, tag) -> door(tag, Texture.weatheredCopperDoorTop, Texture.weatheredCopperDoorBottom));
+ addBlock(s + "weathered_copper_trapdoor", (name, tag) -> trapdoor(tag, Texture.weatheredCopperTrapdoor));
+ addBlock(s + "oxidized_chiseled_copper", Texture.oxidizedChiseledCopper);
+ addBlock(s + "oxidized_copper_grate", Texture.oxidizedCopperGrate);
+ addBlock(s + "oxidized_copper_bulb", (name, tag) -> new CopperBulb(name, tag.get("Properties").get("lit").stringValue().equals("true"), tag.get("Properties").get("powered").stringValue().equals("true"),
+ Texture.oxidizedCopperBulbLitPowered, Texture.oxidizedCopperBulbLit, Texture.oxidizedCopperBulbPowered, Texture.oxidizedCopperBulb));
+ addBlock(s + "oxidized_copper_door", (name, tag) -> door(tag, Texture.oxidizedCopperDoorTop, Texture.oxidizedCopperDoorBottom));
+ addBlock(s + "oxidized_copper_trapdoor", (name, tag) -> trapdoor(tag, Texture.oxidizedCopperTrapdoor));
+ }
+ addBlock("crafter", (name, tag) -> new Crafter(name, tag.get("Properties").get("orientation").stringValue(), tag.get("Properties").get("crafting").stringValue().equals("true"), tag.get("Properties").get("triggered").stringValue().equals("true"),
+ Texture.crafterNorth, Texture.crafterNorthCrafting, Texture.crafterEast, Texture.crafterEastCrafting, Texture.crafterEastTriggered,
+ Texture.crafterSouth, Texture.crafterSouthTriggered, Texture.crafterWest, Texture.crafterWestCrafting, Texture.crafterWestTriggered,
+ Texture.crafterTop, Texture.crafterTopCrafting, Texture.crafterTopTriggered, Texture.crafterBottom));
}
@Override
diff --git a/chunky/src/java/se/llbit/chunky/block/SolidNonOpaqueBlock.java b/chunky/src/java/se/llbit/chunky/block/SolidNonOpaqueBlock.java
new file mode 100644
index 0000000000..1fab2c7711
--- /dev/null
+++ b/chunky/src/java/se/llbit/chunky/block/SolidNonOpaqueBlock.java
@@ -0,0 +1,12 @@
+package se.llbit.chunky.block;
+
+import se.llbit.chunky.resources.Texture;
+
+public class SolidNonOpaqueBlock extends Block {
+
+ public SolidNonOpaqueBlock(String name, Texture texture) {
+ super(name, texture);
+ solid = true;
+ opaque = false;
+ }
+}
diff --git a/chunky/src/java/se/llbit/chunky/block/minecraft/CopperBulb.java b/chunky/src/java/se/llbit/chunky/block/minecraft/CopperBulb.java
new file mode 100644
index 0000000000..31cc91ccae
--- /dev/null
+++ b/chunky/src/java/se/llbit/chunky/block/minecraft/CopperBulb.java
@@ -0,0 +1,44 @@
+/*
+ * Copyright (c) 2023 Chunky contributors
+ *
+ * This file is part of Chunky.
+ *
+ * Chunky is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * Chunky is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ * You should have received a copy of the GNU General Public License
+ * along with Chunky. If not, see .
+ */
+
+package se.llbit.chunky.block.minecraft;
+
+import se.llbit.chunky.block.MinecraftBlock;
+import se.llbit.chunky.resources.Texture;
+
+public class CopperBulb extends MinecraftBlock {
+ private final boolean lit;
+ private final boolean powered;
+
+ public CopperBulb(String name, boolean lit, boolean powered, Texture lp, Texture lnp, Texture nlp, Texture nlnp) {
+ super(name, lit ? (powered ? lp : lnp) : (powered ? nlp : nlnp));
+ this.lit = lit;
+ this.powered = powered;
+ }
+ public boolean isLit() {
+ return lit;
+ }
+
+ public boolean isPowered() {
+ return powered;
+ }
+
+ @Override public String description() {
+ return "lit=" + lit + ", powered=" + powered;
+ }
+}
diff --git a/chunky/src/java/se/llbit/chunky/block/minecraft/Crafter.java b/chunky/src/java/se/llbit/chunky/block/minecraft/Crafter.java
new file mode 100644
index 0000000000..a5d1778410
--- /dev/null
+++ b/chunky/src/java/se/llbit/chunky/block/minecraft/Crafter.java
@@ -0,0 +1,100 @@
+/*
+ * Copyeast (c) 2023 Chunky contributors
+ *
+ * This file is part of Chunky.
+ *
+ * Chunky is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * Chunky is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ * You should have received a copy of the GNU General Public License
+ * along with Chunky. If not, see .
+ */
+
+package se.llbit.chunky.block.minecraft;
+
+import se.llbit.chunky.block.AbstractModelBlock;
+import se.llbit.chunky.model.RotatableBlockModel;
+import se.llbit.chunky.resources.Texture;
+import se.llbit.math.Quad;
+import se.llbit.math.Vector3;
+import se.llbit.math.Vector4;
+
+public class Crafter extends AbstractModelBlock {
+
+ private final String description;
+
+ public Crafter(String name, String orientation, boolean crafting, boolean triggered, Texture north, Texture northCrafting, Texture east, Texture eastCrafting, Texture eastTriggered,
+ Texture south, Texture southTriggered, Texture west, Texture westCrafting, Texture westTriggered, Texture top, Texture topCrafting, Texture topTriggered, Texture bottom) {
+ super(name, north);
+ this.description = "orientation=" + orientation + ", crafting=" + crafting + ", triggered=" + triggered;
+ RotatableBlockModel m = new RotatableBlockModel(crafting ? northCrafting : north,
+ crafting ? eastCrafting : (triggered ? eastTriggered : east),
+ triggered ? southTriggered : south,
+ crafting ? westCrafting : (triggered ? westTriggered : west),
+ crafting ? topCrafting : (triggered ? topTriggered : top),
+ bottom);
+ // Fix top quad
+ m.setFaceQuad(4, new Quad(
+ new Vector3(1, 1, 0),
+ new Vector3(0, 1, 0),
+ new Vector3(1, 1, 1),
+ new Vector4(1, 0, 0, 1))); // texture is mirrored for some reason??
+ switch(orientation) {
+ case "north_up":
+ break;
+ case "east_up":
+ m.rotateY(1);
+ break;
+ case "south_up":
+ m.rotateY(2);
+ break;
+ case "west_up":
+ m.rotateY(-1);
+ break;
+ case "up_south":
+ m.rotateX(1);
+ break;
+ case "up_west":
+ m.rotateX(1);
+ m.rotateY(1);
+ break;
+ case "up_north":
+ m.rotateX(1);
+ m.rotateY(2);
+ break;
+ case "up_east":
+ m.rotateX(1);
+ m.rotateY(-1);
+ break;
+ case "down_north":
+ m.rotateX(-1);
+ break;
+ case "down_east":
+ m.rotateX(-1);
+ m.rotateY(1);
+ break;
+ case "down_south":
+ m.rotateX(-1);
+ m.rotateY(2);
+ break;
+ case "down_west":
+ m.rotateX(-1);
+ m.rotateY(-1);
+ break;
+ }
+ this.model = m;
+ opaque = true;
+ solid = true;
+ }
+
+ @Override
+ public String description() {
+ return description;
+ }
+}
diff --git a/chunky/src/java/se/llbit/chunky/block/minecraft/RedstoneLamp.java b/chunky/src/java/se/llbit/chunky/block/minecraft/RedstoneLamp.java
index 6b6008b2cb..c9930f607d 100644
--- a/chunky/src/java/se/llbit/chunky/block/minecraft/RedstoneLamp.java
+++ b/chunky/src/java/se/llbit/chunky/block/minecraft/RedstoneLamp.java
@@ -22,14 +22,18 @@
import se.llbit.chunky.resources.Texture;
public class RedstoneLamp extends MinecraftBlock {
- public final boolean isLit;
+ private final boolean lit;
public RedstoneLamp(boolean lit) {
super("redstone_lamp", lit ? Texture.redstoneLampOn : Texture.redstoneLampOff);
- this.isLit = lit;
+ this.lit = lit;
+ }
+
+ public boolean isLit() {
+ return lit;
}
@Override public String description() {
- return "lit=" + isLit;
+ return "lit=" + lit;
}
}
diff --git a/chunky/src/java/se/llbit/chunky/chunk/BlockPalette.java b/chunky/src/java/se/llbit/chunky/chunk/BlockPalette.java
index 9fc15279d2..93394c1338 100644
--- a/chunky/src/java/se/llbit/chunky/chunk/BlockPalette.java
+++ b/chunky/src/java/se/llbit/chunky/chunk/BlockPalette.java
@@ -19,6 +19,7 @@
import se.llbit.chunky.block.*;
import se.llbit.chunky.block.minecraft.*;
import se.llbit.chunky.plugin.PluginApi;
+import se.llbit.chunky.resources.Texture;
import se.llbit.math.Octree;
import se.llbit.nbt.CompoundTag;
import se.llbit.nbt.IntTag;
@@ -380,7 +381,7 @@ public static Map> getDefaultMaterialProperties() {
block.ior = 1.52f;
});
materialProperties.put("minecraft:redstone_lamp", block -> {
- if (block instanceof RedstoneLamp && ((RedstoneLamp) block).isLit) {
+ if (block instanceof RedstoneLamp && ((RedstoneLamp) block).isLit()) {
block.emittance = 1.0f;
}
});
@@ -480,42 +481,46 @@ public static Map> getDefaultMaterialProperties() {
block.metalness = 1.0f;
block.setPerceptualSmoothness(0.75);
};
- Consumer lightlyWeatheredCopperConfig = block -> {
+ Consumer exposedCopperConfig = block -> {
block.metalness = 0.66f;
block.setPerceptualSmoothness(0.75);
};
- Consumer semiWeatheredCopperConfig = block -> {
+ Consumer weatheredCopperConfig = block -> {
block.metalness = 0.66f;
block.setPerceptualSmoothness(0.75);
};
- materialProperties.put("minecraft:copper_block", copperConfig);
materialProperties.put("minecraft:raw_copper_block", block -> {
block.metalness = 0.66f;
block.setPerceptualSmoothness(0.5);
});
- materialProperties.put("minecraft:exposed_copper", lightlyWeatheredCopperConfig);
- materialProperties.put("minecraft:weathered_copper", semiWeatheredCopperConfig);
- materialProperties.put("minecraft:cut_copper", copperConfig);
- materialProperties.put("minecraft:exposed_cut_copper", lightlyWeatheredCopperConfig);
- materialProperties.put("minecraft:weathered_cut_copper", semiWeatheredCopperConfig);
- materialProperties.put("minecraft:cut_copper_stairs", copperConfig);
- materialProperties.put("minecraft:exposed_cut_copper_stairs", lightlyWeatheredCopperConfig);
- materialProperties.put("minecraft:weathered_cut_copper_stairs", semiWeatheredCopperConfig);
- materialProperties.put("minecraft:cut_copper_slab", copperConfig);
- materialProperties.put("minecraft:exposed_cut_copper_slab", lightlyWeatheredCopperConfig);
- materialProperties.put("minecraft:weathered_cut_copper_slab", semiWeatheredCopperConfig);
- materialProperties.put("minecraft:waxed_copper_block", copperConfig);
- materialProperties.put("minecraft:waxed_exposed_copper", lightlyWeatheredCopperConfig);
- materialProperties.put("minecraft:waxed_weathered_copper", semiWeatheredCopperConfig);
- materialProperties.put("minecraft:waxed_cut_copper", copperConfig);
- materialProperties.put("minecraft:waxed_exposed_cut_copper", lightlyWeatheredCopperConfig);
- materialProperties.put("minecraft:waxed_weathered_cut_copper", semiWeatheredCopperConfig);
- materialProperties.put("minecraft:waxed_cut_copper_stairs", copperConfig);
- materialProperties.put("minecraft:waxed_exposed_cut_copper_stairs", lightlyWeatheredCopperConfig);
- materialProperties.put("minecraft:waxed_weathered_cut_copper_stairs", semiWeatheredCopperConfig);
- materialProperties.put("minecraft:waxed_cut_copper_slab", copperConfig);
- materialProperties.put("minecraft:waxed_exposed_cut_copper_slab", lightlyWeatheredCopperConfig);
- materialProperties.put("minecraft:waxed_weathered_cut_copper_slab", semiWeatheredCopperConfig);
+ for(String s : new String[]{"minecraft:", "minecraft:waxed_"}) {
+ materialProperties.put(s + "copper_block", copperConfig);
+ materialProperties.put(s + "cut_copper", copperConfig);
+ materialProperties.put(s + "cut_copper_stairs", copperConfig);
+ materialProperties.put(s + "cut_copper_slab", copperConfig);
+ materialProperties.put(s + "chiseled_copper", copperConfig);
+ materialProperties.put(s + "copper_grate", copperConfig);
+ materialProperties.put(s + "copper_door", copperConfig);
+ materialProperties.put(s + "copper_trapdoor", copperConfig);
+
+ materialProperties.put(s + "exposed_copper", exposedCopperConfig);
+ materialProperties.put(s + "exposed_cut_copper", exposedCopperConfig);
+ materialProperties.put(s + "exposed_cut_copper_stairs", exposedCopperConfig);
+ materialProperties.put(s + "exposed_cut_copper_slab", exposedCopperConfig);
+ materialProperties.put(s + "exposed_chiseled_copper", exposedCopperConfig);
+ materialProperties.put(s + "exposed_copper_grate", exposedCopperConfig);
+ materialProperties.put(s + "exposed_copper_door", exposedCopperConfig);
+ materialProperties.put(s + "exposed_copper_trapdoor", exposedCopperConfig);
+
+ materialProperties.put(s + "weathered_copper", weatheredCopperConfig);
+ materialProperties.put(s + "weathered_cut_copper", weatheredCopperConfig);
+ materialProperties.put(s + "weathered_cut_copper_stairs", weatheredCopperConfig);
+ materialProperties.put(s + "weathered_cut_copper_slab", weatheredCopperConfig);
+ materialProperties.put(s + "weathered_chiseled_copper", weatheredCopperConfig);
+ materialProperties.put(s + "weathered_copper_grate", weatheredCopperConfig);
+ materialProperties.put(s + "weathered_copper_door", weatheredCopperConfig);
+ materialProperties.put(s + "weathered_copper_trapdoor", weatheredCopperConfig);
+ }
materialProperties.put("minecraft:lightning_rod", block -> {
// apply copper attributes only to non-powered lightning rods
if (block instanceof LightningRod && !((LightningRod) block).isPowered()) {
@@ -575,6 +580,28 @@ public static Map> getDefaultMaterialProperties() {
materialProperties.put("minecraft:sculk_catalyst", block -> {
block.emittance = 1.0f / 15f * 6;
});
+ for(String s : new String[]{"minecraft:", "minecraft:waxed_"}) {
+ materialProperties.put(s + "copper_bulb", block -> {
+ if(block instanceof CopperBulb && ((CopperBulb) block).isLit()) {
+ block.emittance = 1.0f;
+ }
+ });
+ materialProperties.put(s + "exposed_copper_bulb", block -> {
+ if(block instanceof CopperBulb && ((CopperBulb) block).isLit()) {
+ block.emittance = 12 / 15f;
+ }
+ });
+ materialProperties.put(s + "weathered_copper_bulb", block -> {
+ if(block instanceof CopperBulb && ((CopperBulb) block).isLit()) {
+ block.emittance = 8 / 15f;
+ }
+ });
+ materialProperties.put(s + "oxidized_copper_bulb", block -> {
+ if(block instanceof CopperBulb && ((CopperBulb) block).isLit()) {
+ block.emittance = 4 / 15f;
+ }
+ });
+ }
return materialProperties;
}
diff --git a/chunky/src/java/se/llbit/chunky/model/Model.java b/chunky/src/java/se/llbit/chunky/model/Model.java
index 32b22c0e7d..54a222911f 100644
--- a/chunky/src/java/se/llbit/chunky/model/Model.java
+++ b/chunky/src/java/se/llbit/chunky/model/Model.java
@@ -167,6 +167,18 @@ public static Quad[] rotateZ(Quad[] src) {
return rot;
}
+ /**
+ * @param src source quads
+ * @return Quads rotated about the negative Z axis
+ */
+ public static Quad[] rotateNegZ(Quad[] src) {
+ Quad[] rot = new Quad[src.length];
+ for (int i = 0; i < src.length; ++i) {
+ rot[i] = src[i].transform(Transform.NONE.rotateNegZ());
+ }
+ return rot;
+ }
+
/**
* @param src source quads
* @return Quads rotated about the Z axis by some angle
diff --git a/chunky/src/java/se/llbit/chunky/model/RotatableBlockModel.java b/chunky/src/java/se/llbit/chunky/model/RotatableBlockModel.java
new file mode 100644
index 0000000000..a397387a13
--- /dev/null
+++ b/chunky/src/java/se/llbit/chunky/model/RotatableBlockModel.java
@@ -0,0 +1,111 @@
+/*
+ * Copyright (c) 2016 Jesper Öqvist
+ *
+ * This file is part of Chunky.
+ *
+ * Chunky is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * Chunky is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ * You should have received a copy of the GNU General Public License
+ * along with Chunky. If not, see .
+ */
+package se.llbit.chunky.model;
+
+import se.llbit.chunky.resources.Texture;
+import se.llbit.math.Quad;
+import se.llbit.math.Vector3;
+import se.llbit.math.Vector4;
+
+/**
+ * This block model is used to render blocks which can face east, west, north, south, up and down.
+ * For example, command blocks and observer blocks.
+ */
+public class RotatableBlockModel extends QuadModel {
+ private Quad[] quads = new Quad[] {
+ FULL_BLOCK_NORTH_SIDE,
+ FULL_BLOCK_EAST_SIDE,
+ FULL_BLOCK_SOUTH_SIDE,
+ FULL_BLOCK_WEST_SIDE,
+ FULL_BLOCK_TOP_SIDE,
+ FULL_BLOCK_BOTTOM_SIDE
+ };
+ private final Texture[] textures;
+
+ public RotatableBlockModel(Texture north, Texture east, Texture south, Texture west, Texture top, Texture bottom) {
+ textures = new Texture[] {north, east, south, west, top, bottom};
+ }
+
+ public void setFaceQuad(int face, Quad quad) {
+ quads[face] = quad;
+ }
+
+ public void rotateX(int r) {
+ r %= 4;
+ if(r < 0) {
+ r += 4;
+ }
+ switch(r) {
+ case 1:
+ quads = Model.rotateX(quads);
+ break;
+ case 2:
+ quads = Model.rotateX(Model.rotateX(quads));
+ break;
+ case 3:
+ quads = Model.rotateNegX(quads);
+ break;
+ }
+ }
+
+ public void rotateY(int r) {
+ r %= 4;
+ if(r < 0) {
+ r += 4;
+ }
+ switch(r) {
+ case 1:
+ quads = Model.rotateY(quads);
+ break;
+ case 2:
+ quads = Model.rotateY(Model.rotateY(quads));
+ break;
+ case 3:
+ quads = Model.rotateNegY(quads);
+ break;
+ }
+ }
+
+ public void rotateZ(int r) {
+ r %= 4;
+ if(r < 0) {
+ r += 4;
+ }
+ switch(r) {
+ case 1:
+ quads = Model.rotateZ(quads);
+ break;
+ case 2:
+ quads = Model.rotateZ(Model.rotateZ(quads));
+ break;
+ case 3:
+ quads = Model.rotateNegZ(quads);
+ break;
+ }
+ }
+
+ @Override
+ public Quad[] getQuads() {
+ return quads;
+ }
+
+ @Override
+ public Texture[] getTextures() {
+ return textures;
+ }
+}
diff --git a/chunky/src/java/se/llbit/chunky/resources/Texture.java b/chunky/src/java/se/llbit/chunky/resources/Texture.java
index 7583945752..5bda12f467 100644
--- a/chunky/src/java/se/llbit/chunky/resources/Texture.java
+++ b/chunky/src/java/se/llbit/chunky/resources/Texture.java
@@ -1341,6 +1341,114 @@ public class Texture {
public static final Texture cherryHangingSign = new Texture();
@TexturePath("assets/minecraft/textures/entity/piglin/piglin")
public static final Texture piglin = new Texture();
+ @TexturePath("assets/minecraft/textures/block/polished_tuff")
+ public static final Texture polishedTuff = new Texture();
+ @TexturePath("assets/minecraft/textures/block/tuff_bricks")
+ public static final Texture tuffBricks = new Texture();
+ @TexturePath("assets/minecraft/textures/block/chiseled_tuff")
+ public static final Texture chiseledTuff = new Texture();
+ @TexturePath("assets/minecraft/textures/block/chiseled_tuff_bricks")
+ public static final Texture chiseledTuffBricks = new Texture();
+ @TexturePath("assets/minecraft/textures/block/chiseled_copper")
+ public static final Texture chiseledCopper = new Texture();
+ @TexturePath("assets/minecraft/textures/block/copper_grate")
+ public static final Texture copperGrate = new Texture();
+ @TexturePath("assets/minecraft/textures/block/copper_bulb")
+ public static final Texture copperBulb = new Texture();
+ @TexturePath("assets/minecraft/textures/block/copper_bulb_lit")
+ public static final Texture copperBulbLit = new Texture();
+ @TexturePath("assets/minecraft/textures/block/copper_bulb_powered")
+ public static final Texture copperBulbPowered = new Texture();
+ @TexturePath("assets/minecraft/textures/block/copper_bulb_lit_powered")
+ public static final Texture copperBulbLitPowered = new Texture();
+ @TexturePath("assets/minecraft/textures/block/copper_door_top")
+ public static final Texture copperDoorTop = new Texture();
+ @TexturePath("assets/minecraft/textures/block/copper_door_bottom")
+ public static final Texture copperDoorBottom = new Texture();
+ @TexturePath("assets/minecraft/textures/block/copper_trapdoor")
+ public static final Texture copperTrapdoor = new Texture();
+ @TexturePath("assets/minecraft/textures/block/exposed_chiseled_copper")
+ public static final Texture exposedChiseledCopper = new Texture();
+ @TexturePath("assets/minecraft/textures/block/exposed_copper_grate")
+ public static final Texture exposedCopperGrate = new Texture();
+ @TexturePath("assets/minecraft/textures/block/exposed_copper_bulb")
+ public static final Texture exposedCopperBulb = new Texture();
+ @TexturePath("assets/minecraft/textures/block/exposed_copper_bulb_lit")
+ public static final Texture exposedCopperBulbLit = new Texture();
+ @TexturePath("assets/minecraft/textures/block/exposed_copper_bulb_powered")
+ public static final Texture exposedCopperBulbPowered = new Texture();
+ @TexturePath("assets/minecraft/textures/block/exposed_copper_bulb_lit_powered")
+ public static final Texture exposedCopperBulbLitPowered = new Texture();
+ @TexturePath("assets/minecraft/textures/block/exposed_copper_door_top")
+ public static final Texture exposedCopperDoorTop = new Texture();
+ @TexturePath("assets/minecraft/textures/block/exposed_copper_door_bottom")
+ public static final Texture exposedCopperDoorBottom = new Texture();
+ @TexturePath("assets/minecraft/textures/block/exposed_copper_trapdoor")
+ public static final Texture exposedCopperTrapdoor = new Texture();
+ @TexturePath("assets/minecraft/textures/block/weathered_chiseled_copper")
+ public static final Texture weatheredChiseledCopper = new Texture();
+ @TexturePath("assets/minecraft/textures/block/weathered_copper_grate")
+ public static final Texture weatheredCopperGrate = new Texture();
+ @TexturePath("assets/minecraft/textures/block/weathered_copper_bulb")
+ public static final Texture weatheredCopperBulb = new Texture();
+ @TexturePath("assets/minecraft/textures/block/weathered_copper_bulb_lit")
+ public static final Texture weatheredCopperBulbLit = new Texture();
+ @TexturePath("assets/minecraft/textures/block/weathered_copper_bulb_powered")
+ public static final Texture weatheredCopperBulbPowered = new Texture();
+ @TexturePath("assets/minecraft/textures/block/weathered_copper_bulb_lit_powered")
+ public static final Texture weatheredCopperBulbLitPowered = new Texture();
+ @TexturePath("assets/minecraft/textures/block/weathered_copper_door_top")
+ public static final Texture weatheredCopperDoorTop = new Texture();
+ @TexturePath("assets/minecraft/textures/block/weathered_copper_door_bottom")
+ public static final Texture weatheredCopperDoorBottom = new Texture();
+ @TexturePath("assets/minecraft/textures/block/weathered_copper_trapdoor")
+ public static final Texture weatheredCopperTrapdoor = new Texture();
+ @TexturePath("assets/minecraft/textures/block/oxidized_chiseled_copper")
+ public static final Texture oxidizedChiseledCopper = new Texture();
+ @TexturePath("assets/minecraft/textures/block/oxidized_copper_grate")
+ public static final Texture oxidizedCopperGrate = new Texture();
+ @TexturePath("assets/minecraft/textures/block/oxidized_copper_bulb")
+ public static final Texture oxidizedCopperBulb = new Texture();
+ @TexturePath("assets/minecraft/textures/block/oxidized_copper_bulb_lit")
+ public static final Texture oxidizedCopperBulbLit = new Texture();
+ @TexturePath("assets/minecraft/textures/block/oxidized_copper_bulb_powered")
+ public static final Texture oxidizedCopperBulbPowered = new Texture();
+ @TexturePath("assets/minecraft/textures/block/oxidized_copper_bulb_lit_powered")
+ public static final Texture oxidizedCopperBulbLitPowered = new Texture();
+ @TexturePath("assets/minecraft/textures/block/oxidized_copper_door_top")
+ public static final Texture oxidizedCopperDoorTop = new Texture();
+ @TexturePath("assets/minecraft/textures/block/oxidized_copper_door_bottom")
+ public static final Texture oxidizedCopperDoorBottom = new Texture();
+ @TexturePath("assets/minecraft/textures/block/oxidized_copper_trapdoor")
+ public static final Texture oxidizedCopperTrapdoor = new Texture();
+ @TexturePath("assets/minecraft/textures/block/crafter_north")
+ public static final Texture crafterNorth = new Texture();
+ @TexturePath("assets/minecraft/textures/block/crafter_north_crafting")
+ public static final Texture crafterNorthCrafting = new Texture();
+ @TexturePath("assets/minecraft/textures/block/crafter_east")
+ public static final Texture crafterEast = new Texture();
+ @TexturePath("assets/minecraft/textures/block/crafter_east_crafting")
+ public static final Texture crafterEastCrafting = new Texture();
+ @TexturePath("assets/minecraft/textures/block/crafter_east_triggered")
+ public static final Texture crafterEastTriggered = new Texture();
+ @TexturePath("assets/minecraft/textures/block/crafter_south")
+ public static final Texture crafterSouth = new Texture();
+ @TexturePath("assets/minecraft/textures/block/crafter_south_triggered")
+ public static final Texture crafterSouthTriggered = new Texture();
+ @TexturePath("assets/minecraft/textures/block/crafter_west")
+ public static final Texture crafterWest = new Texture();
+ @TexturePath("assets/minecraft/textures/block/crafter_west_crafting")
+ public static final Texture crafterWestCrafting = new Texture();
+ @TexturePath("assets/minecraft/textures/block/crafter_west_triggered")
+ public static final Texture crafterWestTriggered = new Texture();
+ @TexturePath("assets/minecraft/textures/block/crafter_top")
+ public static final Texture crafterTop = new Texture();
+ @TexturePath("assets/minecraft/textures/block/crafter_top_crafting")
+ public static final Texture crafterTopCrafting = new Texture();
+ @TexturePath("assets/minecraft/textures/block/crafter_top_triggered")
+ public static final Texture crafterTopTriggered = new Texture();
+ @TexturePath("assets/minecraft/textures/block/crafter_bottom")
+ public static final Texture crafterBottom = new Texture();
/** Banner base texture. */
public static final Texture bannerBase = new Texture();