Added ship core & ship controller blockstate properties

This commit is contained in:
Unknown 2018-06-03 10:28:30 +02:00 committed by unknown
parent 67bec007d0
commit 9ae55b3f31
7 changed files with 277 additions and 32 deletions

View file

@ -85,6 +85,23 @@ public abstract class TileEntityAbstractBase extends TileEntity implements IBloc
} }
} }
protected void updateBlockState(final IBlockState blockState_in, @Nonnull final IBlockState blockState_new) {
IBlockState blockState_old = blockState_in;
if (blockState_old == null) {
blockState_old = worldObj.getBlockState(pos);
}
try {
final int metadata_old = blockState_old.getBlock().getMetaFromState(blockState_old);
final int metadata_new = blockState_new.getBlock().getMetaFromState(blockState_new);
if (metadata_old != metadata_new) {
worldObj.setBlockState(pos, blockState_new, 2);
}
} catch (Exception exception) {
exception.printStackTrace();
WarpDrive.logger.error("Exception in " + this);
}
}
@Deprecated @Deprecated
protected void updateMetadata(final int metadata) { protected void updateMetadata(final int metadata) {
if (getBlockMetadata() != metadata) { if (getBlockMetadata() != metadata) {

View file

@ -3,11 +3,14 @@ package cr0s.warpdrive.block.movement;
import cr0s.warpdrive.Commons; import cr0s.warpdrive.Commons;
import cr0s.warpdrive.WarpDrive; import cr0s.warpdrive.WarpDrive;
import cr0s.warpdrive.block.BlockAbstractContainer; import cr0s.warpdrive.block.BlockAbstractContainer;
import cr0s.warpdrive.data.EnumShipControllerCommand;
import javax.annotation.Nonnull; import javax.annotation.Nonnull;
import javax.annotation.Nullable; import javax.annotation.Nullable;
import net.minecraft.block.material.Material; import net.minecraft.block.material.Material;
import net.minecraft.block.properties.PropertyEnum;
import net.minecraft.block.state.BlockStateContainer;
import net.minecraft.block.state.IBlockState; import net.minecraft.block.state.IBlockState;
import net.minecraft.entity.player.EntityPlayer; import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.item.ItemStack; import net.minecraft.item.ItemStack;
@ -21,12 +24,37 @@ import net.minecraftforge.fml.common.registry.GameRegistry;
public class BlockShipController extends BlockAbstractContainer { public class BlockShipController extends BlockAbstractContainer {
public static final PropertyEnum<EnumShipControllerCommand> COMMAND = PropertyEnum.create("command", EnumShipControllerCommand.class);
public BlockShipController(final String registryName) { public BlockShipController(final String registryName) {
super(registryName, Material.IRON); super(registryName, Material.IRON);
setUnlocalizedName("warpdrive.movement.ship_controller"); setUnlocalizedName("warpdrive.movement.ship_controller");
setDefaultState(getDefaultState()
.withProperty(COMMAND, EnumShipControllerCommand.OFFLINE)
);
GameRegistry.registerTileEntity(TileEntityShipController.class, WarpDrive.PREFIX + registryName); GameRegistry.registerTileEntity(TileEntityShipController.class, WarpDrive.PREFIX + registryName);
} }
@Nonnull
@Override
protected BlockStateContainer createBlockState() {
return new BlockStateContainer(this, COMMAND);
}
@SuppressWarnings("deprecation")
@Nonnull
@Override
public IBlockState getStateFromMeta(final int metadata) {
return getDefaultState()
.withProperty(COMMAND, EnumShipControllerCommand.get(metadata));
}
@Override
public int getMetaFromState(final IBlockState blockState) {
return blockState.getValue(COMMAND).ordinal();
}
@Nonnull @Nonnull
@Override @Override
public TileEntity createNewTileEntity(@Nonnull final World world, final int metadata) { public TileEntity createNewTileEntity(@Nonnull final World world, final int metadata) {

View file

@ -111,9 +111,6 @@ public class TileEntityShipController extends TileEntityAbstractInterfaced imple
tileEntityShipCoreWeakReference = new WeakReference<>(tileEntityShipCore); tileEntityShipCoreWeakReference = new WeakReference<>(tileEntityShipCore);
} }
if (command.getCode() != getBlockMetadata()) {
updateMetadata(command.getCode()); // Activated
}
if ( isPendingScan if ( isPendingScan
&& tileEntityShipCore.isAttached(this) ) { && tileEntityShipCore.isAttached(this) ) {
isPendingScan = false; isPendingScan = false;
@ -127,9 +124,9 @@ public class TileEntityShipController extends TileEntityAbstractInterfaced imple
WarpDrive.logger.info(this + " Exception in validateShipSpatialParameters, reason: " + reason.toString()); WarpDrive.logger.info(this + " Exception in validateShipSpatialParameters, reason: " + reason.toString());
} }
} }
} else if (getBlockMetadata() != 0) {
updateMetadata(0); // Inactive
} }
updateBlockState(null, BlockShipController.COMMAND, command);
} }
} }
@ -359,7 +356,7 @@ public class TileEntityShipController extends TileEntityAbstractInterfaced imple
markDirty(); markDirty();
if (WarpDriveConfig.LOGGING_LUA && hasWorldObj()) { if (WarpDriveConfig.LOGGING_LUA && hasWorldObj()) {
WarpDrive.logger.info(String.format("%s Command set to %s (%d)", WarpDrive.logger.info(String.format("%s Command set to %s (%d)",
this, this.command, this.command.getCode())); this, this.command, this.command.ordinal()));
} }
} }
} }
@ -371,7 +368,7 @@ public class TileEntityShipController extends TileEntityAbstractInterfaced imple
if (!success) { if (!success) {
final TileEntityShipCore tileEntityShipCore = tileEntityShipCoreWeakReference == null ? null : tileEntityShipCoreWeakReference.get(); final TileEntityShipCore tileEntityShipCore = tileEntityShipCoreWeakReference == null ? null : tileEntityShipCoreWeakReference.get();
if (tileEntityShipCore != null) { if (tileEntityShipCore != null) {
tileEntityShipCore.messageToAllPlayersOnShip(new TextComponentString(reason.toString())); tileEntityShipCore.messageToAllPlayersOnShip(new TextComponentString(reason));
} }
} }
} }

View file

@ -7,6 +7,7 @@ import cr0s.warpdrive.block.TileEntityAbstractEnergy;
import cr0s.warpdrive.config.Dictionary; import cr0s.warpdrive.config.Dictionary;
import cr0s.warpdrive.config.ShipMovementCosts; import cr0s.warpdrive.config.ShipMovementCosts;
import cr0s.warpdrive.config.WarpDriveConfig; import cr0s.warpdrive.config.WarpDriveConfig;
import cr0s.warpdrive.data.BlockProperties;
import cr0s.warpdrive.data.CelestialObjectManager; import cr0s.warpdrive.data.CelestialObjectManager;
import cr0s.warpdrive.data.EnumShipControllerCommand; import cr0s.warpdrive.data.EnumShipControllerCommand;
import cr0s.warpdrive.data.EnumShipCoreState; import cr0s.warpdrive.data.EnumShipCoreState;
@ -135,8 +136,8 @@ public class TileEntityShipCore extends TileEntityAbstractEnergy implements ISta
} }
TileEntityShipController tileEntityShipController = tileEntityShipControllerWeakReference == null ? null : tileEntityShipControllerWeakReference.get(); TileEntityShipController tileEntityShipController = tileEntityShipControllerWeakReference == null ? null : tileEntityShipControllerWeakReference.get();
if ( tileEntityShipController != null if (tileEntityShipController != null
&& tileEntityShipController.isInvalid() ) { && tileEntityShipController.isInvalid()) {
tileEntityShipControllerWeakReference = null; tileEntityShipControllerWeakReference = null;
tileEntityShipController = null; tileEntityShipController = null;
} }
@ -169,11 +170,6 @@ public class TileEntityShipCore extends TileEntityAbstractEnergy implements ISta
} }
} }
// Refresh rendering
if (getBlockMetadata() != stateCurrent.getMetadata()) {
updateMetadata(stateCurrent.getMetadata());
}
// accelerate update ticks during boot // accelerate update ticks during boot
if (bootTicks > 0) { if (bootTicks > 0) {
bootTicks--; bootTicks--;
@ -211,9 +207,9 @@ public class TileEntityShipCore extends TileEntityAbstractEnergy implements ISta
this, this,
stateCurrent, stateCurrent,
tileEntityShipController == null ? "NA" : tileEntityShipController.isEnabled, tileEntityShipController == null ? "NA" : tileEntityShipController.isEnabled,
tileEntityShipController, tileEntityShipController,
warmupTime_ticks, warmupTime_ticks,
cooldownTime_ticks)); cooldownTime_ticks));
} }
} }
@ -224,6 +220,12 @@ public class TileEntityShipCore extends TileEntityAbstractEnergy implements ISta
updateIsolationState(); updateIsolationState();
} }
// Refresh rendering
final boolean isActive = stateCurrent != EnumShipCoreState.DISCONNECTED
&& tileEntityShipController != null
&& commandCurrent != EnumShipControllerCommand.OFFLINE;
updateBlockState(null, BlockProperties.ACTIVE, isActive);
if (tileEntityShipController == null) { if (tileEntityShipController == null) {
return; return;
} }

View file

@ -1,23 +1,45 @@
package cr0s.warpdrive.data; package cr0s.warpdrive.data;
public enum EnumShipControllerCommand { import javax.annotation.Nonnull;
import java.util.HashMap;
import net.minecraft.util.IStringSerializable;
public enum EnumShipControllerCommand implements IStringSerializable {
OFFLINE(0), // Offline allows to move sub-ships OFFLINE ("offline"), // Offline allows to move sub-ships
IDLE(1), IDLE ("idle"), //
MANUAL(2), // Move ship around including take off and landing MANUAL ("manual"), // Move ship around including take off and landing
// AUTOPILOT(3), // Move ship towards a far destination // AUTOPILOT("autopilot"), // Move ship towards a far destination
SUMMON(4), // Summoning crew SUMMON ("summon"), // Summoning crew
HYPERDRIVE(5), // Jump to/from Hyperspace HYPERDRIVE ("hyperdrive"), // Jump to/from Hyperspace
GATE(6), // Jump via jumpgate GATE ("gate"), // Jump via jumpgate
MAINTENANCE(7); // Maintenance mode MAINTENANCE ("maintenance"); // Maintenance mode
private final int code; private final String name;
EnumShipControllerCommand(final int code) { // cached values
this.code = code; public static final int length;
private static final HashMap<Integer, EnumShipControllerCommand> ID_MAP = new HashMap<>();
static {
length = EnumShipControllerCommand.values().length;
for (final EnumShipControllerCommand forceFieldShape : values()) {
ID_MAP.put(forceFieldShape.ordinal(), forceFieldShape);
}
} }
public int getCode() { EnumShipControllerCommand(final String name) {
return code; this.name = name;
}
public static EnumShipControllerCommand get(final int damage) {
return ID_MAP.get(damage);
}
@Nonnull
@Override
public String getName() {
return name;
} }
} }

View file

@ -0,0 +1,54 @@
{
"forge_marker": 1,
"defaults": {
"model": "minecraft:cube_bottom_top",
"textures": {
"side" : "warpdrive:blocks/movement/ship_controller-side_inactive",
"bottom": "warpdrive:blocks/movement/ship_controller-bottom",
"top" : "warpdrive:blocks/movement/ship_controller-top"
},
"transform": "forge:default-block"
},
"variants": {
"normal": [{}],
"inventory": [{}],
"command": {
"offline": {},
"idle": {
"textures": {
"side" : "warpdrive:blocks/movement/ship_controller-side_active0"
}
},
"manual": {
"textures": {
"side" : "warpdrive:blocks/movement/ship_controller-side_active1"
}
},
"autopilot": {
"textures": {
"side" : "warpdrive:blocks/movement/ship_controller-side_active2"
}
},
"summon": {
"textures": {
"side" : "warpdrive:blocks/movement/ship_controller-side_active3"
}
},
"hyperdrive": {
"textures": {
"side" : "warpdrive:blocks/movement/ship_controller-side_active4"
}
},
"gate": {
"textures": {
"side" : "warpdrive:blocks/movement/ship_controller-side_active5"
}
},
"maintenance": {
"textures": {
"side" : "warpdrive:blocks/movement/ship_controller-side_active7"
}
}
}
}
}

View file

@ -0,0 +1,125 @@
{
"forge_marker": 1,
"variants": {
"normal": [{}],
"inventory": { "model": "minecraft:cube", "textures": {
"particle": "warpdrive:blocks/movement/ship_core-top-bottom",
"down" : "warpdrive:blocks/movement/ship_core-top-bottom",
"up" : "warpdrive:blocks/movement/ship_core-top-bottom",
"north" : "warpdrive:blocks/movement/ship_core-right_online",
"south" : "warpdrive:blocks/movement/ship_core-left_online",
"west" : "warpdrive:blocks/movement/ship_controller-top",
"east" : "warpdrive:blocks/movement/ship_controller-side_active2"
} },
"active=false,facing=down" : { "model": "minecraft:cube", "textures": {
"particle": "warpdrive:blocks/movement/ship_core-top-bottom",
"down" : "warpdrive:blocks/movement/ship_core-top-bottom",
"up" : "warpdrive:blocks/movement/ship_core-top-bottom",
"north" : "warpdrive:blocks/movement/ship_controller-side_inactive",
"south" : "warpdrive:blocks/movement/ship_controller-side_inactive",
"west" : "warpdrive:blocks/movement/ship_controller-side_inactive",
"east" : "warpdrive:blocks/movement/ship_controller-side_inactive"
} },
"active=false,facing=up" : { "model": "minecraft:cube", "textures": {
"particle": "warpdrive:blocks/movement/ship_core-top-bottom",
"down" : "warpdrive:blocks/movement/ship_core-top-bottom",
"up" : "warpdrive:blocks/movement/ship_core-top-bottom",
"north" : "warpdrive:blocks/movement/ship_controller-side_inactive",
"south" : "warpdrive:blocks/movement/ship_controller-side_inactive",
"west" : "warpdrive:blocks/movement/ship_controller-side_inactive",
"east" : "warpdrive:blocks/movement/ship_controller-side_inactive"
} },
"active=false,facing=north": { "model": "minecraft:cube", "textures": {
"particle": "warpdrive:blocks/movement/ship_core-top-bottom",
"down" : "warpdrive:blocks/movement/ship_core-top-bottom",
"up" : "warpdrive:blocks/movement/ship_core-top-bottom",
"north" : "warpdrive:blocks/movement/ship_controller-top",
"south" : "warpdrive:blocks/movement/ship_controller-side_active1",
"west" : "warpdrive:blocks/movement/ship_core-left_offline",
"east" : "warpdrive:blocks/movement/ship_core-right_offline"
} },
"active=false,facing=south": { "model": "minecraft:cube", "textures": {
"particle": "warpdrive:blocks/movement/ship_core-top-bottom",
"down" : "warpdrive:blocks/movement/ship_core-top-bottom",
"up" : "warpdrive:blocks/movement/ship_core-top-bottom",
"north" : "warpdrive:blocks/movement/ship_controller-side_active2",
"south" : "warpdrive:blocks/movement/ship_controller-top",
"west" : "warpdrive:blocks/movement/ship_core-right_offline",
"east" : "warpdrive:blocks/movement/ship_core-left_offline"
} },
"active=false,facing=west" : { "model": "minecraft:cube", "textures": {
"particle": "warpdrive:blocks/movement/ship_core-top-bottom",
"down" : "warpdrive:blocks/movement/ship_core-top-bottom",
"up" : "warpdrive:blocks/movement/ship_core-top-bottom",
"north" : "warpdrive:blocks/movement/ship_core-right_offline",
"south" : "warpdrive:blocks/movement/ship_core-left_offline",
"west" : "warpdrive:blocks/movement/ship_controller-top",
"east" : "warpdrive:blocks/movement/ship_controller-side_active3"
} },
"active=false,facing=east" : { "model": "minecraft:cube", "textures": {
"particle": "warpdrive:blocks/movement/ship_core-top-bottom",
"down" : "warpdrive:blocks/movement/ship_core-top-bottom",
"up" : "warpdrive:blocks/movement/ship_core-top-bottom",
"north" : "warpdrive:blocks/movement/ship_core-left_offline",
"south" : "warpdrive:blocks/movement/ship_core-right_offline",
"west" : "warpdrive:blocks/movement/ship_controller-side_active4",
"east" : "warpdrive:blocks/movement/ship_controller-top"
} },
"active=true,facing=down" : { "model": "minecraft:cube", "textures": {
"particle": "warpdrive:blocks/movement/ship_core-top-bottom",
"down" : "warpdrive:blocks/movement/ship_core-top-bottom",
"up" : "warpdrive:blocks/movement/ship_core-top-bottom",
"north" : "warpdrive:blocks/movement/ship_controller-side_inactive",
"south" : "warpdrive:blocks/movement/ship_controller-side_inactive",
"west" : "warpdrive:blocks/movement/ship_controller-side_inactive",
"east" : "warpdrive:blocks/movement/ship_controller-side_inactive"
} },
"active=true,facing=up" : { "model": "minecraft:cube", "textures": {
"particle": "warpdrive:blocks/movement/ship_core-top-bottom",
"down" : "warpdrive:blocks/movement/ship_core-top-bottom",
"up" : "warpdrive:blocks/movement/ship_core-top-bottom",
"north" : "warpdrive:blocks/movement/ship_controller-side_inactive",
"south" : "warpdrive:blocks/movement/ship_controller-side_inactive",
"west" : "warpdrive:blocks/movement/ship_controller-side_inactive",
"east" : "warpdrive:blocks/movement/ship_controller-side_inactive"
} },
"active=true,facing=north": { "model": "minecraft:cube", "textures": {
"particle": "warpdrive:blocks/movement/ship_core-top-bottom",
"down" : "warpdrive:blocks/movement/ship_core-top-bottom",
"up" : "warpdrive:blocks/movement/ship_core-top-bottom",
"north" : "warpdrive:blocks/movement/ship_controller-top",
"south" : "warpdrive:blocks/movement/ship_controller-side_active1",
"west" : "warpdrive:blocks/movement/ship_core-left_online",
"east" : "warpdrive:blocks/movement/ship_core-right_online"
} },
"active=true,facing=south": { "model": "minecraft:cube", "textures": {
"particle": "warpdrive:blocks/movement/ship_core-top-bottom",
"down" : "warpdrive:blocks/movement/ship_core-top-bottom",
"up" : "warpdrive:blocks/movement/ship_core-top-bottom",
"north" : "warpdrive:blocks/movement/ship_controller-side_active2",
"south" : "warpdrive:blocks/movement/ship_controller-top",
"west" : "warpdrive:blocks/movement/ship_core-right_online",
"east" : "warpdrive:blocks/movement/ship_core-left_online"
} },
"active=true,facing=west" : { "model": "minecraft:cube", "textures": {
"particle": "warpdrive:blocks/movement/ship_core-top-bottom",
"down" : "warpdrive:blocks/movement/ship_core-top-bottom",
"up" : "warpdrive:blocks/movement/ship_core-top-bottom",
"north" : "warpdrive:blocks/movement/ship_core-right_online",
"south" : "warpdrive:blocks/movement/ship_core-left_online",
"west" : "warpdrive:blocks/movement/ship_controller-top",
"east" : "warpdrive:blocks/movement/ship_controller-side_active3"
} },
"active=true,facing=east" : { "model": "minecraft:cube", "textures": {
"particle": "warpdrive:blocks/movement/ship_core-top-bottom",
"down" : "warpdrive:blocks/movement/ship_core-top-bottom",
"up" : "warpdrive:blocks/movement/ship_core-top-bottom",
"north" : "warpdrive:blocks/movement/ship_core-left_online",
"south" : "warpdrive:blocks/movement/ship_core-right_online",
"west" : "warpdrive:blocks/movement/ship_controller-side_active4",
"east" : "warpdrive:blocks/movement/ship_controller-top"
} }
}
}