Added fireresistantce to ruby/cincinnasite armor and ruby blocks (#paulevsGitch/BetterNether/issues/531)

This commit is contained in:
Frank 2022-04-28 20:25:22 +02:00
parent 97d2e6d146
commit 819039d50d
4 changed files with 37 additions and 32 deletions

View file

@ -11,7 +11,7 @@ loader_version= 0.13.3
fabric_version = 0.48.0+1.18.2 fabric_version = 0.48.0+1.18.2
# Mod Properties # Mod Properties
mod_version = 1.4.4 mod_version = 1.4.5
maven_group = ru.bclib maven_group = ru.bclib
archives_base_name = bclib archives_base_name = bclib

View file

@ -27,10 +27,16 @@ import java.util.Optional;
public class BaseSlabBlock extends SlabBlock implements BlockModelProvider { public class BaseSlabBlock extends SlabBlock implements BlockModelProvider {
private final Block parent; private final Block parent;
public final boolean fireproof;
public BaseSlabBlock(Block source) { public BaseSlabBlock(Block source) {
this(source, false);
}
public BaseSlabBlock(Block source, boolean fireproof) {
super(FabricBlockSettings.copyOf(source)); super(FabricBlockSettings.copyOf(source));
this.parent = source; this.parent = source;
this.fireproof = fireproof;
} }
@Override @Override

View file

@ -2,12 +2,14 @@ package ru.bclib.blocks;
import net.fabricmc.api.EnvType; import net.fabricmc.api.EnvType;
import net.fabricmc.api.Environment; import net.fabricmc.api.Environment;
import net.fabricmc.fabric.api.item.v1.FabricItemSettings;
import net.fabricmc.fabric.api.object.builder.v1.block.FabricBlockSettings; import net.fabricmc.fabric.api.object.builder.v1.block.FabricBlockSettings;
import net.minecraft.client.renderer.block.model.BlockModel; import net.minecraft.client.renderer.block.model.BlockModel;
import net.minecraft.client.resources.model.BlockModelRotation; import net.minecraft.client.resources.model.BlockModelRotation;
import net.minecraft.client.resources.model.UnbakedModel; import net.minecraft.client.resources.model.UnbakedModel;
import net.minecraft.core.Registry; import net.minecraft.core.Registry;
import net.minecraft.resources.ResourceLocation; import net.minecraft.resources.ResourceLocation;
import net.minecraft.world.item.BlockItem;
import net.minecraft.world.item.ItemStack; import net.minecraft.world.item.ItemStack;
import net.minecraft.world.level.block.Block; import net.minecraft.world.level.block.Block;
import net.minecraft.world.level.block.StairBlock; import net.minecraft.world.level.block.StairBlock;
@ -20,18 +22,25 @@ import ru.bclib.client.models.BasePatterns;
import ru.bclib.client.models.ModelsHelper; import ru.bclib.client.models.ModelsHelper;
import ru.bclib.client.models.PatternsHelper; import ru.bclib.client.models.PatternsHelper;
import ru.bclib.interfaces.BlockModelProvider; import ru.bclib.interfaces.BlockModelProvider;
import ru.bclib.interfaces.CustomItemProvider;
import java.util.Collections; import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Optional; import java.util.Optional;
public class BaseStairsBlock extends StairBlock implements BlockModelProvider { public class BaseStairsBlock extends StairBlock implements BlockModelProvider, CustomItemProvider {
private final Block parent; private final Block parent;
public final boolean fireproof;
public BaseStairsBlock(Block source) { public BaseStairsBlock(Block source) {
this(source, false);
}
public BaseStairsBlock(Block source, boolean fireproof) {
super(source.defaultBlockState(), FabricBlockSettings.copyOf(source)); super(source.defaultBlockState(), FabricBlockSettings.copyOf(source));
this.parent = source; this.parent = source;
this.fireproof = fireproof;
} }
@Override @Override
@ -50,20 +59,11 @@ public class BaseStairsBlock extends StairBlock implements BlockModelProvider {
@Environment(EnvType.CLIENT) @Environment(EnvType.CLIENT)
public @Nullable BlockModel getBlockModel(ResourceLocation blockId, BlockState blockState) { public @Nullable BlockModel getBlockModel(ResourceLocation blockId, BlockState blockState) {
ResourceLocation parentId = Registry.BLOCK.getKey(parent); ResourceLocation parentId = Registry.BLOCK.getKey(parent);
Optional<String> pattern = Optional.empty(); Optional<String> pattern = PatternsHelper.createJson(switch (blockState.getValue(SHAPE)) {
switch (blockState.getValue(SHAPE)) { case STRAIGHT -> BasePatterns.BLOCK_STAIR;
case STRAIGHT: case INNER_LEFT, INNER_RIGHT -> BasePatterns.BLOCK_STAIR_INNER;
pattern = PatternsHelper.createJson(BasePatterns.BLOCK_STAIR, parentId); case OUTER_LEFT, OUTER_RIGHT -> BasePatterns.BLOCK_STAIR_OUTER;
break; }, parentId);
case INNER_LEFT:
case INNER_RIGHT:
pattern = PatternsHelper.createJson(BasePatterns.BLOCK_STAIR_INNER, parentId);
break;
case OUTER_LEFT:
case OUTER_RIGHT:
pattern = PatternsHelper.createJson(BasePatterns.BLOCK_STAIR_OUTER, parentId);
break;
}
return ModelsHelper.fromPattern(pattern); return ModelsHelper.fromPattern(pattern);
} }
@ -72,18 +72,11 @@ public class BaseStairsBlock extends StairBlock implements BlockModelProvider {
public UnbakedModel getModelVariant(ResourceLocation stateId, BlockState blockState, Map<ResourceLocation, UnbakedModel> modelCache) { public UnbakedModel getModelVariant(ResourceLocation stateId, BlockState blockState, Map<ResourceLocation, UnbakedModel> modelCache) {
String state; String state;
StairsShape shape = blockState.getValue(SHAPE); StairsShape shape = blockState.getValue(SHAPE);
switch (shape) { state = switch (shape) {
case INNER_LEFT: case INNER_LEFT, INNER_RIGHT -> "_inner";
case INNER_RIGHT: case OUTER_LEFT, OUTER_RIGHT -> "_outer";
state = "_inner"; default -> "";
break; };
case OUTER_LEFT:
case OUTER_RIGHT:
state = "_outer";
break;
default:
state = "";
}
ResourceLocation modelId = new ResourceLocation(stateId.getNamespace(), "block/" + stateId.getPath() + state); ResourceLocation modelId = new ResourceLocation(stateId.getNamespace(), "block/" + stateId.getPath() + state);
registerBlockModel(stateId, modelId, blockState, modelCache); registerBlockModel(stateId, modelId, blockState, modelCache);
@ -113,4 +106,10 @@ public class BaseStairsBlock extends StairBlock implements BlockModelProvider {
BlockModelRotation rotation = BlockModelRotation.by(x, y); BlockModelRotation rotation = BlockModelRotation.by(x, y);
return ModelsHelper.createMultiVariant(modelId, rotation.getRotation(), true); return ModelsHelper.createMultiVariant(modelId, rotation.getRotation(), true);
} }
@Override
public BlockItem getCustomItem(ResourceLocation blockID, FabricItemSettings settings) {
if (fireproof) settings = settings.fireproof();
return new BlockItem(this, settings);
}
} }

View file

@ -128,11 +128,11 @@ public class WoodenComplexMaterial extends ComplexMaterial {
.setBlockTags(NamedBlockTags.PLANKS) .setBlockTags(NamedBlockTags.PLANKS)
.setItemTags(NamedItemTags.PLANKS)); .setItemTags(NamedItemTags.PLANKS));
addBlockEntry(new BlockEntry(BLOCK_STAIRS, (complexMaterial, settings) -> new BaseStairsBlock(getBlock(BLOCK_PLANKS))) addBlockEntry(new BlockEntry(BLOCK_STAIRS, (complexMaterial, settings) -> new BaseStairsBlock(getBlock(BLOCK_PLANKS), false))
.setBlockTags(NamedBlockTags.WOODEN_STAIRS, NamedBlockTags.STAIRS) .setBlockTags(NamedBlockTags.WOODEN_STAIRS, NamedBlockTags.STAIRS)
.setItemTags(NamedItemTags.WOODEN_STAIRS, NamedItemTags.STAIRS)); .setItemTags(NamedItemTags.WOODEN_STAIRS, NamedItemTags.STAIRS));
addBlockEntry(new BlockEntry(BLOCK_SLAB, (complexMaterial, settings) -> new BaseSlabBlock(getBlock(BLOCK_PLANKS))) addBlockEntry(new BlockEntry(BLOCK_SLAB, (complexMaterial, settings) -> new BaseSlabBlock(getBlock(BLOCK_PLANKS), false))
.setBlockTags(NamedBlockTags.WOODEN_SLABS, NamedBlockTags.SLABS) .setBlockTags(NamedBlockTags.WOODEN_SLABS, NamedBlockTags.SLABS)
.setItemTags(NamedItemTags.WOODEN_SLABS, NamedItemTags.SLABS)); .setItemTags(NamedItemTags.WOODEN_SLABS, NamedItemTags.SLABS));