Added fireresistantce to ruby/cincinnasite armor and ruby blocks (#paulevsGitch/BetterNether/issues/531)
This commit is contained in:
parent
97d2e6d146
commit
819039d50d
4 changed files with 37 additions and 32 deletions
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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));
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue