4.0.0 - First commit to github

This commit is contained in:
Motschen
2020-12-08 16:34:11 +01:00
parent bc27d95a6a
commit 6829761ab7
143 changed files with 2012 additions and 769 deletions

5
.gitignore vendored
View File

@@ -1,6 +1,11 @@
# gradle # gradle
.gradle/ .gradle/
build/classes/
build/generated/
build/libs/
build/resources/
build/tmp/
out/ out/
classes/ classes/

View File

@@ -1,5 +1,5 @@
plugins { plugins {
id 'fabric-loom' version '0.4-SNAPSHOT' id 'fabric-loom' version '0.5-SNAPSHOT'
id 'maven-publish' id 'maven-publish'
} }
@@ -14,6 +14,7 @@ minecraft {
} }
repositories { repositories {
maven { url = 'https://raw.githubusercontent.com/Devan-Kerman/Devan-Repo/master/'}
maven { url "https://jitpack.io" } maven { url "https://jitpack.io" }
maven { url "https://maven.blamejared.com" } maven { url "https://maven.blamejared.com" }
} }
@@ -28,8 +29,10 @@ dependencies {
modCompile "net.fabricmc.fabric-api:fabric-api:${project.fabric_version}" modCompile "net.fabricmc.fabric-api:fabric-api:${project.fabric_version}"
modCompile("vazkii.patchouli:Patchouli:${project.patchouli_version}") modCompile("vazkii.patchouli:Patchouli:${project.patchouli_version}")
// PSA: Some older mods, compiled on Loom 0.2.1, might have outdated Maven POMs.
// You may need to force-disable transitiveness on them. modImplementation ("me.sargunvohra.mcmods:autoconfig1u:${project.auto_config_version}")
modImplementation ("me.shedaniel.cloth:config-2:${project.cloth_config_version}")
modImplementation ("io.github.prospector:modmenu:${project.mod_menu_version}")
modImplementation "eu.midnightdust:midnight-hats:${midnighthats_version}" modImplementation "eu.midnightdust:midnight-hats:${midnighthats_version}"
include "eu.midnightdust:midnight-hats:${midnighthats_version}" include "eu.midnightdust:midnight-hats:${midnighthats_version}"

Binary file not shown.

View File

@@ -0,0 +1 @@
v1 named intermediary

View File

@@ -1,19 +1,23 @@
# Done to increase the memory available to gradle. # Done to increase the memory available to gradle.
org.gradle.jvmargs=-Xmx1G org.gradle.jvmargs=-Xmx2G
# Fabric Properties # Fabric Properties
# check these on https://fabricmc.net/use # check these on https://fabricmc.net/use
minecraft_version=1.16.2 minecraft_version=1.16.4
yarn_mappings=1.16.2+build.6 yarn_mappings=1.16.4+build.6
loader_version=0.9.1+build.205 loader_version=0.10.6+build.214
# Mod Properties # Mod Properties
mod_version = 3.0.0 mod_version = 4.0.0-dev
maven_group = eu.midnightdust.motschen maven_group = eu.midnightdust.motschen
archives_base_name = decorative archives_base_name = decorative
# Dependencies # Dependencies
# currently not on the main fabric site, check on the maven: https://maven.fabricmc.net/net/fabricmc/fabric-api/fabric-api # currently not on the main fabric site, check on the maven: https://maven.fabricmc.net/net/fabricmc/fabric-api/fabric-api
fabric_version=0.17.2+build.396-1.16 fabric_version=0.25.1+build.416-1.16
patchouli_version=1.16-40-FABRIC patchouli_version=1.16-40-FABRIC
midnighthats_version=1.0.2 midnighthats_version=2.0.1
auto_config_version = 3.2.0-unstable
cloth_config_version = 4.7.0-unstable
mod_menu_version = 1.14.6+build.31

View File

@@ -8,6 +8,7 @@ import eu.midnightdust.motschen.decorative.init.Pool;
import eu.midnightdust.motschen.decorative.init.Signs; import eu.midnightdust.motschen.decorative.init.Signs;
import net.fabricmc.api.ClientModInitializer; import net.fabricmc.api.ClientModInitializer;
import net.fabricmc.fabric.api.blockrenderlayer.v1.BlockRenderLayerMap; import net.fabricmc.fabric.api.blockrenderlayer.v1.BlockRenderLayerMap;
import net.fabricmc.fabric.api.client.model.ModelLoadingRegistry;
import net.fabricmc.fabric.api.client.rendereregistry.v1.BlockEntityRendererRegistry; import net.fabricmc.fabric.api.client.rendereregistry.v1.BlockEntityRendererRegistry;
import net.fabricmc.fabric.api.client.rendereregistry.v1.EntityRendererRegistry; import net.fabricmc.fabric.api.client.rendereregistry.v1.EntityRendererRegistry;
import net.fabricmc.fabric.api.client.rendering.v1.ColorProviderRegistry; import net.fabricmc.fabric.api.client.rendering.v1.ColorProviderRegistry;
@@ -15,6 +16,10 @@ import net.minecraft.block.Block;
import net.minecraft.block.Blocks; import net.minecraft.block.Blocks;
import net.minecraft.client.color.block.BlockColorProvider; import net.minecraft.client.color.block.BlockColorProvider;
import net.minecraft.client.render.RenderLayer; import net.minecraft.client.render.RenderLayer;
import net.minecraft.client.render.model.UnbakedModel;
import net.minecraft.command.argument.ItemEnchantmentArgumentType;
import java.util.function.Supplier;
public class DecorativeClient implements ClientModInitializer { public class DecorativeClient implements ClientModInitializer {
@@ -64,17 +69,15 @@ public class DecorativeClient implements ClientModInitializer {
BlockRenderLayerMap.INSTANCE.putBlocks(RenderLayer.getCutout(),DecorativeMain.ChristmasTree); BlockRenderLayerMap.INSTANCE.putBlocks(RenderLayer.getCutout(),DecorativeMain.ChristmasTree);
BlockRenderLayerMap.INSTANCE.putBlocks(RenderLayer.getCutout(),DecorativeMain.CeilingFan); BlockRenderLayerMap.INSTANCE.putBlocks(RenderLayer.getCutout(),DecorativeMain.CeilingFan);
BlockRenderLayerMap.INSTANCE.putBlocks(RenderLayer.getCutout(),DecorativeMain.SlidingDoor); BlockRenderLayerMap.INSTANCE.putBlocks(RenderLayer.getCutout(),DecorativeMain.SlidingDoor);
BlockRenderLayerMap.INSTANCE.putBlocks(RenderLayer.getCutout(),DecorativeMain.WallClock);
BlockRenderLayerMap.INSTANCE.putBlocks(RenderLayer.getTranslucent(),DecorativeMain.BirdBath); BlockRenderLayerMap.INSTANCE.putBlocks(RenderLayer.getTranslucent(),DecorativeMain.BirdBath);
BlockEntityRendererRegistry.INSTANCE.register(BlockEntities.CeilingFanBlockEntity, CeilingFanRenderer::new); BlockEntityRendererRegistry.INSTANCE.register(BlockEntities.CeilingFanBlockEntity, CeilingFanRenderer::new);
BlockEntityRendererRegistry.INSTANCE.register(BlockEntities.OakChoppingLogBlockEntity, OakChoppingLogBlockEntityRenderer::new); BlockEntityRendererRegistry.INSTANCE.register(BlockEntities.ChoppingLogBlockEntity, ChoppingLogBlockEntityRenderer::new);
BlockEntityRendererRegistry.INSTANCE.register(BlockEntities.SpruceChoppingLogBlockEntity, SpruceChoppingLogBlockEntityRenderer::new);
BlockEntityRendererRegistry.INSTANCE.register(BlockEntities.BirchChoppingLogBlockEntity, BirchChoppingLogBlockEntityRenderer::new);
BlockEntityRendererRegistry.INSTANCE.register(BlockEntities.AcaciaChoppingLogBlockEntity, AcaciaChoppingLogBlockEntityRenderer::new);
BlockEntityRendererRegistry.INSTANCE.register(BlockEntities.JungleChoppingLogBlockEntity, JungleChoppingLogBlockEntityRenderer::new);
BlockEntityRendererRegistry.INSTANCE.register(BlockEntities.DarkOakChoppingLogBlockEntity, DarkOakChoppingLogBlockEntityRenderer::new);
BlockEntityRendererRegistry.INSTANCE.register(BlockEntities.WallClockBlockEntity, WallClockRenderer::new);
BlockEntityRendererRegistry.INSTANCE.register(BlockEntities.DigitalClockBlockEntity, DigitalClockRenderer::new);
} }
public void registerBlockColor(Block block, Block templateBlock) { public void registerBlockColor(Block block, Block templateBlock) {
ColorProviderRegistry.BLOCK.register((type, pos, world, layer) -> { ColorProviderRegistry.BLOCK.register((type, pos, world, layer) -> {

View File

@@ -5,9 +5,13 @@ import eu.midnightdust.motschen.decorative.blockstates.CeilingFanStage;
import eu.midnightdust.motschen.decorative.blockstates.Part; import eu.midnightdust.motschen.decorative.blockstates.Part;
import eu.midnightdust.motschen.decorative.blockstates.PoolShape; import eu.midnightdust.motschen.decorative.blockstates.PoolShape;
import eu.midnightdust.motschen.decorative.blockstates.Program; import eu.midnightdust.motschen.decorative.blockstates.Program;
import eu.midnightdust.motschen.decorative.config.DecorativeConfig;
import eu.midnightdust.motschen.decorative.init.*; import eu.midnightdust.motschen.decorative.init.*;
import eu.midnightdust.motschen.decorative.sound.DecorativeSoundEvents;
import eu.midnightdust.motschen.decorative.world.OreFeatureInjector; import eu.midnightdust.motschen.decorative.world.OreFeatureInjector;
import eu.midnightdust.motschen.decorative.world.OreFeatures; import eu.midnightdust.motschen.decorative.world.OreFeatures;
import me.sargunvohra.mcmods.autoconfig1u.AutoConfig;
import me.sargunvohra.mcmods.autoconfig1u.serializer.JanksonConfigSerializer;
import net.fabricmc.api.ModInitializer; import net.fabricmc.api.ModInitializer;
import net.fabricmc.fabric.api.client.itemgroup.FabricItemGroupBuilder; import net.fabricmc.fabric.api.client.itemgroup.FabricItemGroupBuilder;
import net.fabricmc.fabric.api.object.builder.v1.block.FabricBlockSettings; import net.fabricmc.fabric.api.object.builder.v1.block.FabricBlockSettings;
@@ -20,6 +24,7 @@ import net.minecraft.util.registry.Registry;
public class DecorativeMain implements ModInitializer { public class DecorativeMain implements ModInitializer {
public static final String MOD_ID = "decorative"; public static final String MOD_ID = "decorative";
public static DecorativeConfig DECORATIVE_CONFIG;
public static final ItemGroup IndoorGroup = FabricItemGroupBuilder.build(new Identifier(MOD_ID, "indoor"), () -> new ItemStack(DecorativeMain.Television)); public static final ItemGroup IndoorGroup = FabricItemGroupBuilder.build(new Identifier(MOD_ID, "indoor"), () -> new ItemStack(DecorativeMain.Television));
public static final ItemGroup TrafficGroup = FabricItemGroupBuilder.build(new Identifier(MOD_ID, "traffic"), () -> new ItemStack(DecorativeMain.TrafficCone)); public static final ItemGroup TrafficGroup = FabricItemGroupBuilder.build(new Identifier(MOD_ID, "traffic"), () -> new ItemStack(DecorativeMain.TrafficCone));
@@ -47,9 +52,14 @@ public class DecorativeMain implements ModInitializer {
public static Block ChristmasTree = new ChristmasTree(); public static Block ChristmasTree = new ChristmasTree();
public static Block ChristmasLights = new ChristmasLights(); public static Block ChristmasLights = new ChristmasLights();
public static Block ShowerHead = new ShowerHead(); public static Block ShowerHead = new ShowerHead();
public static Block WallClock = new WallClock();
public static Block SmokeDetector = new SmokeDetector();
@Override @Override
public void onInitialize() { public void onInitialize() {
AutoConfig.register(DecorativeConfig.class, JanksonConfigSerializer::new);
DECORATIVE_CONFIG = AutoConfig.getConfigHolder(DecorativeConfig.class).getConfig();
BlockEntities.init(); BlockEntities.init();
// Traffic // // Traffic //
Registry.register(Registry.BLOCK, new Identifier(MOD_ID,"rocky_asphalt"), RockyAsphalt); Registry.register(Registry.BLOCK, new Identifier(MOD_ID,"rocky_asphalt"), RockyAsphalt);
@@ -81,6 +91,8 @@ public class DecorativeMain implements ModInitializer {
//Furniture// //Furniture//
Registry.register(Registry.BLOCK, new Identifier(MOD_ID,"kitchen_tiles"), KitchenTiles); Registry.register(Registry.BLOCK, new Identifier(MOD_ID,"kitchen_tiles"), KitchenTiles);
Registry.register(Registry.ITEM, new Identifier(MOD_ID,"kitchen_tiles"), new BlockItem(KitchenTiles, new Item.Settings().group(DecorativeMain.IndoorGroup))); Registry.register(Registry.ITEM, new Identifier(MOD_ID,"kitchen_tiles"), new BlockItem(KitchenTiles, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Registry.register(Registry.BLOCK, new Identifier(MOD_ID,"wall_clock"), WallClock);
Registry.register(Registry.ITEM, new Identifier(MOD_ID,"wall_clock"), new BlockItem(WallClock, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Registry.register(Registry.BLOCK, new Identifier(MOD_ID,"television"), Television); Registry.register(Registry.BLOCK, new Identifier(MOD_ID,"television"), Television);
Registry.register(Registry.ITEM, new Identifier(MOD_ID,"television"), new BlockItem(Television, new Item.Settings().group(DecorativeMain.IndoorGroup))); Registry.register(Registry.ITEM, new Identifier(MOD_ID,"television"), new BlockItem(Television, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Registry.register(Registry.BLOCK, new Identifier(MOD_ID,"old_television"), OldTelevision); Registry.register(Registry.BLOCK, new Identifier(MOD_ID,"old_television"), OldTelevision);
@@ -95,10 +107,14 @@ public class DecorativeMain implements ModInitializer {
Registry.register(Registry.ITEM, new Identifier(MOD_ID,"christmas_tree"), new BlockItem(ChristmasTree, new Item.Settings().group(DecorativeMain.IndoorGroup))); Registry.register(Registry.ITEM, new Identifier(MOD_ID,"christmas_tree"), new BlockItem(ChristmasTree, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Registry.register(Registry.BLOCK, new Identifier(MOD_ID,"christmas_lights"), ChristmasLights); Registry.register(Registry.BLOCK, new Identifier(MOD_ID,"christmas_lights"), ChristmasLights);
Registry.register(Registry.ITEM, new Identifier(MOD_ID,"christmas_lights"), new BlockItem(ChristmasLights, new Item.Settings().group(DecorativeMain.IndoorGroup))); Registry.register(Registry.ITEM, new Identifier(MOD_ID,"christmas_lights"), new BlockItem(ChristmasLights, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Registry.register(Registry.BLOCK, new Identifier(MOD_ID,"smoke_detector"), SmokeDetector);
Registry.register(Registry.ITEM, new Identifier(MOD_ID,"smoke_detector"), new BlockItem(SmokeDetector, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Lamps.init(); Lamps.init();
DoubleLamps.init(); DoubleLamps.init();
Clocks.init();
OreFeatures.init(); OreFeatures.init();
OreFeatureInjector.init(); OreFeatureInjector.init();
new DecorativeSoundEvents();
} }
} }

View File

@@ -1,42 +0,0 @@
package eu.midnightdust.motschen.decorative.block;
import eu.midnightdust.motschen.decorative.block.blockentity.AcaciaChoppingLogBlockEntity;
import net.fabricmc.fabric.api.object.builder.v1.block.FabricBlockSettings;
import net.minecraft.block.*;
import net.minecraft.block.entity.BlockEntity;
import net.minecraft.item.ItemPlacementContext;
import net.minecraft.sound.BlockSoundGroup;
import net.minecraft.state.StateManager;
import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.Direction;
import net.minecraft.world.BlockView;
import net.minecraft.world.WorldView;
public class AcaciaChoppingLog extends HorizontalFacingBlock implements BlockEntityProvider {
public AcaciaChoppingLog() {
super(FabricBlockSettings.copy(Blocks.OAK_PLANKS).nonOpaque().sounds(BlockSoundGroup.WOOD));
this.setDefaultState(this.stateManager.getDefaultState().with(FACING, Direction.NORTH));
}
@Override
public BlockState getPlacementState(ItemPlacementContext itemPlacementContext) {
return super.getPlacementState(itemPlacementContext)
.with(FACING, itemPlacementContext.getPlayerFacing().getOpposite());
}
@Override
protected void appendProperties(StateManager.Builder<Block, BlockState> builder) {
builder.add(FACING);
}
public boolean canPlaceAt(BlockState state, WorldView worldView, BlockPos pos) {
return !worldView.isAir(pos.down());
}
@Override
public BlockEntity createBlockEntity(BlockView view) {
return new AcaciaChoppingLogBlockEntity();
}
}

View File

@@ -1,42 +0,0 @@
package eu.midnightdust.motschen.decorative.block;
import eu.midnightdust.motschen.decorative.block.blockentity.BirchChoppingLogBlockEntity;
import net.fabricmc.fabric.api.object.builder.v1.block.FabricBlockSettings;
import net.minecraft.block.*;
import net.minecraft.block.entity.BlockEntity;
import net.minecraft.item.ItemPlacementContext;
import net.minecraft.sound.BlockSoundGroup;
import net.minecraft.state.StateManager;
import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.Direction;
import net.minecraft.world.BlockView;
import net.minecraft.world.WorldView;
public class BirchChoppingLog extends HorizontalFacingBlock implements BlockEntityProvider {
public BirchChoppingLog() {
super(FabricBlockSettings.copy(Blocks.OAK_PLANKS).nonOpaque().sounds(BlockSoundGroup.WOOD));
this.setDefaultState(this.stateManager.getDefaultState().with(FACING, Direction.NORTH));
}
@Override
public BlockState getPlacementState(ItemPlacementContext itemPlacementContext) {
return super.getPlacementState(itemPlacementContext)
.with(FACING, itemPlacementContext.getPlayerFacing().getOpposite());
}
@Override
protected void appendProperties(StateManager.Builder<Block, BlockState> builder) {
builder.add(FACING);
}
public boolean canPlaceAt(BlockState state, WorldView worldView, BlockPos pos) {
return !worldView.isAir(pos.down());
}
@Override
public BlockEntity createBlockEntity(BlockView view) {
return new BirchChoppingLogBlockEntity();
}
}

View File

@@ -1,6 +1,6 @@
package eu.midnightdust.motschen.decorative.block; package eu.midnightdust.motschen.decorative.block;
import eu.midnightdust.motschen.decorative.block.blockentity.OakChoppingLogBlockEntity; import eu.midnightdust.motschen.decorative.block.blockentity.ChoppingLogBlockEntity;
import net.fabricmc.fabric.api.object.builder.v1.block.FabricBlockSettings; import net.fabricmc.fabric.api.object.builder.v1.block.FabricBlockSettings;
import net.minecraft.block.*; import net.minecraft.block.*;
import net.minecraft.block.entity.BlockEntity; import net.minecraft.block.entity.BlockEntity;
@@ -12,9 +12,9 @@ import net.minecraft.util.math.Direction;
import net.minecraft.world.BlockView; import net.minecraft.world.BlockView;
import net.minecraft.world.WorldView; import net.minecraft.world.WorldView;
public class OakChoppingLog extends HorizontalFacingBlock implements BlockEntityProvider { public class ChoppingLog extends HorizontalFacingBlock implements BlockEntityProvider {
public OakChoppingLog() { public ChoppingLog() {
super(FabricBlockSettings.copy(Blocks.OAK_PLANKS).nonOpaque().sounds(BlockSoundGroup.WOOD)); super(FabricBlockSettings.copy(Blocks.OAK_PLANKS).nonOpaque().sounds(BlockSoundGroup.WOOD));
this.setDefaultState(this.stateManager.getDefaultState().with(FACING, Direction.NORTH)); this.setDefaultState(this.stateManager.getDefaultState().with(FACING, Direction.NORTH));
} }
@@ -36,7 +36,7 @@ public class OakChoppingLog extends HorizontalFacingBlock implements BlockEntity
@Override @Override
public BlockEntity createBlockEntity(BlockView view) { public BlockEntity createBlockEntity(BlockView view) {
return new OakChoppingLogBlockEntity(); return new ChoppingLogBlockEntity();
} }
} }

View File

@@ -1,42 +0,0 @@
package eu.midnightdust.motschen.decorative.block;
import eu.midnightdust.motschen.decorative.block.blockentity.DarkOakChoppingLogBlockEntity;
import net.fabricmc.fabric.api.object.builder.v1.block.FabricBlockSettings;
import net.minecraft.block.*;
import net.minecraft.block.entity.BlockEntity;
import net.minecraft.item.ItemPlacementContext;
import net.minecraft.sound.BlockSoundGroup;
import net.minecraft.state.StateManager;
import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.Direction;
import net.minecraft.world.BlockView;
import net.minecraft.world.WorldView;
public class DarkOakChoppingLog extends HorizontalFacingBlock implements BlockEntityProvider {
public DarkOakChoppingLog() {
super(FabricBlockSettings.copy(Blocks.OAK_PLANKS).nonOpaque().sounds(BlockSoundGroup.WOOD));
this.setDefaultState(this.stateManager.getDefaultState().with(FACING, Direction.NORTH));
}
@Override
public BlockState getPlacementState(ItemPlacementContext itemPlacementContext) {
return super.getPlacementState(itemPlacementContext)
.with(FACING, itemPlacementContext.getPlayerFacing().getOpposite());
}
@Override
protected void appendProperties(StateManager.Builder<Block, BlockState> builder) {
builder.add(FACING);
}
public boolean canPlaceAt(BlockState state, WorldView worldView, BlockPos pos) {
return !worldView.isAir(pos.down());
}
@Override
public BlockEntity createBlockEntity(BlockView view) {
return new DarkOakChoppingLogBlockEntity();
}
}

View File

@@ -0,0 +1,74 @@
package eu.midnightdust.motschen.decorative.block;
import eu.midnightdust.motschen.decorative.block.blockentity.DigitalClockBlockEntity;
import eu.midnightdust.motschen.decorative.block.blockentity.WallClockBlockEntity;
import net.fabricmc.fabric.api.object.builder.v1.block.FabricBlockSettings;
import net.minecraft.block.*;
import net.minecraft.block.entity.BlockEntity;
import net.minecraft.item.ItemPlacementContext;
import net.minecraft.sound.BlockSoundGroup;
import net.minecraft.state.StateManager;
import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.Direction;
import net.minecraft.util.shape.VoxelShape;
import net.minecraft.util.shape.VoxelShapes;
import net.minecraft.world.BlockView;
public class DigitalClock extends HorizontalFacingBlock implements BlockEntityProvider {
private static final VoxelShape NORTH_SHAPE;
private static final VoxelShape EAST_SHAPE;
private static final VoxelShape SOUTH_SHAPE;
private static final VoxelShape WEST_SHAPE;
public DigitalClock() {
super(FabricBlockSettings.copy(Blocks.SMOOTH_QUARTZ).nonOpaque().sounds(BlockSoundGroup.STONE));
this.setDefaultState(this.stateManager.getDefaultState().with(FACING, Direction.NORTH));
}
@Override
public BlockEntity createBlockEntity(BlockView view) {
return new DigitalClockBlockEntity();
}
@Override
protected void appendProperties(StateManager.Builder<Block, BlockState> builder) {
builder.add(FACING);
}
@Override
public BlockState getPlacementState(ItemPlacementContext itemPlacementContext) {
return super.getPlacementState(itemPlacementContext)
.with(FACING, itemPlacementContext.getPlayerFacing().getOpposite());
}
@Override
public VoxelShape getOutlineShape(BlockState state, BlockView view, BlockPos pos, ShapeContext context) {
switch (state.get(FACING)) {
case NORTH: return NORTH_SHAPE;
case EAST: return EAST_SHAPE;
case SOUTH: return SOUTH_SHAPE;
case WEST: return WEST_SHAPE;
default: return super.getOutlineShape(state, view, pos, context);
}
}
static {
VoxelShape shape = createCuboidShape(1, 0, 5, 15, 8, 13);
NORTH_SHAPE = shape;
WEST_SHAPE = rotate(Direction.EAST, Direction.NORTH, shape);
EAST_SHAPE = rotate(Direction.EAST, Direction.SOUTH, shape);
SOUTH_SHAPE = rotate(Direction.EAST, Direction.WEST, shape);
}
private static VoxelShape rotate(Direction from, Direction to, VoxelShape shape) {
VoxelShape[] buffer = new VoxelShape[]{ shape, VoxelShapes.empty() };
int times = (to.getHorizontal() - from.getHorizontal() + 4) % 4;
for (int i = 0; i < times; i++) {
buffer[0].forEachBox((minX, minY, minZ, maxX, maxY, maxZ) -> buffer[1] = VoxelShapes.union(buffer[1], VoxelShapes.cuboid(1-maxZ, minY, minX, 1-minZ, maxY, maxX)));
buffer[0] = buffer[1];
buffer[1] = VoxelShapes.empty();
}
return buffer[0];
}
}

View File

@@ -1,42 +0,0 @@
package eu.midnightdust.motschen.decorative.block;
import eu.midnightdust.motschen.decorative.block.blockentity.JungleChoppingLogBlockEntity;
import net.fabricmc.fabric.api.object.builder.v1.block.FabricBlockSettings;
import net.minecraft.block.*;
import net.minecraft.block.entity.BlockEntity;
import net.minecraft.item.ItemPlacementContext;
import net.minecraft.sound.BlockSoundGroup;
import net.minecraft.state.StateManager;
import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.Direction;
import net.minecraft.world.BlockView;
import net.minecraft.world.WorldView;
public class JungleChoppingLog extends HorizontalFacingBlock implements BlockEntityProvider {
public JungleChoppingLog() {
super(FabricBlockSettings.copy(Blocks.OAK_PLANKS).nonOpaque().sounds(BlockSoundGroup.WOOD));
this.setDefaultState(this.stateManager.getDefaultState().with(FACING, Direction.NORTH));
}
@Override
public BlockState getPlacementState(ItemPlacementContext itemPlacementContext) {
return super.getPlacementState(itemPlacementContext)
.with(FACING, itemPlacementContext.getPlayerFacing().getOpposite());
}
@Override
protected void appendProperties(StateManager.Builder<Block, BlockState> builder) {
builder.add(FACING);
}
public boolean canPlaceAt(BlockState state, WorldView worldView, BlockPos pos) {
return !worldView.isAir(pos.down());
}
@Override
public BlockEntity createBlockEntity(BlockView view) {
return new JungleChoppingLogBlockEntity();
}
}

View File

@@ -33,7 +33,7 @@ public class OldTelevision extends HorizontalFacingBlock {
private static final EnumProperty<Program> PROGRAM = DecorativeMain.PROGRAM; private static final EnumProperty<Program> PROGRAM = DecorativeMain.PROGRAM;
public OldTelevision() { public OldTelevision() {
super(FabricBlockSettings.copy(Blocks.BLACK_CONCRETE).nonOpaque().sounds(BlockSoundGroup.STONE).lightLevel(createLightLevelFromBlockState(15))); super(FabricBlockSettings.copy(Blocks.BLACK_CONCRETE).nonOpaque().sounds(BlockSoundGroup.STONE).luminance(createLightLevelFromBlockState()));
this.setDefaultState(this.stateManager.getDefaultState().with(FACING, Direction.NORTH).with(PROGRAM, Program.OFF)); this.setDefaultState(this.stateManager.getDefaultState().with(FACING, Direction.NORTH).with(PROGRAM, Program.OFF));
} }
@@ -104,7 +104,7 @@ public class OldTelevision extends HorizontalFacingBlock {
return !worldView.isAir(pos.down()); return !worldView.isAir(pos.down());
} }
private static ToIntFunction<BlockState> createLightLevelFromBlockState(int litLevel) { private static ToIntFunction<BlockState> createLightLevelFromBlockState() {
return (blockState) -> { return (blockState) -> {
if (blockState.get(PROGRAM) == Program.OFF) { if (blockState.get(PROGRAM) == Program.OFF) {
return 0; return 0;

View File

@@ -0,0 +1,47 @@
package eu.midnightdust.motschen.decorative.block;
import eu.midnightdust.motschen.decorative.block.blockentity.SmokeDetectorBlockEntity;
import eu.midnightdust.motschen.decorative.block.blockentity.WallClockBlockEntity;
import net.fabricmc.fabric.api.object.builder.v1.block.FabricBlockSettings;
import net.minecraft.block.*;
import net.minecraft.block.entity.BlockEntity;
import net.minecraft.item.ItemPlacementContext;
import net.minecraft.sound.BlockSoundGroup;
import net.minecraft.state.StateManager;
import net.minecraft.state.property.BooleanProperty;
import net.minecraft.state.property.Property;
import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.Direction;
import net.minecraft.util.shape.VoxelShape;
import net.minecraft.util.shape.VoxelShapes;
import net.minecraft.world.BlockView;
public class SmokeDetector extends HorizontalFacingBlock implements BlockEntityProvider {
private static final VoxelShape SHAPE;
public static final BooleanProperty ACTIVE = BooleanProperty.of("active");
public SmokeDetector() {
super(FabricBlockSettings.copy(Blocks.SMOOTH_QUARTZ).nonOpaque().sounds(BlockSoundGroup.STONE));
this.setDefaultState(this.stateManager.getDefaultState().with(ACTIVE, false));
}
@Override
public BlockEntity createBlockEntity(BlockView view) {
return new SmokeDetectorBlockEntity();
}
@Override
protected void appendProperties(StateManager.Builder<Block, BlockState> builder) {
builder.add(ACTIVE);
}
@Override
public VoxelShape getOutlineShape(BlockState state, BlockView view, BlockPos pos, ShapeContext context) {
return SHAPE;
}
static {
VoxelShape shape = createCuboidShape(4, 14, 4, 12, 16, 12);
SHAPE = shape;
}
}

View File

@@ -1,42 +0,0 @@
package eu.midnightdust.motschen.decorative.block;
import eu.midnightdust.motschen.decorative.block.blockentity.SpruceChoppingLogBlockEntity;
import net.fabricmc.fabric.api.object.builder.v1.block.FabricBlockSettings;
import net.minecraft.block.*;
import net.minecraft.block.entity.BlockEntity;
import net.minecraft.item.ItemPlacementContext;
import net.minecraft.sound.BlockSoundGroup;
import net.minecraft.state.StateManager;
import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.Direction;
import net.minecraft.world.BlockView;
import net.minecraft.world.WorldView;
public class SpruceChoppingLog extends HorizontalFacingBlock implements BlockEntityProvider {
public SpruceChoppingLog() {
super(FabricBlockSettings.copy(Blocks.OAK_PLANKS).nonOpaque().sounds(BlockSoundGroup.WOOD));
this.setDefaultState(this.stateManager.getDefaultState().with(FACING, Direction.NORTH));
}
@Override
public BlockState getPlacementState(ItemPlacementContext itemPlacementContext) {
return super.getPlacementState(itemPlacementContext)
.with(FACING, itemPlacementContext.getPlayerFacing().getOpposite());
}
@Override
protected void appendProperties(StateManager.Builder<Block, BlockState> builder) {
builder.add(FACING);
}
public boolean canPlaceAt(BlockState state, WorldView worldView, BlockPos pos) {
return !worldView.isAir(pos.down());
}
@Override
public BlockEntity createBlockEntity(BlockView view) {
return new SpruceChoppingLogBlockEntity();
}
}

View File

@@ -34,7 +34,7 @@ public class Television extends HorizontalFacingBlock {
private static final EnumProperty<Program> PROGRAM = DecorativeMain.PROGRAM; private static final EnumProperty<Program> PROGRAM = DecorativeMain.PROGRAM;
public Television() { public Television() {
super(FabricBlockSettings.copy(Blocks.BLACK_CONCRETE).nonOpaque().sounds(BlockSoundGroup.STONE).lightLevel(createLightLevelFromBlockState(15))); super(FabricBlockSettings.copy(Blocks.BLACK_CONCRETE).nonOpaque().sounds(BlockSoundGroup.STONE).luminance(createLightLevelFromBlockState()));
this.setDefaultState(this.stateManager.getDefaultState().with(FACING, Direction.NORTH).with(PROGRAM, Program.OFF)); this.setDefaultState(this.stateManager.getDefaultState().with(FACING, Direction.NORTH).with(PROGRAM, Program.OFF));
} }
@@ -105,7 +105,7 @@ public class Television extends HorizontalFacingBlock {
return !worldView.isAir(pos.down()); return !worldView.isAir(pos.down());
} }
private static ToIntFunction<BlockState> createLightLevelFromBlockState(int litLevel) { private static ToIntFunction<BlockState> createLightLevelFromBlockState() {
return (blockState) -> { return (blockState) -> {
if (blockState.get(PROGRAM) == Program.OFF) { if (blockState.get(PROGRAM) == Program.OFF) {
return 0; return 0;

View File

@@ -0,0 +1,73 @@
package eu.midnightdust.motschen.decorative.block;
import eu.midnightdust.motschen.decorative.block.blockentity.WallClockBlockEntity;
import net.fabricmc.fabric.api.object.builder.v1.block.FabricBlockSettings;
import net.minecraft.block.*;
import net.minecraft.block.entity.BlockEntity;
import net.minecraft.item.ItemPlacementContext;
import net.minecraft.sound.BlockSoundGroup;
import net.minecraft.state.StateManager;
import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.Direction;
import net.minecraft.util.shape.VoxelShape;
import net.minecraft.util.shape.VoxelShapes;
import net.minecraft.world.BlockView;
public class WallClock extends HorizontalFacingBlock implements BlockEntityProvider {
private static final VoxelShape NORTH_SHAPE;
private static final VoxelShape EAST_SHAPE;
private static final VoxelShape SOUTH_SHAPE;
private static final VoxelShape WEST_SHAPE;
public WallClock() {
super(FabricBlockSettings.copy(Blocks.SMOOTH_QUARTZ).nonOpaque().sounds(BlockSoundGroup.STONE));
this.setDefaultState(this.stateManager.getDefaultState().with(FACING, Direction.NORTH));
}
@Override
public BlockEntity createBlockEntity(BlockView view) {
return new WallClockBlockEntity();
}
@Override
protected void appendProperties(StateManager.Builder<Block, BlockState> builder) {
builder.add(FACING);
}
@Override
public BlockState getPlacementState(ItemPlacementContext itemPlacementContext) {
return super.getPlacementState(itemPlacementContext)
.with(FACING, itemPlacementContext.getPlayerFacing().getOpposite());
}
@Override
public VoxelShape getOutlineShape(BlockState state, BlockView view, BlockPos pos, ShapeContext context) {
switch (state.get(FACING)) {
case NORTH: return NORTH_SHAPE;
case EAST: return EAST_SHAPE;
case SOUTH: return SOUTH_SHAPE;
case WEST: return WEST_SHAPE;
default: return super.getOutlineShape(state, view, pos, context);
}
}
static {
VoxelShape shape = createCuboidShape(0, 0, 15, 16, 16, 16);
NORTH_SHAPE = shape;
WEST_SHAPE = rotate(Direction.EAST, Direction.NORTH, shape);
EAST_SHAPE = rotate(Direction.EAST, Direction.SOUTH, shape);
SOUTH_SHAPE = rotate(Direction.EAST, Direction.WEST, shape);
}
private static VoxelShape rotate(Direction from, Direction to, VoxelShape shape) {
VoxelShape[] buffer = new VoxelShape[]{ shape, VoxelShapes.empty() };
int times = (to.getHorizontal() - from.getHorizontal() + 4) % 4;
for (int i = 0; i < times; i++) {
buffer[0].forEachBox((minX, minY, minZ, maxX, maxY, maxZ) -> buffer[1] = VoxelShapes.union(buffer[1], VoxelShapes.cuboid(1-maxZ, minY, minX, 1-minZ, maxY, maxX)));
buffer[0] = buffer[1];
buffer[1] = VoxelShapes.empty();
}
return buffer[0];
}
}

View File

@@ -8,13 +8,13 @@ import net.minecraft.util.Tickable;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.Direction; import net.minecraft.util.math.Direction;
public class OakChoppingLogBlockEntity extends BlockEntity implements Tickable { public class ChoppingLogBlockEntity extends BlockEntity implements Tickable {
private int facing; private int facing;
private double axe_x; private double axe_x;
private double axe_z; private double axe_z;
public OakChoppingLogBlockEntity() { public ChoppingLogBlockEntity() {
super(BlockEntities.OakChoppingLogBlockEntity); super(BlockEntities.ChoppingLogBlockEntity);
} }
@Override @Override

View File

@@ -1,61 +0,0 @@
package eu.midnightdust.motschen.decorative.block.blockentity;
import eu.midnightdust.motschen.decorative.init.BlockEntities;
import net.minecraft.block.BlockState;
import net.minecraft.block.HorizontalFacingBlock;
import net.minecraft.block.entity.BlockEntity;
import net.minecraft.util.Tickable;
import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.Direction;
public class DarkOakChoppingLogBlockEntity extends BlockEntity implements Tickable {
private int facing;
private double axe_x;
private double axe_z;
public DarkOakChoppingLogBlockEntity() {
super(BlockEntities.DarkOakChoppingLogBlockEntity);
}
@Override
public void tick() {
BlockPos pos = this.pos;
BlockState state = this.world.getBlockState(pos);
if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.EAST) {
facing = 180;
axe_x = 0.2D;
axe_z = 0.5D;
return;
}
if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.SOUTH) {
facing = 90;
axe_x = 0.5D;
axe_z = 0.2D;
return;
}
if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.WEST) {
facing = 0;
axe_x = 0.8D;
axe_z = 0.5D;
return;
}
else {
facing = 270;
axe_x = 0.5D;
axe_z = 0.8D;
return;
}
}
public int getFacing() {
return facing;
}
public double getAxeX() {
return axe_x;
}
public double getAxeZ() {
return axe_z;
}
}

View File

@@ -4,58 +4,67 @@ import eu.midnightdust.motschen.decorative.init.BlockEntities;
import net.minecraft.block.BlockState; import net.minecraft.block.BlockState;
import net.minecraft.block.HorizontalFacingBlock; import net.minecraft.block.HorizontalFacingBlock;
import net.minecraft.block.entity.BlockEntity; import net.minecraft.block.entity.BlockEntity;
import net.minecraft.sound.SoundCategory;
import net.minecraft.sound.SoundEvents;
import net.minecraft.util.Tickable; import net.minecraft.util.Tickable;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.Direction; import net.minecraft.util.math.Direction;
public class AcaciaChoppingLogBlockEntity extends BlockEntity implements Tickable { import java.time.LocalTime;
private int facing;
private double axe_x;
private double axe_z;
public AcaciaChoppingLogBlockEntity() { public class DigitalClockBlockEntity extends BlockEntity implements Tickable {
super(BlockEntities.AcaciaChoppingLogBlockEntity); private int facing;
private double x;
private double z;
private int second;
public DigitalClockBlockEntity() {
super(BlockEntities.DigitalClockBlockEntity);
} }
@Override @Override
public void tick() { public void tick() {
if (LocalTime.now().getSecond() != second) {
second = LocalTime.now().getSecond();
}
BlockPos pos = this.pos; BlockPos pos = this.pos;
BlockState state = this.world.getBlockState(pos); BlockState state = this.world.getBlockState(pos);
if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.EAST) { if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.EAST) {
facing = 180; facing = 270;
axe_x = 0.2D; x = 0.626;
axe_z = 0.5D; z = 0.825;
return; return;
} }
if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.SOUTH) { if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.SOUTH) {
facing = 90; facing = 180;
axe_x = 0.5D; x = 0.175;
axe_z = 0.2D; z = 0.626;
return; return;
} }
if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.WEST) { if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.WEST) {
facing = 0; facing = 90;
axe_x = 0.8D; x = 0.374;
axe_z = 0.5D; z = 0.175;
return; return;
} }
else { else {
facing = 270; facing = 0;
axe_x = 0.5D; x = 0.825;
axe_z = 0.8D; z = 0.374;
return; return;
} }
}
}
public int getFacing() { public int getFacing() {
return facing; return facing;
} }
public double getAxeX() { public double getX() {
return axe_x; return x;
} }
public double getAxeZ() { public double getZ() {
return axe_z; return z;
} }
} }

View File

@@ -1,61 +0,0 @@
package eu.midnightdust.motschen.decorative.block.blockentity;
import eu.midnightdust.motschen.decorative.init.BlockEntities;
import net.minecraft.block.BlockState;
import net.minecraft.block.HorizontalFacingBlock;
import net.minecraft.block.entity.BlockEntity;
import net.minecraft.util.Tickable;
import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.Direction;
public class JungleChoppingLogBlockEntity extends BlockEntity implements Tickable {
private int facing;
private double axe_x;
private double axe_z;
public JungleChoppingLogBlockEntity() {
super(BlockEntities.JungleChoppingLogBlockEntity);
}
@Override
public void tick() {
BlockPos pos = this.pos;
BlockState state = this.world.getBlockState(pos);
if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.EAST) {
facing = 180;
axe_x = 0.2D;
axe_z = 0.5D;
return;
}
if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.SOUTH) {
facing = 90;
axe_x = 0.5D;
axe_z = 0.2D;
return;
}
if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.WEST) {
facing = 0;
axe_x = 0.8D;
axe_z = 0.5D;
return;
}
else {
facing = 270;
axe_x = 0.5D;
axe_z = 0.8D;
return;
}
}
public int getFacing() {
return facing;
}
public double getAxeX() {
return axe_x;
}
public double getAxeZ() {
return axe_z;
}
}

View File

@@ -18,14 +18,25 @@ public class PoolSprinklerBlockEntity extends BlockEntity implements Tickable {
@Override @Override
public void tick() { public void tick() {
BlockPos pos = this.pos; BlockPos pos = this.pos;
BlockState state = this.world.getBlockState(pos); if (world != null) {
if (world != null && state.get(PoolSprinkler.POWERED) == true) { BlockState state = this.world.getBlockState(pos);
switch (state.get(PoolSprinkler.FACING)) { if (state.get(PoolSprinkler.POWERED)) {
case NORTH: world.addParticle(ParticleTypes.DRIPPING_WATER,pos.getX()+0.5,pos.getY()+0.5,pos.getZ()-0.34,1,1,1); return; switch (state.get(PoolSprinkler.FACING)) {
case EAST: world.addParticle(ParticleTypes.DRIPPING_WATER,pos.getX()+1.34,pos.getY()+0.5,pos.getZ()+0.5,1,1,1); return; case NORTH:
case SOUTH: world.addParticle(ParticleTypes.DRIPPING_WATER,pos.getX()+0.5,pos.getY()+0.5,pos.getZ()+1.34,1,1,1); return; world.addParticle(ParticleTypes.DRIPPING_WATER, pos.getX() + 0.5, pos.getY() + 0.5, pos.getZ() - 0.34, 1, 1, 1);
case WEST: world.addParticle(ParticleTypes.DRIPPING_WATER,pos.getX()-0.34,pos.getY()+0.5,pos.getZ()+0.5,1,1,1); return; return;
default: return; case EAST:
world.addParticle(ParticleTypes.DRIPPING_WATER, pos.getX() + 1.34, pos.getY() + 0.5, pos.getZ() + 0.5, 1, 1, 1);
return;
case SOUTH:
world.addParticle(ParticleTypes.DRIPPING_WATER, pos.getX() + 0.5, pos.getY() + 0.5, pos.getZ() + 1.34, 1, 1, 1);
return;
case WEST:
world.addParticle(ParticleTypes.DRIPPING_WATER, pos.getX() - 0.34, pos.getY() + 0.5, pos.getZ() + 0.5, 1, 1, 1);
return;
default:
return;
}
} }
} }
} }

View File

@@ -18,14 +18,25 @@ public class ShowerHeadBlockEntity extends BlockEntity implements Tickable {
@Override @Override
public void tick() { public void tick() {
BlockPos pos = this.pos; BlockPos pos = this.pos;
BlockState state = this.world.getBlockState(pos); if (world != null) {
if (world != null && state.get(PoolSprinkler.POWERED) == true) { BlockState state = this.world.getBlockState(pos);
switch (state.get(PoolSprinkler.FACING)) { if (state.get(PoolSprinkler.POWERED) == true) {
case NORTH: world.addParticle(ParticleTypes.DRIPPING_WATER,pos.getX()+0.5,pos.getY()+0.5,pos.getZ()+0.625,1,1,1); return; switch (state.get(PoolSprinkler.FACING)) {
case EAST: world.addParticle(ParticleTypes.DRIPPING_WATER,pos.getX()+0.375,pos.getY()+0.5,pos.getZ()+0.5,1,1,1); return; case NORTH:
case SOUTH: world.addParticle(ParticleTypes.DRIPPING_WATER,pos.getX()+0.5,pos.getY()+0.5,pos.getZ()+0.375,1,1,1); return; world.addParticle(ParticleTypes.DRIPPING_WATER, pos.getX() + 0.5, pos.getY() + 0.5, pos.getZ() + 0.625, 1, 1, 1);
case WEST: world.addParticle(ParticleTypes.DRIPPING_WATER,pos.getX()+0.625,pos.getY()+0.5,pos.getZ()+0.5,1,1,1); return; return;
default: return; case EAST:
world.addParticle(ParticleTypes.DRIPPING_WATER, pos.getX() + 0.375, pos.getY() + 0.5, pos.getZ() + 0.5, 1, 1, 1);
return;
case SOUTH:
world.addParticle(ParticleTypes.DRIPPING_WATER, pos.getX() + 0.5, pos.getY() + 0.5, pos.getZ() + 0.375, 1, 1, 1);
return;
case WEST:
world.addParticle(ParticleTypes.DRIPPING_WATER, pos.getX() + 0.625, pos.getY() + 0.5, pos.getZ() + 0.5, 1, 1, 1);
return;
default:
return;
}
} }
} }
} }

View File

@@ -0,0 +1,47 @@
package eu.midnightdust.motschen.decorative.block.blockentity;
import eu.midnightdust.motschen.decorative.DecorativeMain;
import eu.midnightdust.motschen.decorative.block.SmokeDetector;
import eu.midnightdust.motschen.decorative.init.BlockEntities;
import eu.midnightdust.motschen.decorative.sound.DecorativeSoundEvents;
import net.minecraft.block.entity.BlockEntity;
import net.minecraft.sound.SoundCategory;
import net.minecraft.sound.SoundEvents;
import net.minecraft.tag.BlockTags;
import net.minecraft.util.Tickable;
import net.minecraft.util.math.BlockPos;
import java.time.LocalTime;
public class SmokeDetectorBlockEntity extends BlockEntity implements Tickable {
private int second;
private int sound = 0;
public SmokeDetectorBlockEntity() {
super(BlockEntities.SmokeDetectorBlockEntity);
}
public boolean isInFireRange() {
return this.world.getBlockState(this.pos.down()).isIn(BlockTags.FIRE);
}
@Override
public void tick() {
if (LocalTime.now().getSecond() != second) {
second = LocalTime.now().getSecond();
if (this.isInFireRange()) {
world.setBlockState(pos, DecorativeMain.SmokeDetector.getDefaultState().with(SmokeDetector.ACTIVE, true));
sound = sound + 1;
if (sound > 3) {sound = 0;}
if (sound == 0) {
world.playSound(null, pos, DecorativeSoundEvents.SMOKE_DETECTOR_BEEP, SoundCategory.BLOCKS, 1f, 1f);
}
}
else if (this.world.getBlockState(pos).get(SmokeDetector.ACTIVE).equals(true)) {
world.setBlockState(pos, DecorativeMain.SmokeDetector.getDefaultState().with(SmokeDetector.ACTIVE, false));
}
}
}
}

View File

@@ -1,61 +0,0 @@
package eu.midnightdust.motschen.decorative.block.blockentity;
import eu.midnightdust.motschen.decorative.init.BlockEntities;
import net.minecraft.block.BlockState;
import net.minecraft.block.HorizontalFacingBlock;
import net.minecraft.block.entity.BlockEntity;
import net.minecraft.util.Tickable;
import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.Direction;
public class SpruceChoppingLogBlockEntity extends BlockEntity implements Tickable {
private int facing;
private double axe_x;
private double axe_z;
public SpruceChoppingLogBlockEntity() {
super(BlockEntities.SpruceChoppingLogBlockEntity);
}
@Override
public void tick() {
BlockPos pos = this.pos;
BlockState state = this.world.getBlockState(pos);
if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.EAST) {
facing = 180;
axe_x = 0.2D;
axe_z = 0.5D;
return;
}
if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.SOUTH) {
facing = 90;
axe_x = 0.5D;
axe_z = 0.2D;
return;
}
if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.WEST) {
facing = 0;
axe_x = 0.8D;
axe_z = 0.5D;
return;
}
else {
facing = 270;
axe_x = 0.5D;
axe_z = 0.8D;
return;
}
}
public int getFacing() {
return facing;
}
public double getAxeX() {
return axe_x;
}
public double getAxeZ() {
return axe_z;
}
}

View File

@@ -1,61 +1,73 @@
package eu.midnightdust.motschen.decorative.block.blockentity; package eu.midnightdust.motschen.decorative.block.blockentity;
import eu.midnightdust.motschen.decorative.init.BlockEntities; import eu.midnightdust.motschen.decorative.init.BlockEntities;
import eu.midnightdust.motschen.decorative.sound.DecorativeSoundEvents;
import net.minecraft.block.BlockState; import net.minecraft.block.BlockState;
import net.minecraft.block.HorizontalFacingBlock; import net.minecraft.block.HorizontalFacingBlock;
import net.minecraft.block.entity.BlockEntity; import net.minecraft.block.entity.BlockEntity;
import net.minecraft.sound.SoundCategory;
import net.minecraft.sound.SoundEvents;
import net.minecraft.state.property.Properties;
import net.minecraft.util.Tickable; import net.minecraft.util.Tickable;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.Direction; import net.minecraft.util.math.Direction;
public class BirchChoppingLogBlockEntity extends BlockEntity implements Tickable { import java.time.LocalTime;
private int facing;
private double axe_x;
private double axe_z;
public BirchChoppingLogBlockEntity() { public class WallClockBlockEntity extends BlockEntity implements Tickable {
super(BlockEntities.BirchChoppingLogBlockEntity); private int facing;
private double x;
private double z;
private int second;
public WallClockBlockEntity() {
super(BlockEntities.WallClockBlockEntity);
} }
@Override @Override
public void tick() { public void tick() {
if (LocalTime.now().getSecond() != second) {
second = LocalTime.now().getSecond();
world.playSound(null, pos, SoundEvents.BLOCK_WOODEN_BUTTON_CLICK_ON, SoundCategory.BLOCKS, 0.004f, 1f);
}
BlockPos pos = this.pos; BlockPos pos = this.pos;
BlockState state = this.world.getBlockState(pos); BlockState state = this.world.getBlockState(pos);
if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.EAST) { if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.EAST) {
facing = 180; facing = 270;
axe_x = 0.2D; x = 0.05;
axe_z = 0.5D; z = 0.5;
return; return;
} }
if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.SOUTH) { if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.SOUTH) {
facing = 90; facing = 180;
axe_x = 0.5D; x = 0.5;
axe_z = 0.2D; z = 0.05;
return; return;
} }
if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.WEST) { if (world != null && state.get(HorizontalFacingBlock.FACING) == Direction.WEST) {
facing = 0; facing = 90;
axe_x = 0.8D; x = 0.95;
axe_z = 0.5D; z = 0.5;
return; return;
} }
else { else {
facing = 270; facing = 0;
axe_x = 0.5D; x = 0.5;
axe_z = 0.8D; z = 0.95;
return; return;
} }
}
}
public int getFacing() { public int getFacing() {
return facing; return facing;
} }
public double getAxeX() { public double getX() {
return axe_x; return x;
} }
public double getAxeZ() { public double getZ() {
return axe_z; return z;
} }
} }

View File

@@ -1,52 +0,0 @@
package eu.midnightdust.motschen.decorative.block.render;
import eu.midnightdust.motschen.decorative.block.blockentity.AcaciaChoppingLogBlockEntity;
import net.fabricmc.api.EnvType;
import net.fabricmc.api.Environment;
import net.minecraft.block.BlockState;
import net.minecraft.client.MinecraftClient;
import net.minecraft.client.render.VertexConsumerProvider;
import net.minecraft.client.render.WorldRenderer;
import net.minecraft.client.render.block.entity.BlockEntityRenderDispatcher;
import net.minecraft.client.render.block.entity.BlockEntityRenderer;
import net.minecraft.client.render.model.json.ModelTransformation;
import net.minecraft.client.util.math.MatrixStack;
import net.minecraft.client.util.math.Vector3f;
import net.minecraft.item.ItemStack;
import net.minecraft.item.Items;
import net.minecraft.util.math.BlockPos;
@Environment(EnvType.CLIENT)
public class AcaciaChoppingLogBlockEntityRenderer extends BlockEntityRenderer<AcaciaChoppingLogBlockEntity> {
public AcaciaChoppingLogBlockEntityRenderer(BlockEntityRenderDispatcher blockEntityRenderDispatcher) {
super(blockEntityRenderDispatcher);
}
@Override
public boolean rendersOutsideBoundingBox(AcaciaChoppingLogBlockEntity blockEntity) {
return true;
}
@Override
public void render(AcaciaChoppingLogBlockEntity blockEntity, float tickDelta, MatrixStack matrices, VertexConsumerProvider vertexConsumers, int light, int overlay) {
BlockPos pos = blockEntity.getPos();
BlockState state = blockEntity.getWorld().getBlockState(pos);
matrices.push();
int lightAbove = WorldRenderer.getLightmapCoordinates(blockEntity.getWorld(), blockEntity.getPos().up());
matrices.translate(blockEntity.getAxeX(), 1.5D, blockEntity.getAxeZ());
matrices.scale(2.5f,2.5f,2.5f);
matrices.multiply(Vector3f.POSITIVE_Y.getDegreesQuaternion(blockEntity.getFacing()));
matrices.multiply(Vector3f.POSITIVE_Z.getDegreesQuaternion(160));
MinecraftClient.getInstance().getItemRenderer().renderItem(new ItemStack(Items.IRON_AXE),
ModelTransformation.Mode.GROUND, lightAbove, overlay, matrices, vertexConsumers);
matrices.pop();
}
}

View File

@@ -1,52 +0,0 @@
package eu.midnightdust.motschen.decorative.block.render;
import eu.midnightdust.motschen.decorative.block.blockentity.BirchChoppingLogBlockEntity;
import net.fabricmc.api.EnvType;
import net.fabricmc.api.Environment;
import net.minecraft.block.BlockState;
import net.minecraft.client.MinecraftClient;
import net.minecraft.client.render.VertexConsumerProvider;
import net.minecraft.client.render.WorldRenderer;
import net.minecraft.client.render.block.entity.BlockEntityRenderDispatcher;
import net.minecraft.client.render.block.entity.BlockEntityRenderer;
import net.minecraft.client.render.model.json.ModelTransformation;
import net.minecraft.client.util.math.MatrixStack;
import net.minecraft.client.util.math.Vector3f;
import net.minecraft.item.ItemStack;
import net.minecraft.item.Items;
import net.minecraft.util.math.BlockPos;
@Environment(EnvType.CLIENT)
public class BirchChoppingLogBlockEntityRenderer extends BlockEntityRenderer<BirchChoppingLogBlockEntity> {
public BirchChoppingLogBlockEntityRenderer(BlockEntityRenderDispatcher blockEntityRenderDispatcher) {
super(blockEntityRenderDispatcher);
}
@Override
public boolean rendersOutsideBoundingBox(BirchChoppingLogBlockEntity blockEntity) {
return true;
}
@Override
public void render(BirchChoppingLogBlockEntity blockEntity, float tickDelta, MatrixStack matrices, VertexConsumerProvider vertexConsumers, int light, int overlay) {
BlockPos pos = blockEntity.getPos();
BlockState state = blockEntity.getWorld().getBlockState(pos);
matrices.push();
int lightAbove = WorldRenderer.getLightmapCoordinates(blockEntity.getWorld(), blockEntity.getPos().up());
matrices.translate(blockEntity.getAxeX(), 1.5D, blockEntity.getAxeZ());
matrices.scale(2.5f,2.5f,2.5f);
matrices.multiply(Vector3f.POSITIVE_Y.getDegreesQuaternion(blockEntity.getFacing()));
matrices.multiply(Vector3f.POSITIVE_Z.getDegreesQuaternion(160));
MinecraftClient.getInstance().getItemRenderer().renderItem(new ItemStack(Items.IRON_AXE),
ModelTransformation.Mode.GROUND, lightAbove, overlay, matrices, vertexConsumers);
matrices.pop();
}
}

View File

@@ -1,6 +1,6 @@
package eu.midnightdust.motschen.decorative.block.render; package eu.midnightdust.motschen.decorative.block.render;
import eu.midnightdust.motschen.decorative.block.blockentity.OakChoppingLogBlockEntity; import eu.midnightdust.motschen.decorative.block.blockentity.ChoppingLogBlockEntity;
import net.fabricmc.api.EnvType; import net.fabricmc.api.EnvType;
import net.fabricmc.api.Environment; import net.fabricmc.api.Environment;
import net.minecraft.block.BlockState; import net.minecraft.block.BlockState;
@@ -16,20 +16,20 @@ import net.minecraft.item.Items;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
@Environment(EnvType.CLIENT) @Environment(EnvType.CLIENT)
public class OakChoppingLogBlockEntityRenderer extends BlockEntityRenderer<OakChoppingLogBlockEntity> { public class ChoppingLogBlockEntityRenderer extends BlockEntityRenderer<ChoppingLogBlockEntity> {
public OakChoppingLogBlockEntityRenderer(BlockEntityRenderDispatcher blockEntityRenderDispatcher) { public ChoppingLogBlockEntityRenderer(BlockEntityRenderDispatcher blockEntityRenderDispatcher) {
super(blockEntityRenderDispatcher); super(blockEntityRenderDispatcher);
} }
@Override @Override
public boolean rendersOutsideBoundingBox(OakChoppingLogBlockEntity blockEntity) { public boolean rendersOutsideBoundingBox(ChoppingLogBlockEntity blockEntity) {
return true; return true;
} }
@Override @Override
public void render(OakChoppingLogBlockEntity blockEntity, float tickDelta, MatrixStack matrices, VertexConsumerProvider vertexConsumers, int light, int overlay) { public void render(ChoppingLogBlockEntity blockEntity, float tickDelta, MatrixStack matrices, VertexConsumerProvider vertexConsumers, int light, int overlay) {
BlockPos pos = blockEntity.getPos(); BlockPos pos = blockEntity.getPos();
BlockState state = blockEntity.getWorld().getBlockState(pos); BlockState state = blockEntity.getWorld().getBlockState(pos);

View File

@@ -1,52 +0,0 @@
package eu.midnightdust.motschen.decorative.block.render;
import eu.midnightdust.motschen.decorative.block.blockentity.DarkOakChoppingLogBlockEntity;
import net.fabricmc.api.EnvType;
import net.fabricmc.api.Environment;
import net.minecraft.block.BlockState;
import net.minecraft.client.MinecraftClient;
import net.minecraft.client.render.VertexConsumerProvider;
import net.minecraft.client.render.WorldRenderer;
import net.minecraft.client.render.block.entity.BlockEntityRenderDispatcher;
import net.minecraft.client.render.block.entity.BlockEntityRenderer;
import net.minecraft.client.render.model.json.ModelTransformation;
import net.minecraft.client.util.math.MatrixStack;
import net.minecraft.client.util.math.Vector3f;
import net.minecraft.item.ItemStack;
import net.minecraft.item.Items;
import net.minecraft.util.math.BlockPos;
@Environment(EnvType.CLIENT)
public class DarkOakChoppingLogBlockEntityRenderer extends BlockEntityRenderer<DarkOakChoppingLogBlockEntity> {
public DarkOakChoppingLogBlockEntityRenderer(BlockEntityRenderDispatcher blockEntityRenderDispatcher) {
super(blockEntityRenderDispatcher);
}
@Override
public boolean rendersOutsideBoundingBox(DarkOakChoppingLogBlockEntity blockEntity) {
return true;
}
@Override
public void render(DarkOakChoppingLogBlockEntity blockEntity, float tickDelta, MatrixStack matrices, VertexConsumerProvider vertexConsumers, int light, int overlay) {
BlockPos pos = blockEntity.getPos();
BlockState state = blockEntity.getWorld().getBlockState(pos);
matrices.push();
int lightAbove = WorldRenderer.getLightmapCoordinates(blockEntity.getWorld(), blockEntity.getPos().up());
matrices.translate(blockEntity.getAxeX(), 1.5D, blockEntity.getAxeZ());
matrices.scale(2.5f,2.5f,2.5f);
matrices.multiply(Vector3f.POSITIVE_Y.getDegreesQuaternion(blockEntity.getFacing()));
matrices.multiply(Vector3f.POSITIVE_Z.getDegreesQuaternion(160));
MinecraftClient.getInstance().getItemRenderer().renderItem(new ItemStack(Items.IRON_AXE),
ModelTransformation.Mode.GROUND, lightAbove, overlay, matrices, vertexConsumers);
matrices.pop();
}
}

View File

@@ -0,0 +1,86 @@
package eu.midnightdust.motschen.decorative.block.render;
import eu.midnightdust.motschen.decorative.DecorativeMain;
import eu.midnightdust.motschen.decorative.block.blockentity.DigitalClockBlockEntity;
import eu.midnightdust.motschen.decorative.block.blockentity.WallClockBlockEntity;
import net.fabricmc.api.EnvType;
import net.fabricmc.api.Environment;
import net.minecraft.client.font.TextRenderer;
import net.minecraft.client.model.ModelPart;
import net.minecraft.client.render.*;
import net.minecraft.client.render.block.entity.BlockEntityRenderDispatcher;
import net.minecraft.client.render.block.entity.BlockEntityRenderer;
import net.minecraft.client.render.block.entity.SignBlockEntityRenderer;
import net.minecraft.client.util.math.MatrixStack;
import net.minecraft.client.util.math.Vector3f;
import net.minecraft.util.Identifier;
import java.text.SimpleDateFormat;
import java.time.LocalTime;
import java.util.SimpleTimeZone;
import java.util.TimeZone;
@Environment(EnvType.CLIENT)
public class DigitalClockRenderer extends BlockEntityRenderer<DigitalClockBlockEntity> {
public DigitalClockRenderer(BlockEntityRenderDispatcher blockEntityRenderDispatcher) {
super(blockEntityRenderDispatcher);
}
private int getHour12hFormat() {
int hour;
hour = LocalTime.now().getHour();
if (hour > 12) {
hour = hour - 12;
}
return hour;
}
private String getTime() {
String hour;
String minute;
// Hour
if (DecorativeMain.DECORATIVE_CONFIG.use12hTime) {
if (getHour12hFormat() <= 9) {
hour = "0" + getHour12hFormat();
} else {
hour = "" + getHour12hFormat();
}
}
else {
if (LocalTime.now().getHour() <= 9) {
hour = "0" + LocalTime.now().getHour();
} else {
hour = "" + LocalTime.now().getHour();
}
}
// Minute
if (LocalTime.now().getMinute() <= 9) {
minute = "0" + LocalTime.now().getMinute();
}
else {
minute = "" + LocalTime.now().getMinute();
}
String time = hour +":"+ minute;
return time;
}
@Override
public void render(DigitalClockBlockEntity blockEntity, float tickDelta, MatrixStack matrices, VertexConsumerProvider vertexConsumers, int light, int overlay) {
matrices.push();
int lightAtBlock1 = WorldRenderer.getLightmapCoordinates(blockEntity.getWorld(), blockEntity.getPos());
TextRenderer textRenderer = dispatcher.getTextRenderer();
matrices.translate(blockEntity.getX(),0.35,blockEntity.getZ());
matrices.scale(0.025f, 0.025f, 0.025f);
matrices.multiply(Vector3f.POSITIVE_Y.getDegreesQuaternion(blockEntity.getFacing()));
matrices.multiply(Vector3f.POSITIVE_Z.getDegreesQuaternion(180));
textRenderer.draw(getTime(), 0, 0, 16382457, false, matrices.peek().getModel(), vertexConsumers, false, 0, lightAtBlock1);
matrices.pop();
}
}

View File

@@ -1,52 +0,0 @@
package eu.midnightdust.motschen.decorative.block.render;
import eu.midnightdust.motschen.decorative.block.blockentity.JungleChoppingLogBlockEntity;
import net.fabricmc.api.EnvType;
import net.fabricmc.api.Environment;
import net.minecraft.block.BlockState;
import net.minecraft.client.MinecraftClient;
import net.minecraft.client.render.VertexConsumerProvider;
import net.minecraft.client.render.WorldRenderer;
import net.minecraft.client.render.block.entity.BlockEntityRenderDispatcher;
import net.minecraft.client.render.block.entity.BlockEntityRenderer;
import net.minecraft.client.render.model.json.ModelTransformation;
import net.minecraft.client.util.math.MatrixStack;
import net.minecraft.client.util.math.Vector3f;
import net.minecraft.item.ItemStack;
import net.minecraft.item.Items;
import net.minecraft.util.math.BlockPos;
@Environment(EnvType.CLIENT)
public class JungleChoppingLogBlockEntityRenderer extends BlockEntityRenderer<JungleChoppingLogBlockEntity> {
public JungleChoppingLogBlockEntityRenderer(BlockEntityRenderDispatcher blockEntityRenderDispatcher) {
super(blockEntityRenderDispatcher);
}
@Override
public boolean rendersOutsideBoundingBox(JungleChoppingLogBlockEntity blockEntity) {
return true;
}
@Override
public void render(JungleChoppingLogBlockEntity blockEntity, float tickDelta, MatrixStack matrices, VertexConsumerProvider vertexConsumers, int light, int overlay) {
BlockPos pos = blockEntity.getPos();
BlockState state = blockEntity.getWorld().getBlockState(pos);
matrices.push();
int lightAbove = WorldRenderer.getLightmapCoordinates(blockEntity.getWorld(), blockEntity.getPos().up());
matrices.translate(blockEntity.getAxeX(), 1.5D, blockEntity.getAxeZ());
matrices.scale(2.5f,2.5f,2.5f);
matrices.multiply(Vector3f.POSITIVE_Y.getDegreesQuaternion(blockEntity.getFacing()));
matrices.multiply(Vector3f.POSITIVE_Z.getDegreesQuaternion(160));
MinecraftClient.getInstance().getItemRenderer().renderItem(new ItemStack(Items.IRON_AXE),
ModelTransformation.Mode.GROUND, lightAbove, overlay, matrices, vertexConsumers);
matrices.pop();
}
}

View File

@@ -1,52 +0,0 @@
package eu.midnightdust.motschen.decorative.block.render;
import eu.midnightdust.motschen.decorative.block.blockentity.SpruceChoppingLogBlockEntity;
import net.fabricmc.api.EnvType;
import net.fabricmc.api.Environment;
import net.minecraft.block.BlockState;
import net.minecraft.client.MinecraftClient;
import net.minecraft.client.render.VertexConsumerProvider;
import net.minecraft.client.render.WorldRenderer;
import net.minecraft.client.render.block.entity.BlockEntityRenderDispatcher;
import net.minecraft.client.render.block.entity.BlockEntityRenderer;
import net.minecraft.client.render.model.json.ModelTransformation;
import net.minecraft.client.util.math.MatrixStack;
import net.minecraft.client.util.math.Vector3f;
import net.minecraft.item.ItemStack;
import net.minecraft.item.Items;
import net.minecraft.util.math.BlockPos;
@Environment(EnvType.CLIENT)
public class SpruceChoppingLogBlockEntityRenderer extends BlockEntityRenderer<SpruceChoppingLogBlockEntity> {
public SpruceChoppingLogBlockEntityRenderer(BlockEntityRenderDispatcher blockEntityRenderDispatcher) {
super(blockEntityRenderDispatcher);
}
@Override
public boolean rendersOutsideBoundingBox(SpruceChoppingLogBlockEntity blockEntity) {
return true;
}
@Override
public void render(SpruceChoppingLogBlockEntity blockEntity, float tickDelta, MatrixStack matrices, VertexConsumerProvider vertexConsumers, int light, int overlay) {
BlockPos pos = blockEntity.getPos();
BlockState state = blockEntity.getWorld().getBlockState(pos);
matrices.push();
int lightAbove = WorldRenderer.getLightmapCoordinates(blockEntity.getWorld(), blockEntity.getPos().up());
matrices.translate(blockEntity.getAxeX(), 1.5D, blockEntity.getAxeZ());
matrices.scale(2.5f,2.5f,2.5f);
matrices.multiply(Vector3f.POSITIVE_Y.getDegreesQuaternion(blockEntity.getFacing()));
matrices.multiply(Vector3f.POSITIVE_Z.getDegreesQuaternion(160));
MinecraftClient.getInstance().getItemRenderer().renderItem(new ItemStack(Items.IRON_AXE),
ModelTransformation.Mode.GROUND, lightAbove, overlay, matrices, vertexConsumers);
matrices.pop();
}
}

View File

@@ -0,0 +1,83 @@
package eu.midnightdust.motschen.decorative.block.render;
import eu.midnightdust.motschen.decorative.block.blockentity.WallClockBlockEntity;
import net.fabricmc.api.EnvType;
import net.fabricmc.api.Environment;
import net.minecraft.client.model.ModelPart;
import net.minecraft.client.render.*;
import net.minecraft.client.render.block.entity.BlockEntityRenderDispatcher;
import net.minecraft.client.render.block.entity.BlockEntityRenderer;
import net.minecraft.client.util.math.MatrixStack;
import net.minecraft.client.util.math.Vector3f;
import net.minecraft.util.Identifier;
import java.time.LocalTime;
@Environment(EnvType.CLIENT)
public class WallClockRenderer extends BlockEntityRenderer<WallClockBlockEntity> {
private final ModelPart blades;
private final ModelPart seconds;
private final ModelPart minutes;
private final ModelPart hours;
public WallClockRenderer(BlockEntityRenderDispatcher blockEntityRenderDispatcher) {
super(blockEntityRenderDispatcher);
blades = new ModelPart(16, 16, 0, 0);
blades.setPivot(0.0F, 0.0F, 0.0F);
seconds = new ModelPart(16, 16, 8, 0);
seconds.addCuboid(-0.175F, 0.0F, 0.0F, 0.25F, 7.0F, 0.2F, 0.0F);
blades.addChild(seconds);
minutes = new ModelPart(16, 16, 0, 0);
minutes.addCuboid(-0.25F, 0.0F, 0.0F, 0.5F, 6.0F, 0.2F, 0.0F);
blades.addChild(minutes);
hours = new ModelPart(16, 16, 0, 0);
hours.addCuboid(-0.25F, 0.0F, 0.0F, 0.5F, 4.0F, 0.2F, 0.0F);
blades.addChild(hours);
}
private int getHour12hFormat() {
int hour;
hour = LocalTime.now().getHour();
if (hour >= 12) {
hour = hour - 12;
}
return hour;
}
@Override
public void render(WallClockBlockEntity blockEntity, float tickDelta, MatrixStack matrices, VertexConsumerProvider vertexConsumers, int light, int overlay) {
int lightAtBlock = WorldRenderer.getLightmapCoordinates(blockEntity.getWorld(), blockEntity.getPos());
matrices.push();
VertexConsumer redVertex = vertexConsumers.getBuffer(RenderLayer.getEntityCutoutNoCull(new Identifier("textures/block/red_concrete.png")));
int lightAtBlock1 = WorldRenderer.getLightmapCoordinates(blockEntity.getWorld(), blockEntity.getPos());
matrices.translate(blockEntity.getX(),0.5,blockEntity.getZ());
matrices.multiply(Vector3f.POSITIVE_Y.getDegreesQuaternion(blockEntity.getFacing()));
matrices.multiply(Vector3f.POSITIVE_Z.getDegreesQuaternion(LocalTime.now().getSecond() * 6));
seconds.render(matrices, redVertex, lightAtBlock1, OverlayTexture.DEFAULT_UV, 1.0F, 1.0F, 1.0F, 1.0F);
matrices.pop();
matrices.push();
VertexConsumer blackVertex = vertexConsumers.getBuffer(RenderLayer.getEntityCutoutNoCull(new Identifier("textures/block/black_concrete.png")));
int lightAtBlock2 = WorldRenderer.getLightmapCoordinates(blockEntity.getWorld(), blockEntity.getPos());
matrices.translate(blockEntity.getX(),0.5,blockEntity.getZ());
matrices.multiply(Vector3f.POSITIVE_Y.getDegreesQuaternion(blockEntity.getFacing()));
matrices.multiply(Vector3f.POSITIVE_Z.getDegreesQuaternion(LocalTime.now().getMinute() * 6));
minutes.render(matrices, blackVertex, lightAtBlock2, OverlayTexture.DEFAULT_UV, 1.0F, 1.0F, 1.0F, 1.0F);
matrices.pop();
matrices.push();
VertexConsumer blackVertex2 = vertexConsumers.getBuffer(RenderLayer.getEntityCutoutNoCull(new Identifier("textures/block/black_concrete.png")));
int lightAtBlock3 = WorldRenderer.getLightmapCoordinates(blockEntity.getWorld(), blockEntity.getPos());
matrices.translate(blockEntity.getX(),0.5,blockEntity.getZ());
matrices.multiply(Vector3f.POSITIVE_Y.getDegreesQuaternion(blockEntity.getFacing()));
matrices.multiply(Vector3f.POSITIVE_Z.getDegreesQuaternion(getHour12hFormat() * 30));
hours.render(matrices, blackVertex2, lightAtBlock3, OverlayTexture.DEFAULT_UV, 1.0F, 1.0F, 1.0F, 1.0F);
matrices.pop();
}
}

View File

@@ -0,0 +1,11 @@
package eu.midnightdust.motschen.decorative.config;
import me.sargunvohra.mcmods.autoconfig1u.ConfigData;
import me.sargunvohra.mcmods.autoconfig1u.annotation.Config;
import me.sargunvohra.mcmods.autoconfig1u.shadowed.blue.endless.jankson.Comment;
@Config(name = "decorative")
public class DecorativeConfig implements ConfigData {
@Comment(value = "Use 12h Time")
public boolean use12hTime = true;
}

View File

@@ -0,0 +1,16 @@
package eu.midnightdust.motschen.decorative.config;
import io.github.prospector.modmenu.api.ConfigScreenFactory;
import io.github.prospector.modmenu.api.ModMenuApi;
import me.sargunvohra.mcmods.autoconfig1u.AutoConfig;
import net.fabricmc.api.EnvType;
import net.fabricmc.api.Environment;
@Environment(EnvType.CLIENT)
public class ModMenuIntegration implements ModMenuApi {
@Override
public ConfigScreenFactory<?> getModConfigScreenFactory() {
return parent -> AutoConfig.getConfigScreen(DecorativeConfig.class, parent).get();
}
}

View File

@@ -2,6 +2,7 @@ package eu.midnightdust.motschen.decorative.init;
import eu.midnightdust.motschen.decorative.DecorativeMain; import eu.midnightdust.motschen.decorative.DecorativeMain;
import eu.midnightdust.motschen.decorative.block.blockentity.*; import eu.midnightdust.motschen.decorative.block.blockentity.*;
import net.minecraft.block.Blocks;
import net.minecraft.block.entity.BlockEntityType; import net.minecraft.block.entity.BlockEntityType;
import net.minecraft.util.Identifier; import net.minecraft.util.Identifier;
import net.minecraft.util.registry.Registry; import net.minecraft.util.registry.Registry;
@@ -11,22 +12,18 @@ public class BlockEntities {
public static BlockEntityType<PoolSprinklerBlockEntity> PoolSprinklerBlockEntity; public static BlockEntityType<PoolSprinklerBlockEntity> PoolSprinklerBlockEntity;
public static BlockEntityType<ShowerHeadBlockEntity> ShowerHeadBlockEntity; public static BlockEntityType<ShowerHeadBlockEntity> ShowerHeadBlockEntity;
public static BlockEntityType<CeilingFanBlockEntity> CeilingFanBlockEntity; public static BlockEntityType<CeilingFanBlockEntity> CeilingFanBlockEntity;
public static BlockEntityType<OakChoppingLogBlockEntity> OakChoppingLogBlockEntity; public static BlockEntityType<ChoppingLogBlockEntity> ChoppingLogBlockEntity;
public static BlockEntityType<SpruceChoppingLogBlockEntity> SpruceChoppingLogBlockEntity; public static BlockEntityType<WallClockBlockEntity> WallClockBlockEntity;
public static BlockEntityType<BirchChoppingLogBlockEntity> BirchChoppingLogBlockEntity; public static BlockEntityType<DigitalClockBlockEntity> DigitalClockBlockEntity;
public static BlockEntityType<AcaciaChoppingLogBlockEntity> AcaciaChoppingLogBlockEntity; public static BlockEntityType<SmokeDetectorBlockEntity> SmokeDetectorBlockEntity;
public static BlockEntityType<JungleChoppingLogBlockEntity> JungleChoppingLogBlockEntity;
public static BlockEntityType<DarkOakChoppingLogBlockEntity> DarkOakChoppingLogBlockEntity;
public static void init() { public static void init() {
PoolSprinklerBlockEntity = Registry.register(Registry.BLOCK_ENTITY_TYPE, new Identifier(DecorativeMain.MOD_ID,"pool_sprinkler_blockentity"), BlockEntityType.Builder.create(PoolSprinklerBlockEntity::new, Pool.PoolSprinkler).build(null)); PoolSprinklerBlockEntity = Registry.register(Registry.BLOCK_ENTITY_TYPE, new Identifier(DecorativeMain.MOD_ID,"pool_sprinkler_blockentity"), BlockEntityType.Builder.create(PoolSprinklerBlockEntity::new, Pool.PoolSprinkler).build(null));
ShowerHeadBlockEntity = Registry.register(Registry.BLOCK_ENTITY_TYPE, new Identifier(DecorativeMain.MOD_ID,"shower_head_blockentity"), BlockEntityType.Builder.create(ShowerHeadBlockEntity::new, DecorativeMain.ShowerHead).build(null)); ShowerHeadBlockEntity = Registry.register(Registry.BLOCK_ENTITY_TYPE, new Identifier(DecorativeMain.MOD_ID,"shower_head_blockentity"), BlockEntityType.Builder.create(ShowerHeadBlockEntity::new, DecorativeMain.ShowerHead).build(null));
CeilingFanBlockEntity = Registry.register(Registry.BLOCK_ENTITY_TYPE, new Identifier(DecorativeMain.MOD_ID,"ceiling_fan_blockentity"), BlockEntityType.Builder.create(CeilingFanBlockEntity::new, DecorativeMain.CeilingFan).build(null)); CeilingFanBlockEntity = Registry.register(Registry.BLOCK_ENTITY_TYPE, new Identifier(DecorativeMain.MOD_ID,"ceiling_fan_blockentity"), BlockEntityType.Builder.create(CeilingFanBlockEntity::new, DecorativeMain.CeilingFan).build(null));
OakChoppingLogBlockEntity = Registry.register(Registry.BLOCK_ENTITY_TYPE, new Identifier(DecorativeMain.MOD_ID,"oak_chopping_log_blockentity"), BlockEntityType.Builder.create(OakChoppingLogBlockEntity::new, LogsWithAxes.OakChoppingLog).build(null)); ChoppingLogBlockEntity = Registry.register(Registry.BLOCK_ENTITY_TYPE, new Identifier(DecorativeMain.MOD_ID,"chopping_log_blockentity"), BlockEntityType.Builder.create(ChoppingLogBlockEntity::new, LogsWithAxes.OakChoppingLog, LogsWithAxes.BirchChoppingLog, LogsWithAxes.AcaciaChoppingLog, LogsWithAxes.DarkOakChoppingLog, LogsWithAxes.JungleChoppingLog, LogsWithAxes.SpruceChoppingLog).build(null));
SpruceChoppingLogBlockEntity = Registry.register(Registry.BLOCK_ENTITY_TYPE, new Identifier(DecorativeMain.MOD_ID,"spruce_chopping_log_blockentity"), BlockEntityType.Builder.create(SpruceChoppingLogBlockEntity::new, LogsWithAxes.SpruceChoppingLog).build(null)); WallClockBlockEntity = Registry.register(Registry.BLOCK_ENTITY_TYPE, new Identifier(DecorativeMain.MOD_ID,"wall_clock_blockentity"), BlockEntityType.Builder.create(WallClockBlockEntity::new, DecorativeMain.WallClock).build(null));
BirchChoppingLogBlockEntity = Registry.register(Registry.BLOCK_ENTITY_TYPE, new Identifier(DecorativeMain.MOD_ID,"birch_chopping_log_blockentity"), BlockEntityType.Builder.create(BirchChoppingLogBlockEntity::new, LogsWithAxes.BirchChoppingLog).build(null)); DigitalClockBlockEntity = Registry.register(Registry.BLOCK_ENTITY_TYPE, new Identifier(DecorativeMain.MOD_ID,"digital_clock_blockentity"), BlockEntityType.Builder.create(DigitalClockBlockEntity::new, Clocks.RedDigitalClock, Clocks.BlackDigitalClock, Clocks.BlueDigitalClock, Clocks.BrownDigitalClock, Clocks.CyanDigitalClock, Clocks.GrayDigitalClock, Clocks.GreenDigitalClock, Clocks.LightBlueDigitalClock, Clocks.LightGrayDigitalClock, Clocks.LimeDigitalClock, Clocks.MagentaDigitalClock, Clocks.OrangeDigitalClock, Clocks.PinkDigitalClock, Clocks.PurpleDigitalClock, Clocks.WhiteDigitalClock, Clocks.YellowDigitalClock).build(null));
AcaciaChoppingLogBlockEntity = Registry.register(Registry.BLOCK_ENTITY_TYPE, new Identifier(DecorativeMain.MOD_ID,"acacia_chopping_log_blockentity"), BlockEntityType.Builder.create(AcaciaChoppingLogBlockEntity::new, LogsWithAxes.AcaciaChoppingLog).build(null)); SmokeDetectorBlockEntity = Registry.register(Registry.BLOCK_ENTITY_TYPE, new Identifier(DecorativeMain.MOD_ID,"smoke_detector_blockentity"), BlockEntityType.Builder.create(SmokeDetectorBlockEntity::new, DecorativeMain.SmokeDetector).build(null));
JungleChoppingLogBlockEntity = Registry.register(Registry.BLOCK_ENTITY_TYPE, new Identifier(DecorativeMain.MOD_ID,"jungle_chopping_log_blockentity"), BlockEntityType.Builder.create(JungleChoppingLogBlockEntity::new, LogsWithAxes.JungleChoppingLog).build(null));
DarkOakChoppingLogBlockEntity = Registry.register(Registry.BLOCK_ENTITY_TYPE, new Identifier(DecorativeMain.MOD_ID,"dark_oak_chopping_log_blockentity"), BlockEntityType.Builder.create(DarkOakChoppingLogBlockEntity::new, LogsWithAxes.DarkOakChoppingLog).build(null));
} }
} }

View File

@@ -0,0 +1,63 @@
package eu.midnightdust.motschen.decorative.init;
import eu.midnightdust.motschen.decorative.DecorativeMain;
import eu.midnightdust.motschen.decorative.block.DigitalClock;
import net.minecraft.block.Block;
import net.minecraft.item.BlockItem;
import net.minecraft.item.Item;
import net.minecraft.util.Identifier;
import net.minecraft.util.registry.Registry;
public class Clocks {
public static Block WhiteDigitalClock = new DigitalClock();
public static Block OrangeDigitalClock = new DigitalClock();
public static Block MagentaDigitalClock = new DigitalClock();
public static Block LightBlueDigitalClock = new DigitalClock();
public static Block YellowDigitalClock = new DigitalClock();
public static Block LimeDigitalClock = new DigitalClock();
public static Block PinkDigitalClock = new DigitalClock();
public static Block GrayDigitalClock = new DigitalClock();
public static Block LightGrayDigitalClock = new DigitalClock();
public static Block CyanDigitalClock = new DigitalClock();
public static Block PurpleDigitalClock = new DigitalClock();
public static Block BlueDigitalClock = new DigitalClock();
public static Block BrownDigitalClock = new DigitalClock();
public static Block GreenDigitalClock = new DigitalClock();
public static Block RedDigitalClock = new DigitalClock();
public static Block BlackDigitalClock = new DigitalClock();
public static void init() {
Registry.register(Registry.BLOCK, new Identifier(DecorativeMain.MOD_ID,"white_digital_clock"), WhiteDigitalClock);
Registry.register(Registry.ITEM, new Identifier(DecorativeMain.MOD_ID,"white_digital_clock"), new BlockItem(WhiteDigitalClock, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Registry.register(Registry.BLOCK, new Identifier(DecorativeMain.MOD_ID,"orange_digital_clock"), OrangeDigitalClock);
Registry.register(Registry.ITEM, new Identifier(DecorativeMain.MOD_ID,"orange_digital_clock"), new BlockItem(OrangeDigitalClock, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Registry.register(Registry.BLOCK, new Identifier(DecorativeMain.MOD_ID,"magenta_digital_clock"), MagentaDigitalClock);
Registry.register(Registry.ITEM, new Identifier(DecorativeMain.MOD_ID,"magenta_digital_clock"), new BlockItem(MagentaDigitalClock, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Registry.register(Registry.BLOCK, new Identifier(DecorativeMain.MOD_ID,"light_blue_digital_clock"), LightBlueDigitalClock);
Registry.register(Registry.ITEM, new Identifier(DecorativeMain.MOD_ID,"light_blue_digital_clock"), new BlockItem(LightBlueDigitalClock, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Registry.register(Registry.BLOCK, new Identifier(DecorativeMain.MOD_ID,"yellow_digital_clock"), YellowDigitalClock);
Registry.register(Registry.ITEM, new Identifier(DecorativeMain.MOD_ID,"yellow_digital_clock"), new BlockItem(YellowDigitalClock, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Registry.register(Registry.BLOCK, new Identifier(DecorativeMain.MOD_ID,"lime_digital_clock"), LimeDigitalClock);
Registry.register(Registry.ITEM, new Identifier(DecorativeMain.MOD_ID,"lime_digital_clock"), new BlockItem(LimeDigitalClock, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Registry.register(Registry.BLOCK, new Identifier(DecorativeMain.MOD_ID,"pink_digital_clock"), PinkDigitalClock);
Registry.register(Registry.ITEM, new Identifier(DecorativeMain.MOD_ID,"pink_digital_clock"), new BlockItem(PinkDigitalClock, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Registry.register(Registry.BLOCK, new Identifier(DecorativeMain.MOD_ID,"gray_digital_clock"), GrayDigitalClock);
Registry.register(Registry.ITEM, new Identifier(DecorativeMain.MOD_ID,"gray_digital_clock"), new BlockItem(GrayDigitalClock, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Registry.register(Registry.BLOCK, new Identifier(DecorativeMain.MOD_ID,"light_gray_digital_clock"), LightGrayDigitalClock);
Registry.register(Registry.ITEM, new Identifier(DecorativeMain.MOD_ID,"light_gray_digital_clock"), new BlockItem(LightGrayDigitalClock, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Registry.register(Registry.BLOCK, new Identifier(DecorativeMain.MOD_ID,"cyan_digital_clock"), CyanDigitalClock);
Registry.register(Registry.ITEM, new Identifier(DecorativeMain.MOD_ID,"cyan_digital_clock"), new BlockItem(CyanDigitalClock, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Registry.register(Registry.BLOCK, new Identifier(DecorativeMain.MOD_ID,"purple_digital_clock"), PurpleDigitalClock);
Registry.register(Registry.ITEM, new Identifier(DecorativeMain.MOD_ID,"purple_digital_clock"), new BlockItem(PurpleDigitalClock, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Registry.register(Registry.BLOCK, new Identifier(DecorativeMain.MOD_ID,"blue_digital_clock"), BlueDigitalClock);
Registry.register(Registry.ITEM, new Identifier(DecorativeMain.MOD_ID,"blue_digital_clock"), new BlockItem(BlueDigitalClock, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Registry.register(Registry.BLOCK, new Identifier(DecorativeMain.MOD_ID,"brown_digital_clock"), BrownDigitalClock);
Registry.register(Registry.ITEM, new Identifier(DecorativeMain.MOD_ID,"brown_digital_clock"), new BlockItem(BrownDigitalClock, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Registry.register(Registry.BLOCK, new Identifier(DecorativeMain.MOD_ID,"green_digital_clock"), GreenDigitalClock);
Registry.register(Registry.ITEM, new Identifier(DecorativeMain.MOD_ID,"green_digital_clock"), new BlockItem(GreenDigitalClock, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Registry.register(Registry.BLOCK, new Identifier(DecorativeMain.MOD_ID,"red_digital_clock"), RedDigitalClock);
Registry.register(Registry.ITEM, new Identifier(DecorativeMain.MOD_ID,"red_digital_clock"), new BlockItem(RedDigitalClock, new Item.Settings().group(DecorativeMain.IndoorGroup)));
Registry.register(Registry.BLOCK, new Identifier(DecorativeMain.MOD_ID,"black_digital_clock"), BlackDigitalClock);
Registry.register(Registry.ITEM, new Identifier(DecorativeMain.MOD_ID,"black_digital_clock"), new BlockItem(BlackDigitalClock, new Item.Settings().group(DecorativeMain.IndoorGroup)));
}
}

View File

@@ -9,12 +9,12 @@ import net.minecraft.util.Identifier;
import net.minecraft.util.registry.Registry; import net.minecraft.util.registry.Registry;
public class LogsWithAxes { public class LogsWithAxes {
public static Block OakChoppingLog = new OakChoppingLog(); public static Block OakChoppingLog = new ChoppingLog();
public static Block SpruceChoppingLog = new SpruceChoppingLog(); public static Block SpruceChoppingLog = new ChoppingLog();
public static Block BirchChoppingLog = new BirchChoppingLog(); public static Block BirchChoppingLog = new ChoppingLog();
public static Block AcaciaChoppingLog = new AcaciaChoppingLog(); public static Block AcaciaChoppingLog = new ChoppingLog();
public static Block JungleChoppingLog = new JungleChoppingLog(); public static Block JungleChoppingLog = new ChoppingLog();
public static Block DarkOakChoppingLog = new DarkOakChoppingLog(); public static Block DarkOakChoppingLog = new ChoppingLog();
public static void init() { public static void init() {
Registry.register(Registry.BLOCK, new Identifier(DecorativeMain.MOD_ID,"oak_log_with_axe"), OakChoppingLog); Registry.register(Registry.BLOCK, new Identifier(DecorativeMain.MOD_ID,"oak_log_with_axe"), OakChoppingLog);

View File

@@ -16,7 +16,7 @@ import net.minecraft.util.TypedActionResult;
import net.minecraft.util.hit.BlockHitResult; import net.minecraft.util.hit.BlockHitResult;
import net.minecraft.util.hit.HitResult; import net.minecraft.util.hit.HitResult;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
import net.minecraft.world.RayTraceContext; import net.minecraft.world.RaycastContext;
import net.minecraft.world.World; import net.minecraft.world.World;
public class BathTireItem extends Item { public class BathTireItem extends Item {
@@ -31,7 +31,7 @@ public class BathTireItem extends Item {
public TypedActionResult<ItemStack> use(World world, PlayerEntity user, Hand hand) { public TypedActionResult<ItemStack> use(World world, PlayerEntity user, Hand hand) {
ItemStack itemStack = user.getStackInHand(hand); ItemStack itemStack = user.getStackInHand(hand);
HitResult hitResult = rayTrace(world, user, RayTraceContext.FluidHandling.SOURCE_ONLY); HitResult hitResult = raycast(world, user, RaycastContext.FluidHandling.SOURCE_ONLY);
if (hitResult.getType() != HitResult.Type.BLOCK) { if (hitResult.getType() != HitResult.Type.BLOCK) {
return TypedActionResult.pass(itemStack); return TypedActionResult.pass(itemStack);
} else if (world.isClient) { } else if (world.isClient) {

View File

@@ -6,6 +6,7 @@ import net.minecraft.util.registry.Registry;
public class DecorativeSoundEvents { public class DecorativeSoundEvents {
public static final SoundEvent CEILINGFAN_AMBIENT = register("decorative:ceiling_fan.ambient"); public static final SoundEvent CEILINGFAN_AMBIENT = register("decorative:ceiling_fan.ambient");
public static final SoundEvent SMOKE_DETECTOR_BEEP = register("decorative:smoke_detector.beep");
private static SoundEvent register(String id) { private static SoundEvent register(String id) {
return Registry.register(Registry.SOUND_EVENT, id, new SoundEvent(new Identifier(id))); return Registry.register(Registry.SOUND_EVENT, id, new SoundEvent(new Identifier(id)));

View File

@@ -9,7 +9,7 @@ import net.minecraft.world.gen.feature.Feature;
import net.minecraft.world.gen.feature.OreFeatureConfig; import net.minecraft.world.gen.feature.OreFeatureConfig;
public class OreFeatures { public class OreFeatures {
public static final ConfiguredFeature<?, ?> ROCKY_ASPHALT_FEATURE = Feature.ORE.configure(new OreFeatureConfig(OreFeatureConfig.Rules.BASE_STONE_OVERWORLD, DecorativeMain.RockyAsphalt.getDefaultState(), 7)).method_30377(200).spreadHorizontally().repeat(20); public static final ConfiguredFeature<?, ?> ROCKY_ASPHALT_FEATURE = Feature.ORE.configure(new OreFeatureConfig(OreFeatureConfig.Rules.BASE_STONE_OVERWORLD, DecorativeMain.RockyAsphalt.getDefaultState(), 7)).applyChance(200).spreadHorizontally().repeat(20);
public static void init() { public static void init() {
Registry.register(BuiltinRegistries.CONFIGURED_FEATURE, new Identifier(DecorativeMain.MOD_ID, "rocky_asphalt"), ROCKY_ASPHALT_FEATURE); Registry.register(BuiltinRegistries.CONFIGURED_FEATURE, new Identifier(DecorativeMain.MOD_ID, "rocky_asphalt"), ROCKY_ASPHALT_FEATURE);

View File

@@ -0,0 +1,8 @@
{
"variants": {
"facing=south": { "model": "decorative:block/black_digital_clock", "y": 180 },
"facing=west": { "model": "decorative:block/black_digital_clock", "y": 270 },
"facing=north": { "model": "decorative:block/black_digital_clock" },
"facing=east": { "model": "decorative:block/black_digital_clock", "y": 90 }
}
}

View File

@@ -0,0 +1,8 @@
{
"variants": {
"facing=south": { "model": "decorative:block/blue_digital_clock", "y": 180 },
"facing=west": { "model": "decorative:block/blue_digital_clock", "y": 270 },
"facing=north": { "model": "decorative:block/blue_digital_clock" },
"facing=east": { "model": "decorative:block/blue_digital_clock", "y": 90 }
}
}

View File

@@ -0,0 +1,8 @@
{
"variants": {
"facing=south": { "model": "decorative:block/brown_digital_clock", "y": 180 },
"facing=west": { "model": "decorative:block/brown_digital_clock", "y": 270 },
"facing=north": { "model": "decorative:block/brown_digital_clock" },
"facing=east": { "model": "decorative:block/brown_digital_clock", "y": 90 }
}
}

View File

@@ -0,0 +1,8 @@
{
"variants": {
"facing=south": { "model": "decorative:block/cyan_digital_clock", "y": 180 },
"facing=west": { "model": "decorative:block/cyan_digital_clock", "y": 270 },
"facing=north": { "model": "decorative:block/cyan_digital_clock" },
"facing=east": { "model": "decorative:block/cyan_digital_clock", "y": 90 }
}
}

View File

@@ -0,0 +1,8 @@
{
"variants": {
"facing=south": { "model": "decorative:block/gray_digital_clock", "y": 180 },
"facing=west": { "model": "decorative:block/gray_digital_clock", "y": 270 },
"facing=north": { "model": "decorative:block/gray_digital_clock" },
"facing=east": { "model": "decorative:block/gray_digital_clock", "y": 90 }
}
}

View File

@@ -0,0 +1,8 @@
{
"variants": {
"facing=south": { "model": "decorative:block/green_digital_clock", "y": 180 },
"facing=west": { "model": "decorative:block/green_digital_clock", "y": 270 },
"facing=north": { "model": "decorative:block/green_digital_clock" },
"facing=east": { "model": "decorative:block/green_digital_clock", "y": 90 }
}
}

View File

@@ -0,0 +1,8 @@
{
"variants": {
"facing=south": { "model": "decorative:block/light_blue_digital_clock", "y": 180 },
"facing=west": { "model": "decorative:block/light_blue_digital_clock", "y": 270 },
"facing=north": { "model": "decorative:block/light_blue_digital_clock" },
"facing=east": { "model": "decorative:block/light_blue_digital_clock", "y": 90 }
}
}

View File

@@ -0,0 +1,8 @@
{
"variants": {
"facing=south": { "model": "decorative:block/light_gray_digital_clock", "y": 180 },
"facing=west": { "model": "decorative:block/light_gray_digital_clock", "y": 270 },
"facing=north": { "model": "decorative:block/light_gray_digital_clock" },
"facing=east": { "model": "decorative:block/light_gray_digital_clock", "y": 90 }
}
}

View File

@@ -0,0 +1,8 @@
{
"variants": {
"facing=south": { "model": "decorative:block/lime_digital_clock", "y": 180 },
"facing=west": { "model": "decorative:block/lime_digital_clock", "y": 270 },
"facing=north": { "model": "decorative:block/lime_digital_clock" },
"facing=east": { "model": "decorative:block/lime_digital_clock", "y": 90 }
}
}

View File

@@ -0,0 +1,8 @@
{
"variants": {
"facing=south": { "model": "decorative:block/magenta_digital_clock", "y": 180 },
"facing=west": { "model": "decorative:block/magenta_digital_clock", "y": 270 },
"facing=north": { "model": "decorative:block/magenta_digital_clock" },
"facing=east": { "model": "decorative:block/magenta_digital_clock", "y": 90 }
}
}

View File

@@ -0,0 +1,8 @@
{
"variants": {
"facing=south": { "model": "decorative:block/orange_digital_clock", "y": 180 },
"facing=west": { "model": "decorative:block/orange_digital_clock", "y": 270 },
"facing=north": { "model": "decorative:block/orange_digital_clock" },
"facing=east": { "model": "decorative:block/orange_digital_clock", "y": 90 }
}
}

View File

@@ -0,0 +1,8 @@
{
"variants": {
"facing=south": { "model": "decorative:block/pink_digital_clock", "y": 180 },
"facing=west": { "model": "decorative:block/pink_digital_clock", "y": 270 },
"facing=north": { "model": "decorative:block/pink_digital_clock" },
"facing=east": { "model": "decorative:block/pink_digital_clock", "y": 90 }
}
}

View File

@@ -0,0 +1,8 @@
{
"variants": {
"facing=south": { "model": "decorative:block/purple_digital_clock", "y": 180 },
"facing=west": { "model": "decorative:block/purple_digital_clock", "y": 270 },
"facing=north": { "model": "decorative:block/purple_digital_clock" },
"facing=east": { "model": "decorative:block/purple_digital_clock", "y": 90 }
}
}

View File

@@ -0,0 +1,8 @@
{
"variants": {
"facing=south": { "model": "decorative:block/red_digital_clock", "y": 180 },
"facing=west": { "model": "decorative:block/red_digital_clock", "y": 270 },
"facing=north": { "model": "decorative:block/red_digital_clock" },
"facing=east": { "model": "decorative:block/red_digital_clock", "y": 90 }
}
}

View File

@@ -0,0 +1,6 @@
{
"variants": {
"active=true": { "model": "decorative:block/smoke_detector_on" },
"active=false": { "model": "decorative:block/smoke_detector_off" }
}
}

View File

@@ -0,0 +1,8 @@
{
"variants": {
"facing=south": { "model": "decorative:block/wall_clock", "y": 180 },
"facing=west": { "model": "decorative:block/wall_clock", "y": 270 },
"facing=north": { "model": "decorative:block/wall_clock" },
"facing=east": { "model": "decorative:block/wall_clock", "y": 90 }
}
}

View File

@@ -0,0 +1,8 @@
{
"variants": {
"facing=south": { "model": "decorative:block/white_digital_clock", "y": 180 },
"facing=west": { "model": "decorative:block/white_digital_clock", "y": 270 },
"facing=north": { "model": "decorative:block/white_digital_clock" },
"facing=east": { "model": "decorative:block/white_digital_clock", "y": 90 }
}
}

View File

@@ -0,0 +1,8 @@
{
"variants": {
"facing=south": { "model": "decorative:block/yellow_digital_clock", "y": 180 },
"facing=west": { "model": "decorative:block/yellow_digital_clock", "y": 270 },
"facing=north": { "model": "decorative:block/yellow_digital_clock" },
"facing=east": { "model": "decorative:block/yellow_digital_clock", "y": 90 }
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,14 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "decorative:block/red_lamp",
"material": "canvas:emissive_no_diffuse"
},
{
"sprite": "decorative:block/green_lamp",
"material": "canvas:emissive_no_diffuse"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,26 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "decorative:tv/nyancat",
"material": "canvas:emissive_no_diffuse"
},
{
"sprite": "decorative:tv/creeper",
"material": "canvas:emissive_no_diffuse"
},
{
"sprite": "decorative:tv/woodys",
"material": "canvas:emissive_no_diffuse"
},
{
"sprite": "decorative:tv/tater",
"material": "canvas:emissive_no_diffuse"
},
{
"sprite": "minecraft:block/lime_terracotta",
"material": "canvas:emissive_no_diffuse"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,22 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "decorative:tv/nyancat",
"material": "canvas:emissive_no_diffuse"
},
{
"sprite": "decorative:tv/creeper",
"material": "canvas:emissive_no_diffuse"
},
{
"sprite": "decorative:tv/woodys",
"material": "canvas:emissive_no_diffuse"
},
{
"sprite": "decorative:tv/tater",
"material": "canvas:emissive_no_diffuse"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,10 @@
{
"defaultMap": {
"spriteMap": [
{
"sprite": "minecraft:block/redstone_lamp_on",
"material": "canvas:warm_glow"
}
]
}
}

View File

@@ -0,0 +1,12 @@
{
"map": [
{
"predicate": {
"materialPredicate": {
"renderLayerName": "text"
}
},
"material": "canvas:emissive_transform"
}
]
}

View File

@@ -0,0 +1,6 @@
{
"parent": "decorative:block/digital_clock",
"textures": {
"2": "block/black_concrete"
}
}

View File

@@ -0,0 +1,6 @@
{
"parent": "decorative:block/digital_clock",
"textures": {
"2": "block/blue_concrete"
}
}

Some files were not shown because too many files have changed in this diff Show More