Door and Sapling patterns

This commit is contained in:
Aleksey 2020-10-14 09:58:05 +03:00
parent 04f4b5576f
commit c955d3032e
11 changed files with 249 additions and 14 deletions

View file

@ -1,5 +1,6 @@
package ru.betterend.blocks.basis;
import java.io.Reader;
import java.util.Collections;
import java.util.List;
@ -10,10 +11,13 @@ import net.minecraft.block.DoorBlock;
import net.minecraft.block.enums.DoubleBlockHalf;
import net.minecraft.item.ItemStack;
import net.minecraft.loot.context.LootContext;
import net.minecraft.util.Identifier;
import net.minecraft.util.registry.Registry;
import ru.betterend.client.ERenderLayer;
import ru.betterend.client.IRenderTypeable;
import ru.betterend.client.IRenderTypeable;
import ru.betterend.interfaces.Patterned;
public class BlockDoor extends DoorBlock implements IRenderTypeable {
public class BlockDoor extends DoorBlock implements IRenderTypeable, Patterned {
public BlockDoor(Block block) {
super(FabricBlockSettings.copy(block).nonOpaque());
}
@ -30,4 +34,33 @@ public class BlockDoor extends DoorBlock implements IRenderTypeable {
public ERenderLayer getRenderLayer() {
return ERenderLayer.CUTOUT;
}
@Override
public String getStatesPattern(Reader data, String block) {
Identifier blockId = Registry.BLOCK.getId(this);
return Patterned.createJson(data, blockId, block);
}
@Override
public String getModelPattern(String block) {
Identifier blockId = Registry.BLOCK.getId(this);
if (block.contains("item")) {
block = block.split("/")[1];
return Patterned.createJson(Patterned.ITEM_MODEL, block);
}
if (block.contains("top_hinge")) {
return Patterned.createJson(Patterned.DOOR_MODEL_TOP_HINGE, blockId, block);
}
if (block.contains("bottom_hinge")) {
return Patterned.createJson(Patterned.DOOR_MODEL_BOTTOM_HINGE, blockId, block);
}
if (block.contains("top")) {
return Patterned.createJson(Patterned.DOOR_MODEL_TOP, blockId, block);
}
return Patterned.createJson(Patterned.DOOR_MODEL_BOTTOM, blockId, block);
}
public Identifier statePatternId() {
return Patterned.DOOR_STATES_PATTERN;
}
}