Skip to content

Commit

Permalink
feat:Computerized Redstone Link
Browse files Browse the repository at this point in the history
Push to v1.0.0-pre2.
  • Loading branch information
Sascha-T committed Jul 29, 2022
1 parent 4afbaa1 commit 8a0ac4e
Show file tree
Hide file tree
Showing 17 changed files with 747 additions and 6 deletions.
1 change: 1 addition & 0 deletions blockbench/computerized_redstone_link.bbmodel
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
{"meta":{"format_version":"4.0","model_format":"java_block","box_uv":false},"name":"computerized_redstone_link","parent":"","ambientocclusion":true,"front_gui_light":false,"visible_box":[1,1,0],"variable_placeholders":"","variable_placeholder_buttons":[],"resolution":{"width":16,"height":16},"elements":[{"name":"box","rescale":false,"locked":false,"from":[1,0,1],"to":[15,2,15],"autouv":0,"color":4,"origin":[0,0,0],"faces":{"north":{"uv":[0,0,14,2],"texture":1},"east":{"uv":[0,0,14,2],"texture":1},"south":{"uv":[0,0,14,2],"texture":1},"west":{"uv":[0,0,14,2],"texture":1},"up":{"uv":[1,1,15,15],"texture":2},"down":{"uv":[1,1,15,15],"texture":2}},"type":"cube","uuid":"6ab9df4b-2d79-ae67-a995-d407e4b7d2c7"},{"name":"stick","rescale":false,"locked":false,"from":[2,2,2],"to":[3,10,3],"autouv":0,"color":5,"origin":[0,0,0],"faces":{"north":{"uv":[1,2,2,10],"texture":3},"east":{"uv":[1,2,2,10],"texture":3},"south":{"uv":[1,2,2,10],"texture":3},"west":{"uv":[1,2,2,10],"texture":3},"up":{"uv":[2,1,3,2],"texture":3},"down":{"uv":[0,0,1,1]}},"type":"cube","uuid":"d08ca785-2762-01f9-742b-8dee066d3e84"},{"name":"dish","rescale":false,"locked":false,"from":[0,9,0],"to":[5,9,5],"autouv":0,"color":5,"origin":[0,0,0],"faces":{"north":{"uv":[0,0,5,0]},"east":{"uv":[0,0,5,0]},"south":{"uv":[0,0,5,0]},"west":{"uv":[0,0,5,0]},"up":{"uv":[4,0,9,5],"texture":3},"down":{"uv":[4,0,9,5],"texture":3}},"type":"cube","uuid":"4c22dbfc-d5b2-89e8-f050-ee0047022709"},{"name":"stick","rescale":false,"locked":false,"from":[8,2,2],"to":[9,10,3],"autouv":0,"color":5,"origin":[0,0,0],"faces":{"north":{"uv":[1,2,2,10],"texture":3},"east":{"uv":[1,2,2,10],"texture":3},"south":{"uv":[1,2,2,10],"texture":3},"west":{"uv":[1,2,2,10],"texture":3},"up":{"uv":[2,1,3,2],"texture":3},"down":{"uv":[0,0,1,1]}},"type":"cube","uuid":"fc51e6f3-164e-1115-fdb5-73e905ba937c"},{"name":"cube","rescale":false,"locked":false,"from":[2,-1,2],"to":[14,0,14],"autouv":0,"color":7,"origin":[0,0,0],"faces":{"north":{"uv":[0,0,12,1],"texture":4},"east":{"uv":[0,0,12,1],"texture":4},"south":{"uv":[0,0,12,1],"texture":4},"west":{"uv":[0,0,12,1],"texture":4},"up":{"uv":[0,0,12,12]},"down":{"uv":[0,0,10,10],"texture":4}},"type":"cube","uuid":"c54fec1f-a187-289c-d9ed-f15e8c0cd0a8"}],"outliner":[{"name":"antenna 1","origin":[0,0,0],"color":0,"nbt":"{}","armAnimationEnabled":false,"uuid":"388bde65-fb8b-a828-9d4c-843c267ea8da","export":true,"isOpen":true,"locked":false,"visibility":true,"autouv":0,"children":["fc51e6f3-164e-1115-fdb5-73e905ba937c","c54fec1f-a187-289c-d9ed-f15e8c0cd0a8"]},{"name":"antenna 1","origin":[0,0,0],"color":0,"nbt":"{}","armAnimationEnabled":false,"uuid":"8466190f-aa1e-0ffe-a0a8-ffe184a60eae","export":true,"isOpen":true,"locked":false,"visibility":true,"autouv":0,"children":["d08ca785-2762-01f9-742b-8dee066d3e84","4c22dbfc-d5b2-89e8-f050-ee0047022709"]},{"name":"VoxelShapes","origin":[0,0,0],"color":0,"nbt":"{}","armAnimationEnabled":false,"uuid":"45700195-9ab4-e25e-ca62-33988cc74b7d","export":true,"isOpen":true,"locked":false,"visibility":true,"autouv":0,"children":["6ab9df4b-2d79-ae67-a995-d407e4b7d2c7"]}],"textures":[{"path":"C:\\Users\\sasch\\Downloads\\Create-mc1.18-dev\\src\\main\\resources\\assets\\create\\textures\\block\\brass_casing_inner.png","name":"brass_casing_inner.png","folder":"block","namespace":"create","id":"0","particle":true,"render_mode":"default","visible":true,"mode":"bitmap","saved":true,"uuid":"5ee7dca0-8235-14e5-d9e7-f667bf2f9d55","relative_path":"../../../../Users/sasch/Downloads/Create-mc1.18-dev/src/main/resources/assets/create/textures/block/brass_casing_inner.png","source":""},{"path":"C:\\Users\\sasch\\Downloads\\Create-mc1.18-dev\\src\\main\\resources\\assets\\create\\textures\\block\\brass_casing_side.png","name":"brass_casing_side.png","folder":"block","namespace":"create","id":"1","particle":false,"render_mode":"default","visible":true,"mode":"bitmap","saved":true,"uuid":"82c1f331-ef7e-60bc-0d92-b5b64210cd0a","relative_path":"../../../../Users/sasch/Downloads/Create-mc1.18-dev/src/main/resources/assets/create/textures/block/brass_casing_side.png","source":""},{"path":"C:\\Users\\sasch\\Downloads\\Create-mc1.18-dev\\src\\main\\resources\\assets\\create\\textures\\block\\brass_casing.png","name":"brass_casing.png","folder":"block","namespace":"create","id":"2","particle":false,"render_mode":"default","visible":true,"mode":"bitmap","saved":true,"uuid":"7b89993d-b0bf-324e-b069-b035682425fc","relative_path":"../../../../Users/sasch/Downloads/Create-mc1.18-dev/src/main/resources/assets/create/textures/block/brass_casing.png","source":""},{"path":"C:\\Users\\sasch\\Downloads\\Create-mc1.18-dev\\src\\main\\resources\\assets\\create\\textures\\block\\redstone_antenna_powered.png","name":"redstone_antenna_powered.png","folder":"block","namespace":"create","id":"3","particle":false,"render_mode":"default","visible":true,"mode":"bitmap","saved":true,"uuid":"1ecdeba7-eef3-c37d-78bd-aadd28c24765","relative_path":"../../../../Users/sasch/Downloads/Create-mc1.18-dev/src/main/resources/assets/create/textures/block/redstone_antenna_powered.png","source":""},{"path":"C:\\Users\\sasch\\Downloads\\Create-mc1.18-dev\\src\\main\\resources\\assets\\create\\textures\\block\\filtered_detector_front.png","name":"filtered_detector_front.png","folder":"block","namespace":"create","id":"4","particle":false,"render_mode":"default","visible":true,"mode":"bitmap","saved":true,"uuid":"7e722d7e-ec58-46ac-43f0-f6b09c2de9d0","relative_path":"../../../../Users/sasch/Downloads/Create-mc1.18-dev/src/main/resources/assets/create/textures/block/filtered_detector_front.png","source":""}],"display":{"thirdperson_righthand":{"rotation":[75,45,0],"translation":[0,2.5,0],"scale":[0.375,0.375,0.375]},"thirdperson_lefthand":{"rotation":[75,45,0],"translation":[0,2.5,0],"scale":[0.375,0.375,0.375]},"firstperson_righthand":{"rotation":[0,45,0],"scale":[0.4,0.4,0.4]},"firstperson_lefthand":{"rotation":[0,225,0],"scale":[0.4,0.4,0.4]},"ground":{"translation":[0,3,0],"scale":[0.25,0.25,0.25]},"gui":{"rotation":[30,225,0],"scale":[0.625,0.625,0.625]},"fixed":{"scale":[0.5,0.5,0.5]}}}
2 changes: 1 addition & 1 deletion build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ plugins {
apply plugin: 'org.spongepowered.mixin'

group = 'de.saschat'
version = '1.0.0-pre1'
version = '1.0.0-pre2'

java {
archivesBaseName = 'createcomputing'
Expand Down
Original file line number Diff line number Diff line change
@@ -1,8 +1,11 @@
package de.saschat.createcomputing;

import com.mojang.logging.LogUtils;
import de.saschat.createcomputing.config.CreateComputingConfigServer;
import net.minecraftforge.common.MinecraftForge;
import net.minecraftforge.fml.ModLoadingContext;
import net.minecraftforge.fml.common.Mod;
import net.minecraftforge.fml.config.ModConfig;
import net.minecraftforge.fml.javafmlmod.FMLJavaModLoadingContext;
import org.slf4j.Logger;

Expand All @@ -13,6 +16,7 @@ public class CreateComputingMod {
public static final Logger LOGGER = LogUtils.getLogger();

public CreateComputingMod() {
ModLoadingContext.get().registerConfig(ModConfig.Type.SERVER, CreateComputingConfigServer.pair.getRight());
Registries.init(FMLJavaModLoadingContext.get().getModEventBus());
MinecraftForge.EVENT_BUS.register(this);
}
Expand Down
55 changes: 53 additions & 2 deletions src/main/java/de/saschat/createcomputing/Registries.java
Original file line number Diff line number Diff line change
@@ -1,16 +1,23 @@
package de.saschat.createcomputing;

import com.simibubi.create.Create;
import com.simibubi.create.content.logistics.IRedstoneLinkable;
import com.simibubi.create.content.logistics.RedstoneLinkNetworkHandler;
import com.simibubi.create.content.logistics.trains.management.edgePoint.TrackTargetingBlockItem;
import com.simibubi.create.foundation.utility.Couple;
import com.simibubi.create.repack.registrate.util.nullness.NonNullBiFunction;
import de.saschat.createcomputing.blocks.ComputerizedDisplaySourceBlock;
import de.saschat.createcomputing.blocks.ComputerizedDisplayTargetBlock;
import de.saschat.createcomputing.blocks.ComputerizedRedstoneLinkBlock;
import de.saschat.createcomputing.blocks.TrainNetworkObserverBlock;
import de.saschat.createcomputing.tiles.ComputerizedDisplaySourceTile;
import de.saschat.createcomputing.tiles.ComputerizedDisplayTargetTile;
import de.saschat.createcomputing.tiles.ComputerizedRedstoneLinkTile;
import de.saschat.createcomputing.tiles.TrainNetworkObserverTile;
import de.saschat.createcomputing.tiles.renderer.TrainNetworkObserverRenderer;
import net.minecraft.client.renderer.ItemBlockRenderTypes;
import net.minecraft.client.renderer.RenderType;
import net.minecraft.commands.Commands;
import net.minecraft.world.item.BlockItem;
import net.minecraft.world.item.CreativeModeTab;
import net.minecraft.world.item.Item;
Expand All @@ -19,6 +26,7 @@
import net.minecraft.world.level.block.entity.BlockEntity;
import net.minecraft.world.level.block.entity.BlockEntityType;
import net.minecraftforge.client.event.EntityRenderersEvent;
import net.minecraftforge.event.RegisterCommandsEvent;
import net.minecraftforge.eventbus.api.IEventBus;
import net.minecraftforge.eventbus.api.SubscribeEvent;
import net.minecraftforge.fml.common.Mod;
Expand All @@ -30,6 +38,8 @@
import net.minecraftforge.registries.RegistryObject;

import java.util.Arrays;
import java.util.Map;
import java.util.Set;
import java.util.function.Supplier;

public class Registries {
Expand Down Expand Up @@ -103,6 +113,22 @@ public ItemStack makeIcon() {
COMPUTERIZED_DISPLAY_TARGET
);

// Computerized Redstone Link
public static RegistryObject<Block> COMPUTERIZED_REDSTONE_LINK = registerBlock(
"computerized_redstone_link",
ComputerizedRedstoneLinkBlock::new
);
public static RegistryObject<Item> COMPUTERIZED_REDSTONE_LINK_ITEM = registerBlockItem(
"computerized_redstone_link",
COMPUTERIZED_REDSTONE_LINK,
new Item.Properties().tab(TAB)
);
public static RegistryObject<BlockEntityType<ComputerizedRedstoneLinkTile>> COMPUTERIZED_REDSTONE_LINK_TILE = registerTile(
"computerized_redstone_link",
ComputerizedRedstoneLinkTile::new,
COMPUTERIZED_REDSTONE_LINK
);

// Train Network Observer
public static RegistryObject<Block> TRAIN_NETWORK_OBSERVER = registerBlock(
"train_network_observer",
Expand All @@ -125,21 +151,46 @@ public ItemStack makeIcon() {
public static class RegistryEvents {
@SubscribeEvent
public static void fmlCommon(final FMLCommonSetupEvent blockRegistryEvent) {
// Register a new block here
CreateComputingMod.LOGGER.info("Registering all Create behaviours.");
Behaviours.register();
CreateComputingMod.LOGGER.info("Registered all Create behaviour.");
}

@SubscribeEvent
public static void fmlClient(final FMLClientSetupEvent blockRegistryEvent) {
ItemBlockRenderTypes.setRenderLayer(COMPUTERIZED_DISPLAY_TARGET.get(), RenderType.cutout());
ItemBlockRenderTypes.setRenderLayer(COMPUTERIZED_REDSTONE_LINK.get(), RenderType.cutout());
}

@SubscribeEvent
public static void modRenderer(final EntityRenderersEvent.RegisterRenderers event) {
event.registerBlockEntityRenderer(TRAIN_NETWORK_OBSERVER_TILE.get(), TrainNetworkObserverRenderer::new);
}
public static void modData(final GatherDataEvent event) {}
public static void modData(final GatherDataEvent event) {
}
}
@Mod.EventBusSubscriber(bus = Mod.EventBusSubscriber.Bus.FORGE)
public static class ForgeEvents {
@SubscribeEvent
public static void modCommands(final RegisterCommandsEvent event) {
System.out.println("REGISTER COMMANDS");
event.getDispatcher().register(
Commands.literal("redstone_link").executes(context -> {
Map<Couple<RedstoneLinkNetworkHandler.Frequency>, Set<IRedstoneLinkable>> coupleSetMap = Create.REDSTONE_LINK_NETWORK_HANDLER.networksIn(context.getSource().getLevel());
coupleSetMap.forEach((frequencies, iRedstoneLinkables) -> {
System.out.println("Frequency: " + frequencies.get(true).getStack().getItem().getRegistryName().toString() + ", " + frequencies.get(false).getStack().getItem().getRegistryName().toString());
for (IRedstoneLinkable iRedstoneLinkable : iRedstoneLinkables) {
System.out.println("\tAt " + iRedstoneLinkable.getLocation().toString() + ", listening: " + iRedstoneLinkable.isListening() + ", alive: " + iRedstoneLinkable.isAlive() + ", strength: " + iRedstoneLinkable.getTransmittedStrength());
}
});
return 0;
})
);
}


}



// Real loading
Expand Down
16 changes: 16 additions & 0 deletions src/main/java/de/saschat/createcomputing/Utils.java
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,29 @@

import net.minecraft.core.Direction;
import net.minecraft.nbt.*;
import net.minecraft.resources.ResourceLocation;
import net.minecraft.world.item.Item;
import net.minecraft.world.item.Items;
import net.minecraft.world.phys.shapes.Shapes;
import net.minecraft.world.phys.shapes.VoxelShape;
import net.minecraftforge.registries.ForgeRegistries;

import java.util.HashMap;
import java.util.Map;

public class Utils {
public static Item getByName(ResourceLocation loc) {
var itemRegistryObject = ForgeRegistries.ITEMS.getEntries().stream().filter(a -> {
return a.getValue().getRegistryName().equals(loc);
}).findFirst().orElseGet(() -> null);
if (itemRegistryObject == null)
return Items.AIR;
return itemRegistryObject.getValue();
}

public interface Receiver<T> {
void receive(T a);
}
public static VoxelShape rotate(Direction from, Direction to, VoxelShape shape) {
VoxelShape[] buffer = new VoxelShape[]{ shape, Shapes.empty() };

Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
package de.saschat.createcomputing.blocks;

import com.simibubi.create.foundation.block.ITE;
import de.saschat.createcomputing.Registries;
import de.saschat.createcomputing.tiles.ComputerizedRedstoneLinkTile;
import net.minecraft.core.BlockPos;
import net.minecraft.world.level.BlockGetter;
import net.minecraft.world.level.block.Block;
import net.minecraft.world.level.block.entity.BlockEntityType;
import net.minecraft.world.level.block.state.BlockBehaviour;
import net.minecraft.world.level.block.state.BlockState;
import net.minecraft.world.level.material.Material;
import net.minecraft.world.phys.shapes.CollisionContext;
import net.minecraft.world.phys.shapes.VoxelShape;

public class ComputerizedRedstoneLinkBlock extends Block implements ITE<ComputerizedRedstoneLinkTile> {
public ComputerizedRedstoneLinkBlock() {
super(BlockBehaviour.Properties.of(Material.WOOD));
}

@Override
public Class<ComputerizedRedstoneLinkTile> getTileEntityClass() {
return ComputerizedRedstoneLinkTile.class;
}

@Override
public BlockEntityType<? extends ComputerizedRedstoneLinkTile> getTileEntityType() {
return Registries.COMPUTERIZED_REDSTONE_LINK_TILE.get();
}


@Override
public VoxelShape getShape(BlockState p_60555_, BlockGetter p_60556_, BlockPos p_60557_, CollisionContext p_60558_) {
return box(
1,0,1,15,2,15
);
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
package de.saschat.createcomputing.config;

import net.minecraft.resources.ResourceLocation;
import net.minecraftforge.common.ForgeConfigSpec;
import net.minecraftforge.common.ForgeConfigSpec.*;
import org.apache.commons.lang3.tuple.Pair;

import java.util.List;

public class CreateComputingConfigServer {
public ConfigValue<List<String>> BANNED_LINK_ITEMS;
public LongValue MAXIMUM_CONCURRENT_LINKS;

public CreateComputingConfigServer(ForgeConfigSpec.Builder builder) {
BANNED_LINK_ITEMS = builder.comment("These are the items the computerized redstone link cannot use.").define(
"computerized_redstone_link.banned_link_items",
List.of(
new ResourceLocation("minecraft", "dragon_egg").toString(),
new ResourceLocation("minecraft", "nether_star").toString()
)
);
MAXIMUM_CONCURRENT_LINKS = builder.comment("This is the maximum amount of concurrent handles one computerized redstone link is allowed ot have.").defineInRange(
"computerized_redstone_link.maximum_concurrent_links",
8,
1,
Long.MAX_VALUE
);

}

public static Pair<CreateComputingConfigServer, ForgeConfigSpec> pair = new ForgeConfigSpec.Builder()
.configure(CreateComputingConfigServer::new);

public static CreateComputingConfigServer get() {
return pair.getLeft();
}
}
Loading

0 comments on commit 8a0ac4e

Please sign in to comment.