even more porty?

This commit is contained in:
grimmauld 2020-09-22 22:00:44 +02:00
parent fe92f8fb41
commit f01aeee43e
20 changed files with 167 additions and 149 deletions

View file

@ -1004,7 +1004,7 @@ public class AllBlocks {
.register(); .register();
public static final BlockEntry<OxidizingBlock> COPPER_BLOCK = public static final BlockEntry<OxidizingBlock> COPPER_BLOCK =
REGISTRATE.block("copper_block", p -> new OxidizingBlock(p, 1 / 32f, true)) REGISTRATE.block("copper_block", p -> new OxidizingBlock(p, 1 / 32f))
.initialProperties(() -> Blocks.IRON_BLOCK) .initialProperties(() -> Blocks.IRON_BLOCK)
.transform(tagBlockAndItem("storage_blocks/copper")) .transform(tagBlockAndItem("storage_blocks/copper"))
.transform(oxidizedItemModel()) .transform(oxidizedItemModel())
@ -1027,14 +1027,14 @@ public class AllBlocks {
.transform(oxidizedBlockstate()) .transform(oxidizedBlockstate())
.register(); .register();
public static final BlockEntry<MetalBlock> ZINC_BLOCK = REGISTRATE.block("zinc_block", p -> new MetalBlock(p, true)) public static final BlockEntry<Block> ZINC_BLOCK = REGISTRATE.block("zinc_block", p -> new Block(p))
.initialProperties(() -> Blocks.IRON_BLOCK) .initialProperties(() -> Blocks.IRON_BLOCK)
.transform(tagBlockAndItem("storage_blocks/zinc")) .transform(tagBlockAndItem("storage_blocks/zinc"))
.build() .build()
.register(); .register();
public static final BlockEntry<MetalBlock> BRASS_BLOCK = public static final BlockEntry<Block> BRASS_BLOCK =
REGISTRATE.block("brass_block", p -> new MetalBlock(p, true)) REGISTRATE.block("brass_block", p -> new Block(p))
.initialProperties(() -> Blocks.IRON_BLOCK) .initialProperties(() -> Blocks.IRON_BLOCK)
.transform(tagBlockAndItem("storage_blocks/brass")) .transform(tagBlockAndItem("storage_blocks/brass"))
.build() .build()

View file

@ -22,6 +22,7 @@ import com.simibubi.create.foundation.utility.FilesHelper;
import com.simibubi.create.foundation.utility.Lang; import com.simibubi.create.foundation.utility.Lang;
import net.minecraft.client.Minecraft; import net.minecraft.client.Minecraft;
import net.minecraft.util.text.ITextComponent;
import net.minecraft.util.text.StringTextComponent; import net.minecraft.util.text.StringTextComponent;
import net.minecraftforge.api.distmarker.Dist; import net.minecraftforge.api.distmarker.Dist;
import net.minecraftforge.api.distmarker.OnlyIn; import net.minecraftforge.api.distmarker.OnlyIn;
@ -31,7 +32,7 @@ public class ClientSchematicLoader {
public static final int PACKET_DELAY = 10; public static final int PACKET_DELAY = 10;
private List<String> availableSchematics; private List<ITextComponent> availableSchematics;
private Map<String, InputStream> activeUploads; private Map<String, InputStream> activeUploads;
private int packetCycle; private int packetCycle;
@ -68,10 +69,8 @@ public class ClientSchematicLoader {
// Too big // Too big
Integer maxSize = AllConfigs.SERVER.schematics.maxTotalSchematicSize.get(); Integer maxSize = AllConfigs.SERVER.schematics.maxTotalSchematicSize.get();
if (size > maxSize * 1000) { if (size > maxSize * 1000) {
Minecraft.getInstance().player.sendMessage(new StringTextComponent( Minecraft.getInstance().player.sendMessage(Lang.translate("schematics.uploadTooLarge").append(" (" + size / 1000 + " KB)."), Minecraft.getInstance().player.getUniqueID());
Lang.translate("schematics.uploadTooLarge") + " (" + size / 1000 + " KB).")); Minecraft.getInstance().player.sendMessage(Lang.translate("schematics.maxAllowedSize").append(" " + maxSize + " KB"), Minecraft.getInstance().player.getUniqueID());
Minecraft.getInstance().player.sendMessage(
new StringTextComponent(Lang.translate("schematics.maxAllowedSize") + " " + maxSize + " KB"));
return; return;
} }
@ -126,7 +125,7 @@ public class ClientSchematicLoader {
if (Files.isDirectory(path)) if (Files.isDirectory(path))
return; return;
availableSchematics.add(path.getFileName().toString()); availableSchematics.add(ITextComponent.of(path.getFileName().toString()));
}); });
} catch (NoSuchFileException e) { } catch (NoSuchFileException e) {
// No Schematics created yet // No Schematics created yet
@ -136,7 +135,7 @@ public class ClientSchematicLoader {
} }
public List<String> getAvailableSchematics() { public List<ITextComponent> getAvailableSchematics() {
return availableSchematics; return availableSchematics;
} }

View file

@ -4,6 +4,7 @@ import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.List; import java.util.List;
import com.simibubi.create.foundation.utility.BlockHelper;
import net.minecraft.block.*; import net.minecraft.block.*;
import net.minecraft.entity.Entity; import net.minecraft.entity.Entity;
import net.minecraft.entity.EntityType; import net.minecraft.entity.EntityType;
@ -49,7 +50,7 @@ public class ItemRequirement {
Item item = BlockItem.BLOCK_TO_ITEM.getOrDefault(state.getBlock(), Items.AIR); Item item = BlockItem.BLOCK_TO_ITEM.getOrDefault(state.getBlock(), Items.AIR);
// double slab needs two items // double slab needs two items
if (state.has(BlockStateProperties.SLAB_TYPE) && state.get(BlockStateProperties.SLAB_TYPE) == SlabType.DOUBLE) if (BlockHelper.hasBlockStateProperty(state, BlockStateProperties.SLAB_TYPE) && state.get(BlockStateProperties.SLAB_TYPE) == SlabType.DOUBLE)
return new ItemRequirement(ItemUseType.CONSUME, Arrays.asList(new ItemStack(item, 2))); return new ItemRequirement(ItemUseType.CONSUME, Arrays.asList(new ItemStack(item, 2)));
if (block instanceof TurtleEggBlock) if (block instanceof TurtleEggBlock)
return new ItemRequirement(ItemUseType.CONSUME, Arrays.asList(new ItemStack(item, state.get(TurtleEggBlock.EGGS).intValue()))); return new ItemRequirement(ItemUseType.CONSUME, Arrays.asList(new ItemStack(item, state.get(TurtleEggBlock.EGGS).intValue())));

View file

@ -91,9 +91,9 @@ public class MaterialChecklist {
Collections.sort(keys, (item1, item2) -> { Collections.sort(keys, (item1, item2) -> {
Locale locale = Locale.ENGLISH; Locale locale = Locale.ENGLISH;
String name1 = String name1 =
new TranslationTextComponent(((Item) item1).getTranslationKey()).getFormattedText().toLowerCase(locale); new TranslationTextComponent(item1.getTranslationKey()).getFormattedText().toLowerCase(locale);
String name2 = String name2 =
new TranslationTextComponent(((Item) item2).getTranslationKey()).getFormattedText().toLowerCase(locale); new TranslationTextComponent(item2.getTranslationKey()).getFormattedText().toLowerCase(locale);
return name1.compareTo(name2); return name1.compareTo(name2);
}); });

View file

@ -8,6 +8,7 @@ import java.util.Map;
import java.util.Set; import java.util.Set;
import java.util.function.Predicate; import java.util.function.Predicate;
import com.simibubi.create.foundation.utility.BlockHelper;
import com.simibubi.create.foundation.utility.worldWrappers.WrappedWorld; import com.simibubi.create.foundation.utility.worldWrappers.WrappedWorld;
import net.minecraft.block.Block; import net.minecraft.block.Block;
@ -24,14 +25,11 @@ import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.math.AxisAlignedBB; import net.minecraft.util.math.AxisAlignedBB;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.MutableBoundingBox; import net.minecraft.util.math.MutableBoundingBox;
import net.minecraft.world.EmptyTickList; import net.minecraft.world.*;
import net.minecraft.world.ITickList;
import net.minecraft.world.LightType;
import net.minecraft.world.World;
import net.minecraft.world.biome.Biome; import net.minecraft.world.biome.Biome;
import net.minecraft.world.biome.Biomes; import net.minecraft.world.biome.Biomes;
public class SchematicWorld extends WrappedWorld { public class SchematicWorld extends WrappedWorld implements IServerWorld {
private Map<BlockPos, BlockState> blocks; private Map<BlockPos, BlockState> blocks;
private Map<BlockPos, TileEntity> tileEntities; private Map<BlockPos, TileEntity> tileEntities;
@ -102,7 +100,7 @@ public class SchematicWorld extends WrappedWorld {
return Blocks.GRASS_BLOCK.getDefaultState(); return Blocks.GRASS_BLOCK.getDefaultState();
if (getBounds().isVecInside(pos) && blocks.containsKey(pos)) { if (getBounds().isVecInside(pos) && blocks.containsKey(pos)) {
BlockState blockState = blocks.get(pos); BlockState blockState = blocks.get(pos);
if (blockState.has(BlockStateProperties.LIT)) if (BlockHelper.hasBlockStateProperty(blockState, BlockStateProperties.LIT))
blockState = blockState.with(BlockStateProperties.LIT, false); blockState = blockState.with(BlockStateProperties.LIT, false);
return blockState; return blockState;
} }

View file

@ -1,5 +1,6 @@
package com.simibubi.create.content.schematics.block; package com.simibubi.create.content.schematics.block;
import com.mojang.blaze3d.matrix.MatrixStack;
import com.mojang.blaze3d.systems.RenderSystem; import com.mojang.blaze3d.systems.RenderSystem;
import com.simibubi.create.AllBlocks; import com.simibubi.create.AllBlocks;
import com.simibubi.create.CreateClient; import com.simibubi.create.CreateClient;
@ -18,7 +19,9 @@ import net.minecraft.entity.player.PlayerInventory;
import net.minecraft.item.ItemStack; import net.minecraft.item.ItemStack;
import net.minecraft.util.Util; import net.minecraft.util.Util;
import net.minecraft.util.math.MathHelper; import net.minecraft.util.math.MathHelper;
import net.minecraft.util.text.IFormattableTextComponent;
import net.minecraft.util.text.ITextComponent; import net.minecraft.util.text.ITextComponent;
import net.minecraft.util.text.StringTextComponent;
import java.nio.file.Paths; import java.nio.file.Paths;
import java.util.List; import java.util.List;
@ -35,11 +38,11 @@ public class SchematicTableScreen extends AbstractSimiContainerScreen<SchematicT
private IconButton refreshButton; private IconButton refreshButton;
private Label schematicsLabel; private Label schematicsLabel;
private final String title = Lang.translate("gui.schematicTable.title"); private final ITextComponent title = Lang.translate("gui.schematicTable.title");
private final String uploading = Lang.translate("gui.schematicTable.uploading"); private final ITextComponent uploading = Lang.translate("gui.schematicTable.uploading");
private final String finished = Lang.translate("gui.schematicTable.finished"); private final ITextComponent finished = Lang.translate("gui.schematicTable.finished");
private final String noSchematics = Lang.translate("gui.schematicTable.noSchematics"); private final ITextComponent noSchematics = Lang.translate("gui.schematicTable.noSchematics");
private final String availableSchematicsTitle = Lang.translate("gui.schematicTable.availableSchematics"); private final ITextComponent availableSchematicsTitle = Lang.translate("gui.schematicTable.availableSchematics");
private final ItemStack renderedItem = AllBlocks.SCHEMATIC_TABLE.asStack(); private final ItemStack renderedItem = AllBlocks.SCHEMATIC_TABLE.asStack();
private float progress; private float progress;
@ -61,14 +64,14 @@ public class SchematicTableScreen extends AbstractSimiContainerScreen<SchematicT
int mainTop = guiTop - 16; int mainTop = guiTop - 16;
CreateClient.schematicSender.refresh(); CreateClient.schematicSender.refresh();
List<String> availableSchematics = CreateClient.schematicSender.getAvailableSchematics(); List<ITextComponent> availableSchematics = CreateClient.schematicSender.getAvailableSchematics();
schematicsLabel = new Label(mainLeft + 36, mainTop + 26, "").withShadow(); schematicsLabel = new Label(mainLeft + 36, mainTop + 26, "").withShadow();
schematicsLabel.text = ""; schematicsLabel.text = StringTextComponent.EMPTY;
if (!availableSchematics.isEmpty()) { if (!availableSchematics.isEmpty()) {
schematicsArea = schematicsArea =
new SelectionScrollInput(mainLeft + 33, mainTop + 23, 134, 14).forOptions(availableSchematics) new SelectionScrollInput(mainLeft + 33, mainTop + 23, 134, 14).forOptions(availableSchematics)
.titled(availableSchematicsTitle) .titled(availableSchematicsTitle.copy())
.writingTo(schematicsLabel); .writingTo(schematicsLabel);
widgets.add(schematicsArea); widgets.add(schematicsArea);
widgets.add(schematicsLabel); widgets.add(schematicsLabel);
@ -83,13 +86,7 @@ public class SchematicTableScreen extends AbstractSimiContainerScreen<SchematicT
} }
@Override @Override
protected void drawGuiContainerBackgroundLayer(float partialTicks, int mouseX, int mouseY) { protected void renderWindow(MatrixStack matrixStack, int mouseX, int mouseY, float partialTicks) {
super.drawGuiContainerBackgroundLayer(partialTicks, mouseX, mouseY);
}
@Override
protected void renderWindow(int mouseX, int mouseY, float partialTicks) {
int x = guiLeft + 20; int x = guiLeft + 20;
int y = guiTop; int y = guiTop;
@ -98,32 +95,31 @@ public class SchematicTableScreen extends AbstractSimiContainerScreen<SchematicT
int mainTop = guiTop - 16; int mainTop = guiTop - 16;
AllGuiTextures.PLAYER_INVENTORY.draw(this, x - 16, y + 70 + 14); AllGuiTextures.PLAYER_INVENTORY.draw(this, x - 16, y + 70 + 14);
font.drawString(playerInventory.getDisplayName() textRenderer.draw(matrixStack, playerInventory.getDisplayName(), x - 15 + 7, y + 64 + 26, 0x666666);
.getFormattedText(), x - 15 + 7, y + 64 + 26, 0x666666);
SCHEMATIC_TABLE.draw(this, mainLeft, mainTop); SCHEMATIC_TABLE.draw(this, mainLeft, mainTop);
if (container.getTileEntity().isUploading) if (container.getTileEntity().isUploading)
font.drawString(uploading, mainLeft + 76, mainTop + 10, AllGuiTextures.FONT_COLOR); textRenderer.draw(matrixStack, uploading, mainLeft + 76, mainTop + 10, AllGuiTextures.FONT_COLOR);
else if (container.getSlot(1).getHasStack()) else if (container.getSlot(1).getHasStack())
font.drawString(finished, mainLeft + 60, mainTop + 10, AllGuiTextures.FONT_COLOR); textRenderer.draw(matrixStack, finished, mainLeft + 60, mainTop + 10, AllGuiTextures.FONT_COLOR);
else else
font.drawString(title, mainLeft + 60, mainTop + 10, AllGuiTextures.FONT_COLOR); textRenderer.draw(matrixStack, title, mainLeft + 60, mainTop + 10, AllGuiTextures.FONT_COLOR);
if (schematicsArea == null) if (schematicsArea == null)
font.drawStringWithShadow(noSchematics, mainLeft + 39, mainTop + 26, 0xFFDD44); textRenderer.drawWithShadow(matrixStack, noSchematics, mainLeft + 39, mainTop + 26, 0xFFDD44);
GuiGameElement.of(renderedItem) GuiGameElement.of(renderedItem)
.at(mainLeft + 217, mainTop + 48) .at(mainLeft + 217, mainTop + 48)
.scale(3) .scale(3)
.render(); .render();
minecraft.getTextureManager() client.getTextureManager()
.bindTexture(SCHEMATIC_TABLE_PROGRESS.location); .bindTexture(SCHEMATIC_TABLE_PROGRESS.location);
int width = (int) (SCHEMATIC_TABLE_PROGRESS.width int width = (int) (SCHEMATIC_TABLE_PROGRESS.width
* MathHelper.lerp(partialTicks, lastChasingProgress, chasingProgress)); * MathHelper.lerp(partialTicks, lastChasingProgress, chasingProgress));
int height = SCHEMATIC_TABLE_PROGRESS.height; int height = SCHEMATIC_TABLE_PROGRESS.height;
RenderSystem.disableLighting(); RenderSystem.disableLighting();
drawTexture(mainLeft + 94, mainTop + 56, SCHEMATIC_TABLE_PROGRESS.startX, SCHEMATIC_TABLE_PROGRESS.startY, width, drawTexture(matrixStack, mainLeft + 94, mainTop + 56, SCHEMATIC_TABLE_PROGRESS.startX, SCHEMATIC_TABLE_PROGRESS.startY, width,
height); height);
} }
@ -146,7 +142,7 @@ public class SchematicTableScreen extends AbstractSimiContainerScreen<SchematicT
if (schematicsLabel != null) { if (schematicsLabel != null) {
schematicsLabel.colored(0xCCDDFF); schematicsLabel.colored(0xCCDDFF);
schematicsLabel.text = container.getTileEntity().uploadingSchematic; schematicsLabel.text = ITextComponent.of(container.getTileEntity().uploadingSchematic);
} }
if (schematicsArea != null) if (schematicsArea != null)
schematicsArea.visible = false; schematicsArea.visible = false;
@ -173,9 +169,9 @@ public class SchematicTableScreen extends AbstractSimiContainerScreen<SchematicT
&& schematicsArea != null) { && schematicsArea != null) {
lastChasingProgress = chasingProgress = progress = 0; lastChasingProgress = chasingProgress = progress = 0;
List<String> availableSchematics = schematicSender.getAvailableSchematics(); List<ITextComponent> availableSchematics = schematicSender.getAvailableSchematics();
String schematic = availableSchematics.get(schematicsArea.getState()); ITextComponent schematic = availableSchematics.get(schematicsArea.getState());
schematicSender.startNewUpload(schematic); schematicSender.startNewUpload(schematic.getUnformattedComponentText());
} }
if (folderButton.isHovered()) { if (folderButton.isHovered()) {
@ -186,18 +182,18 @@ public class SchematicTableScreen extends AbstractSimiContainerScreen<SchematicT
if (refreshButton.isHovered()) { if (refreshButton.isHovered()) {
schematicSender.refresh(); schematicSender.refresh();
List<String> availableSchematics = schematicSender.getAvailableSchematics(); List<ITextComponent> availableSchematics = schematicSender.getAvailableSchematics();
widgets.remove(schematicsArea); widgets.remove(schematicsArea);
if (!availableSchematics.isEmpty()) { if (!availableSchematics.isEmpty()) {
schematicsArea = new SelectionScrollInput(guiLeft - 56 + 33, guiTop - 16 + 23, 134, 14) schematicsArea = new SelectionScrollInput(guiLeft - 56 + 33, guiTop - 16 + 23, 134, 14)
.forOptions(availableSchematics) .forOptions(availableSchematics)
.titled(availableSchematicsTitle) .titled(availableSchematicsTitle.copy())
.writingTo(schematicsLabel); .writingTo(schematicsLabel);
widgets.add(schematicsArea); widgets.add(schematicsArea);
} else { } else {
schematicsArea = null; schematicsArea = null;
schematicsLabel.text = ""; schematicsLabel.text = StringTextComponent.EMPTY;
} }
} }

View file

@ -2,6 +2,7 @@ package com.simibubi.create.content.schematics.block;
import com.simibubi.create.foundation.tileEntity.SyncedTileEntity; import com.simibubi.create.foundation.tileEntity.SyncedTileEntity;
import net.minecraft.block.BlockState;
import net.minecraft.entity.player.PlayerEntity; import net.minecraft.entity.player.PlayerEntity;
import net.minecraft.entity.player.PlayerInventory; import net.minecraft.entity.player.PlayerInventory;
import net.minecraft.inventory.container.Container; import net.minecraft.inventory.container.Container;
@ -48,14 +49,14 @@ public class SchematicTableTileEntity extends SyncedTileEntity implements ITicka
} }
@Override @Override
public void read(CompoundNBT compound) { public void fromTag(BlockState state, CompoundNBT compound) {
inventory.deserializeNBT(compound.getCompound("Inventory")); inventory.deserializeNBT(compound.getCompound("Inventory"));
readClientUpdate(compound); readClientUpdate(state, compound);
super.read(compound); super.fromTag(state, compound);
} }
@Override @Override
public void readClientUpdate(CompoundNBT compound) { public void readClientUpdate(BlockState state, CompoundNBT compound) {
if (compound.contains("Uploading")) { if (compound.contains("Uploading")) {
isUploading = true; isUploading = true;
uploadingSchematic = compound.getString("Schematic"); uploadingSchematic = compound.getString("Schematic");

View file

@ -1,6 +1,7 @@
package com.simibubi.create.content.schematics.block; package com.simibubi.create.content.schematics.block;
import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableList;
import com.mojang.blaze3d.matrix.MatrixStack;
import com.simibubi.create.AllBlocks; import com.simibubi.create.AllBlocks;
import com.simibubi.create.content.schematics.packet.ConfigureSchematicannonPacket; import com.simibubi.create.content.schematics.packet.ConfigureSchematicannonPacket;
import com.simibubi.create.content.schematics.packet.ConfigureSchematicannonPacket.Option; import com.simibubi.create.content.schematics.packet.ConfigureSchematicannonPacket.Option;
@ -19,6 +20,7 @@ import net.minecraft.client.gui.widget.Widget;
import net.minecraft.client.renderer.Rectangle2d; import net.minecraft.client.renderer.Rectangle2d;
import net.minecraft.entity.player.PlayerInventory; import net.minecraft.entity.player.PlayerInventory;
import net.minecraft.item.ItemStack; import net.minecraft.item.ItemStack;
import net.minecraft.util.text.IFormattableTextComponent;
import net.minecraft.util.text.ITextComponent; import net.minecraft.util.text.ITextComponent;
import net.minecraft.util.text.TextFormatting; import net.minecraft.util.text.TextFormatting;
@ -48,15 +50,15 @@ public class SchematicannonScreen extends AbstractSimiContainerScreen<Schematica
private List<Rectangle2d> extraAreas; private List<Rectangle2d> extraAreas;
private final String title = Lang.translate("gui.schematicannon.title"); private final ITextComponent title = Lang.translate("gui.schematicannon.title");
private final String settingsTitle = Lang.translate("gui.schematicannon.settingsTitle"); private final ITextComponent settingsTitle = Lang.translate("gui.schematicannon.settingsTitle");
private final String listPrinter = Lang.translate("gui.schematicannon.listPrinter"); private final ITextComponent listPrinter = Lang.translate("gui.schematicannon.listPrinter");
private final String _gunpowderLevel = "gui.schematicannon.gunpowderLevel"; private final String _gunpowderLevel = "gui.schematicannon.gunpowderLevel";
private final String _shotsRemaining = "gui.schematicannon.shotsRemaining"; private final String _shotsRemaining = "gui.schematicannon.shotsRemaining";
private final String _shotsRemainingWithBackup = "gui.schematicannon.shotsRemainingWithBackup"; private final String _shotsRemainingWithBackup = "gui.schematicannon.shotsRemainingWithBackup";
private final String optionEnabled = Lang.translate("gui.schematicannon.optionEnabled"); private final ITextComponent optionEnabled = Lang.translate("gui.schematicannon.optionEnabled");
private final String optionDisabled = Lang.translate("gui.schematicannon.optionDisabled"); private final ITextComponent optionDisabled = Lang.translate("gui.schematicannon.optionDisabled");
private final ItemStack renderedItem = AllBlocks.SCHEMATICANNON.asStack(); private final ItemStack renderedItem = AllBlocks.SCHEMATICANNON.asStack();
@ -92,7 +94,7 @@ public class SchematicannonScreen extends AbstractSimiContainerScreen<Schematica
List<AllIcons> icons = ImmutableList List<AllIcons> icons = ImmutableList
.of(AllIcons.I_DONT_REPLACE, AllIcons.I_REPLACE_SOLID, AllIcons.I_REPLACE_ANY, .of(AllIcons.I_DONT_REPLACE, AllIcons.I_REPLACE_SOLID, AllIcons.I_REPLACE_ANY,
AllIcons.I_REPLACE_EMPTY); AllIcons.I_REPLACE_EMPTY);
List<String> toolTips = ImmutableList List<ITextComponent> toolTips = ImmutableList
.of(Lang.translate("gui.schematicannon.option.dontReplaceSolid"), .of(Lang.translate("gui.schematicannon.option.dontReplaceSolid"),
Lang.translate("gui.schematicannon.option.replaceWithSolid"), Lang.translate("gui.schematicannon.option.replaceWithSolid"),
Lang.translate("gui.schematicannon.option.replaceWithAny"), Lang.translate("gui.schematicannon.option.replaceWithAny"),
@ -190,8 +192,8 @@ public class SchematicannonScreen extends AbstractSimiContainerScreen<Schematica
if (!button.isHovered()) if (!button.isHovered())
return; return;
boolean enabled = indicator.state == State.ON; boolean enabled = indicator.state == State.ON;
List<String> tip = button.getToolTip(); List<ITextComponent> tip = button.getToolTip();
tip.add(TextFormatting.BLUE + (enabled ? optionEnabled : optionDisabled)); tip.add((enabled ? optionEnabled : optionDisabled).copy().formatted(TextFormatting.BLUE));
tip tip
.addAll(TooltipHelper .addAll(TooltipHelper
.cutString(Lang.translate("gui.schematicannon.option." + tooltipKey + ".description"), GRAY, .cutString(Lang.translate("gui.schematicannon.option." + tooltipKey + ".description"), GRAY,
@ -199,14 +201,14 @@ public class SchematicannonScreen extends AbstractSimiContainerScreen<Schematica
} }
@Override @Override
protected void renderWindow(int mouseX, int mouseY, float partialTicks) { protected void renderWindow(MatrixStack matrixStack, int mouseX, int mouseY, float partialTicks) {
AllGuiTextures.PLAYER_INVENTORY.draw(this, guiLeft - 10, guiTop + 145); AllGuiTextures.PLAYER_INVENTORY.draw(this, guiLeft - 10, guiTop + 145);
AllGuiTextures.SCHEMATICANNON_BG.draw(this, guiLeft + 20, guiTop); AllGuiTextures.SCHEMATICANNON_BG.draw(this, guiLeft + 20, guiTop);
SchematicannonTileEntity te = container.getTileEntity(); SchematicannonTileEntity te = container.getTileEntity();
renderPrintingProgress(te.schematicProgress); renderPrintingProgress(matrixStack, te.schematicProgress);
renderFuelBar(te.fuelLevel); renderFuelBar(matrixStack, te.fuelLevel);
renderChecklistPrinterProgress(te.bookPrintingProgress); renderChecklistPrinterProgress(matrixStack, te.bookPrintingProgress);
if (!te.inventory.getStackInSlot(0).isEmpty()) if (!te.inventory.getStackInSlot(0).isEmpty())
renderBlueprintHighlight(); renderBlueprintHighlight();
@ -217,21 +219,21 @@ public class SchematicannonScreen extends AbstractSimiContainerScreen<Schematica
.render(); .render();
font.drawString(title, guiLeft + 80, guiTop + 10, AllGuiTextures.FONT_COLOR); textRenderer.draw(matrixStack, title, guiLeft + 80, guiTop + 10, AllGuiTextures.FONT_COLOR);
String msg = Lang.translate("schematicannon.status." + te.statusMsg); IFormattableTextComponent msg = Lang.translate("schematicannon.status." + te.statusMsg);
int stringWidth = font.getStringWidth(msg); int stringWidth = textRenderer.getWidth(msg);
if (te.missingItem != null) { if (te.missingItem != null) {
stringWidth += 15; stringWidth += 15;
itemRenderer.renderItemIntoGUI(te.missingItem, guiLeft + 145, guiTop + 25); itemRenderer.renderItemIntoGUI(te.missingItem, guiLeft + 145, guiTop + 25);
} }
font.drawStringWithShadow(msg, guiLeft + 20 + 96 - stringWidth / 2, guiTop + 30, 0xCCDDFF); textRenderer.drawWithShadow(matrixStack, msg, guiLeft + 20 + 96 - stringWidth / 2, guiTop + 30, 0xCCDDFF);
font.drawString(settingsTitle, guiLeft + 20 + 13, guiTop + 84, AllGuiTextures.FONT_COLOR); textRenderer.draw(matrixStack, settingsTitle, guiLeft + 20 + 13, guiTop + 84, AllGuiTextures.FONT_COLOR);
font textRenderer
.drawString(playerInventory.getDisplayName().getFormattedText(), guiLeft - 10 + 7, guiTop + 145 + 6, .draw(matrixStack, playerInventory.getDisplayName(), guiLeft - 10 + 7, guiTop + 145 + 6,
0x666666); 0x666666);
// to see or debug the bounds of the extra area uncomment the following lines // to see or debug the bounds of the extra area uncomment the following lines
@ -244,34 +246,34 @@ public class SchematicannonScreen extends AbstractSimiContainerScreen<Schematica
AllGuiTextures.SCHEMATICANNON_HIGHLIGHT.draw(this, guiLeft + 20 + 8, guiTop + 31); AllGuiTextures.SCHEMATICANNON_HIGHLIGHT.draw(this, guiLeft + 20 + 8, guiTop + 31);
} }
protected void renderPrintingProgress(float progress) { protected void renderPrintingProgress(MatrixStack matrixStack, float progress) {
progress = Math.min(progress, 1); progress = Math.min(progress, 1);
AllGuiTextures sprite = AllGuiTextures.SCHEMATICANNON_PROGRESS; AllGuiTextures sprite = AllGuiTextures.SCHEMATICANNON_PROGRESS;
minecraft.getTextureManager().bindTexture(sprite.location); client.getTextureManager().bindTexture(sprite.location);
drawTexture(guiLeft + 20 + 39, guiTop + 36, sprite.startX, sprite.startY, (int) (sprite.width * progress), drawTexture(matrixStack, guiLeft + 20 + 39, guiTop + 36, sprite.startX, sprite.startY, (int) (sprite.width * progress),
sprite.height); sprite.height);
} }
protected void renderChecklistPrinterProgress(float progress) { protected void renderChecklistPrinterProgress(MatrixStack matrixStack, float progress) {
AllGuiTextures sprite = AllGuiTextures.SCHEMATICANNON_PROGRESS_2; AllGuiTextures sprite = AllGuiTextures.SCHEMATICANNON_PROGRESS_2;
minecraft.getTextureManager().bindTexture(sprite.location); client.getTextureManager().bindTexture(sprite.location);
drawTexture(guiLeft + 20 + 222, guiTop + 42, sprite.startX, sprite.startY, sprite.width, drawTexture(matrixStack, guiLeft + 20 + 222, guiTop + 42, sprite.startX, sprite.startY, sprite.width,
(int) (sprite.height * progress)); (int) (sprite.height * progress));
} }
protected void renderFuelBar(float amount) { protected void renderFuelBar(MatrixStack matrixStack, float amount) {
AllGuiTextures sprite = AllGuiTextures.SCHEMATICANNON_FUEL; AllGuiTextures sprite = AllGuiTextures.SCHEMATICANNON_FUEL;
if (container.getTileEntity().hasCreativeCrate) { if (container.getTileEntity().hasCreativeCrate) {
AllGuiTextures.SCHEMATICANNON_FUEL_CREATIVE.draw(this, guiLeft + 20 + 73, guiTop + 135); AllGuiTextures.SCHEMATICANNON_FUEL_CREATIVE.draw(this, guiLeft + 20 + 73, guiTop + 135);
return; return;
} }
minecraft.getTextureManager().bindTexture(sprite.location); client.getTextureManager().bindTexture(sprite.location);
drawTexture(guiLeft + 20 + 73, guiTop + 135, sprite.startX, sprite.startY, (int) (sprite.width * amount), drawTexture(matrixStack, guiLeft + 20 + 73, guiTop + 135, sprite.startX, sprite.startY, (int) (sprite.width * amount),
sprite.height); sprite.height);
} }
@Override @Override
protected void renderWindowForeground(int mouseX, int mouseY, float partialTicks) { protected void renderWindowForeground(MatrixStack matrixStack, int mouseX, int mouseY, float partialTicks) {
int fuelX = guiLeft + 20 + 73, fuelY = guiTop + 135; int fuelX = guiLeft + 20 + 73, fuelY = guiTop + 135;
SchematicannonTileEntity te = container.getTileEntity(); SchematicannonTileEntity te = container.getTileEntity();
if (mouseX >= fuelX && mouseY >= fuelY && mouseX <= fuelX + AllGuiTextures.SCHEMATICANNON_FUEL.width if (mouseX >= fuelX && mouseY >= fuelY && mouseX <= fuelX + AllGuiTextures.SCHEMATICANNON_FUEL.width
@ -300,16 +302,16 @@ public class SchematicannonScreen extends AbstractSimiContainerScreen<Schematica
int missingBlockX = guiLeft + 145, missingBlockY = guiTop + 25; int missingBlockX = guiLeft + 145, missingBlockY = guiTop + 25;
if (mouseX >= missingBlockX && mouseY >= missingBlockY && mouseX <= missingBlockX + 16 if (mouseX >= missingBlockX && mouseY >= missingBlockY && mouseX <= missingBlockX + 16
&& mouseY <= missingBlockY + 16) { && mouseY <= missingBlockY + 16) {
renderTooltip(te.missingItem, mouseX, mouseY); renderTooltip(matrixStack, te.missingItem, mouseX, mouseY);
} }
} }
int paperX = guiLeft + 20 + 202, paperY = guiTop + 20; int paperX = guiLeft + 20 + 202, paperY = guiTop + 20;
if (mouseX >= paperX && mouseY >= paperY && mouseX <= paperX + 16 && mouseY <= paperY + 16) { if (mouseX >= paperX && mouseY >= paperY && mouseX <= paperX + 16 && mouseY <= paperY + 16) {
renderTooltip(listPrinter, mouseX, mouseY); renderTooltip(matrixStack, listPrinter, mouseX, mouseY);
} }
super.renderWindowForeground(mouseX, mouseY, partialTicks); super.renderWindowForeground(matrixStack, mouseX, mouseY, partialTicks);
} }
@Override @Override

View file

@ -694,9 +694,9 @@ public class SchematicannonTileEntity extends SmartTileEntity implements INamedC
boolean placingAir = state.getBlock() == Blocks.AIR; boolean placingAir = state.getBlock() == Blocks.AIR;
BlockState toReplaceOther = null; BlockState toReplaceOther = null;
if (state.has(BlockStateProperties.BED_PART) && state.has(BlockStateProperties.HORIZONTAL_FACING) && state.get(BlockStateProperties.BED_PART) == BedPart.FOOT) if (BlockHelper.hasBlockStateProperty(state, BlockStateProperties.BED_PART) && BlockHelper.hasBlockStateProperty(state, BlockStateProperties.HORIZONTAL_FACING) && state.get(BlockStateProperties.BED_PART) == BedPart.FOOT)
toReplaceOther = world.getBlockState(pos.offset(state.get(BlockStateProperties.HORIZONTAL_FACING))); toReplaceOther = world.getBlockState(pos.offset(state.get(BlockStateProperties.HORIZONTAL_FACING)));
if (state.has(BlockStateProperties.DOUBLE_BLOCK_HALF) if (BlockHelper.hasBlockStateProperty(state, BlockStateProperties.DOUBLE_BLOCK_HALF)
&& state.get(BlockStateProperties.DOUBLE_BLOCK_HALF) == DoubleBlockHalf.LOWER) && state.get(BlockStateProperties.DOUBLE_BLOCK_HALF) == DoubleBlockHalf.LOWER)
toReplaceOther = world.getBlockState(pos.up()); toReplaceOther = world.getBlockState(pos.up());
@ -739,10 +739,10 @@ public class SchematicannonTileEntity extends SmartTileEntity implements INamedC
return true; return true;
// Block doesnt need to be placed twice (Doors, beds, double plants) // Block doesnt need to be placed twice (Doors, beds, double plants)
if (state.has(BlockStateProperties.DOUBLE_BLOCK_HALF) if (BlockHelper.hasBlockStateProperty(state, BlockStateProperties.DOUBLE_BLOCK_HALF)
&& state.get(BlockStateProperties.DOUBLE_BLOCK_HALF) == DoubleBlockHalf.UPPER) && state.get(BlockStateProperties.DOUBLE_BLOCK_HALF) == DoubleBlockHalf.UPPER)
return true; return true;
if (state.has(BlockStateProperties.BED_PART) && state.get(BlockStateProperties.BED_PART) == BedPart.HEAD) if (BlockHelper.hasBlockStateProperty(state, BlockStateProperties.BED_PART) && state.get(BlockStateProperties.BED_PART) == BedPart.HEAD)
return true; return true;
if (state.getBlock() instanceof PistonHeadBlock) if (state.getBlock() instanceof PistonHeadBlock)
return true; return true;

View file

@ -207,7 +207,7 @@ public class SchematicAndQuillHandler {
new BlockPos(bb.getXSize(), bb.getYSize(), bb.getZSize()), true, Blocks.AIR); new BlockPos(bb.getXSize(), bb.getYSize(), bb.getZSize()), true, Blocks.AIR);
if (string.isEmpty()) if (string.isEmpty())
string = Lang.translate("schematicAndQuill.fallbackName"); string = Lang.translate("schematicAndQuill.fallbackName").getUnformattedComponentText();
String folderPath = "schematics"; String folderPath = "schematics";
FilesHelper.createFolderIfMissing(folderPath); FilesHelper.createFolderIfMissing(folderPath);

View file

@ -3,6 +3,7 @@ package com.simibubi.create.content.schematics.client;
import java.util.Collections; import java.util.Collections;
import java.util.List; import java.util.List;
import com.mojang.blaze3d.matrix.MatrixStack;
import com.mojang.blaze3d.systems.RenderSystem; import com.mojang.blaze3d.systems.RenderSystem;
import com.simibubi.create.AllItems; import com.simibubi.create.AllItems;
import com.simibubi.create.CreateClient; import com.simibubi.create.CreateClient;
@ -19,6 +20,9 @@ import net.minecraft.nbt.NBTUtil;
import net.minecraft.util.Mirror; import net.minecraft.util.Mirror;
import net.minecraft.util.Rotation; import net.minecraft.util.Rotation;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
import net.minecraft.util.text.ITextComponent;
import net.minecraft.util.text.StringTextComponent;
import net.minecraft.util.text.TranslationTextComponent;
import net.minecraft.world.gen.feature.template.PlacementSettings; import net.minecraft.world.gen.feature.template.PlacementSettings;
public class SchematicEditScreen extends AbstractSimiScreen { public class SchematicEditScreen extends AbstractSimiScreen {
@ -27,13 +31,13 @@ public class SchematicEditScreen extends AbstractSimiScreen {
private TextFieldWidget yInput; private TextFieldWidget yInput;
private TextFieldWidget zInput; private TextFieldWidget zInput;
private final List<String> rotationOptions = private final List<ITextComponent> rotationOptions =
Lang.translatedOptions("schematic.rotation", "none", "cw90", "cw180", "cw270"); Lang.translatedOptions("schematic.rotation", "none", "cw90", "cw180", "cw270");
private final List<String> mirrorOptions = private final List<ITextComponent> mirrorOptions =
Lang.translatedOptions("schematic.mirror", "none", "leftRight", "frontBack"); Lang.translatedOptions("schematic.mirror", "none", "leftRight", "frontBack");
private final String positionLabel = Lang.translate("schematic.position"); private final ITextComponent positionLabel = Lang.translate("schematic.position");
private final String rotationLabel = Lang.translate("schematic.rotation"); private final ITextComponent rotationLabel = Lang.translate("schematic.rotation");
private final String mirrorLabel = Lang.translate("schematic.mirror"); private final ITextComponent mirrorLabel = Lang.translate("schematic.mirror");
private ScrollInput rotationArea; private ScrollInput rotationArea;
private ScrollInput mirrorArea; private ScrollInput mirrorArea;
@ -46,9 +50,9 @@ public class SchematicEditScreen extends AbstractSimiScreen {
int y = guiTop; int y = guiTop;
handler = CreateClient.schematicHandler; handler = CreateClient.schematicHandler;
xInput = new TextFieldWidget(font, x + 75, y + 32, 32, 10, ""); xInput = new TextFieldWidget(textRenderer, x + 75, y + 32, 32, 10, StringTextComponent.EMPTY);
yInput = new TextFieldWidget(font, x + 115, y + 32, 32, 10, ""); yInput = new TextFieldWidget(textRenderer, x + 115, y + 32, 32, 10, StringTextComponent.EMPTY);
zInput = new TextFieldWidget(font, x + 155, y + 32, 32, 10, ""); zInput = new TextFieldWidget(textRenderer, x + 155, y + 32, 32, 10, StringTextComponent.EMPTY);
BlockPos anchor = handler.getTransformation().getAnchor(); BlockPos anchor = handler.getTransformation().getAnchor();
if (handler.isDeployed()) { if (handler.isDeployed()) {
@ -56,7 +60,7 @@ public class SchematicEditScreen extends AbstractSimiScreen {
yInput.setText("" + anchor.getY()); yInput.setText("" + anchor.getY());
zInput.setText("" + anchor.getZ()); zInput.setText("" + anchor.getZ());
} else { } else {
BlockPos alt = minecraft.player.getPosition(); BlockPos alt = client.player.getBlockPos();
xInput.setText("" + alt.getX()); xInput.setText("" + alt.getX());
yInput.setText("" + alt.getY()); yInput.setText("" + alt.getY());
zInput.setText("" + alt.getZ()); zInput.setText("" + alt.getZ());
@ -82,11 +86,11 @@ public class SchematicEditScreen extends AbstractSimiScreen {
PlacementSettings settings = handler.getTransformation().toSettings(); PlacementSettings settings = handler.getTransformation().toSettings();
Label labelR = new Label(x + 99, y + 52, "").withShadow(); Label labelR = new Label(x + 99, y + 52, "").withShadow();
rotationArea = new SelectionScrollInput(x + 96, y + 49, 94, 14).forOptions(rotationOptions).titled("Rotation") rotationArea = new SelectionScrollInput(x + 96, y + 49, 94, 14).forOptions(rotationOptions).titled(new StringTextComponent("Rotation"))
.setState(settings.getRotation().ordinal()).writingTo(labelR); .setState(settings.getRotation().ordinal()).writingTo(labelR);
Label labelM = new Label(x + 99, y + 72, "").withShadow(); Label labelM = new Label(x + 99, y + 72, "").withShadow();
mirrorArea = new SelectionScrollInput(x + 96, y + 69, 94, 14).forOptions(mirrorOptions).titled("Mirror") mirrorArea = new SelectionScrollInput(x + 96, y + 69, 94, 14).forOptions(mirrorOptions).titled(new StringTextComponent("Mirror"))
.setState(settings.getMirror().ordinal()).writingTo(labelM); .setState(settings.getMirror().ordinal()).writingTo(labelM);
Collections.addAll(widgets, xInput, yInput, zInput); Collections.addAll(widgets, xInput, yInput, zInput);
@ -99,7 +103,7 @@ public class SchematicEditScreen extends AbstractSimiScreen {
public boolean keyPressed(int code, int p_keyPressed_2_, int p_keyPressed_3_) { public boolean keyPressed(int code, int p_keyPressed_2_, int p_keyPressed_3_) {
if (isPaste(code)) { if (isPaste(code)) {
String coords = minecraft.keyboardListener.getClipboardString(); String coords = client.keyboardListener.getClipboardString();
if (coords != null && !coords.isEmpty()) { if (coords != null && !coords.isEmpty()) {
coords.replaceAll(" ", ""); coords.replaceAll(" ", "");
String[] split = coords.split(","); String[] split = coords.split(",");
@ -126,17 +130,17 @@ public class SchematicEditScreen extends AbstractSimiScreen {
} }
@Override @Override
protected void renderWindow(int mouseX, int mouseY, float partialTicks) { protected void renderWindow(MatrixStack matrixStack, int mouseX, int mouseY, float partialTicks) {
int x = guiLeft; int x = guiLeft;
int y = guiTop; int y = guiTop;
AllGuiTextures.SCHEMATIC.draw(this, x, y); AllGuiTextures.SCHEMATIC.draw(this, x, y);
font.drawStringWithShadow(handler.getCurrentSchematicName(), textRenderer.drawWithShadow(matrixStack, handler.getCurrentSchematicName(),
x + 103 - font.getStringWidth(handler.getCurrentSchematicName()) / 2, y + 10, 0xDDEEFF); x + 103 - textRenderer.getStringWidth(handler.getCurrentSchematicName()) / 2, y + 10, 0xDDEEFF);
font.drawString(positionLabel, x + 10, y + 32, AllGuiTextures.FONT_COLOR); textRenderer.draw(matrixStack, positionLabel, x + 10, y + 32, AllGuiTextures.FONT_COLOR);
font.drawString(rotationLabel, x + 10, y + 52, AllGuiTextures.FONT_COLOR); textRenderer.draw(matrixStack, rotationLabel, x + 10, y + 52, AllGuiTextures.FONT_COLOR);
font.drawString(mirrorLabel, x + 10, y + 72, AllGuiTextures.FONT_COLOR); textRenderer.draw(matrixStack, mirrorLabel, x + 10, y + 72, AllGuiTextures.FONT_COLOR);
RenderSystem.pushMatrix(); RenderSystem.pushMatrix();
RenderSystem.translated(guiLeft + 220, guiTop + 20, 0); RenderSystem.translated(guiLeft + 220, guiTop + 20, 0);

View file

@ -127,11 +127,11 @@ public class SchematicHandler {
SchematicWorld wMirroredLR = new SchematicWorld(clientWorld); SchematicWorld wMirroredLR = new SchematicWorld(clientWorld);
PlacementSettings placementSettings = new PlacementSettings(); PlacementSettings placementSettings = new PlacementSettings();
schematic.addBlocksToWorld(w, BlockPos.ZERO, placementSettings); schematic.place(w, BlockPos.ZERO, placementSettings);
placementSettings.setMirror(Mirror.FRONT_BACK); placementSettings.setMirror(Mirror.FRONT_BACK);
schematic.addBlocksToWorld(wMirroredFB, BlockPos.ZERO.east(size.getX() - 1), placementSettings); schematic.place(wMirroredFB, BlockPos.ZERO.east(size.getX() - 1), placementSettings);
placementSettings.setMirror(Mirror.LEFT_RIGHT); placementSettings.setMirror(Mirror.LEFT_RIGHT);
schematic.addBlocksToWorld(wMirroredLR, BlockPos.ZERO.south(size.getZ() - 1), placementSettings); schematic.place(wMirroredLR, BlockPos.ZERO.south(size.getZ() - 1), placementSettings);
renderers.get(0) renderers.get(0)
.display(w); .display(w);

View file

@ -6,6 +6,7 @@ import java.util.List;
import com.simibubi.create.foundation.gui.AllIcons; import com.simibubi.create.foundation.gui.AllIcons;
import com.simibubi.create.foundation.utility.Lang; import com.simibubi.create.foundation.utility.Lang;
import net.minecraft.util.text.TranslationTextComponent;
public enum Tools { public enum Tools {
@ -28,7 +29,7 @@ public enum Tools {
return tool; return tool;
} }
public String getDisplayName() { public TranslationTextComponent getDisplayName() {
return Lang.translate("schematic.tool." + Lang.asId(name())); return Lang.translate("schematic.tool." + Lang.asId(name()));
} }
@ -44,7 +45,7 @@ public enum Tools {
return tools; return tools;
} }
public List<String> getDescription() { public List<TranslationTextComponent> getDescription() {
return Lang.translatedOptions("schematic.tool." + Lang.asId(name()) + ".description", "0", "1", "2", "3"); return Lang.translatedOptions("schematic.tool." + Lang.asId(name()) + ".description", "0", "1", "2", "3");
} }

View file

@ -77,7 +77,7 @@ public class SchematicItem extends Item {
tooltip.add(new StringTextComponent(TextFormatting.GOLD + stack.getTag() tooltip.add(new StringTextComponent(TextFormatting.GOLD + stack.getTag()
.getString("File"))); .getString("File")));
} else { } else {
tooltip.add(new StringTextComponent(TextFormatting.RED + Lang.translate("schematic.invalid"))); tooltip.add(Lang.translate("schematic.invalid").formatted(TextFormatting.RED));
} }
super.addInformation(stack, worldIn, tooltip, flagIn); super.addInformation(stack, worldIn, tooltip, flagIn);
} }

View file

@ -37,7 +37,7 @@ public class SchematicPlacePacket extends SimplePacketBase {
Template t = SchematicItem.loadSchematic(stack); Template t = SchematicItem.loadSchematic(stack);
PlacementSettings settings = SchematicItem.getSettings(stack); PlacementSettings settings = SchematicItem.getSettings(stack);
settings.setIgnoreEntities(false); settings.setIgnoreEntities(false);
t.addBlocksToWorld(player.getServerWorld(), NBTUtil.readBlockPos(stack.getTag().getCompound("Anchor")), t.place(player.getServerWorld(), NBTUtil.readBlockPos(stack.getTag().getCompound("Anchor")),
settings); settings);
}); });
context.get().setPacketHandled(true); context.get().setPacketHandled(true);

View file

@ -68,7 +68,7 @@ public class CommonEvents {
@SubscribeEvent @SubscribeEvent
public static void serverStarted(FMLServerStartingEvent event) { public static void serverStarted(FMLServerStartingEvent event) {
AllCommands.register(event.getCommandDispatcher()); AllCommands.register(event.getServer().getCommandManager().getDispatcher());
} }
@SubscribeEvent @SubscribeEvent

View file

@ -2,6 +2,9 @@ package com.simibubi.create.foundation.gui;
import java.util.function.Consumer; import java.util.function.Consumer;
import com.mojang.blaze3d.matrix.MatrixStack;
import net.minecraft.util.text.ITextComponent;
import net.minecraft.util.text.StringTextComponent;
import org.lwjgl.glfw.GLFW; import org.lwjgl.glfw.GLFW;
import com.simibubi.create.foundation.utility.Lang; import com.simibubi.create.foundation.utility.Lang;
@ -11,8 +14,8 @@ import net.minecraft.client.gui.widget.button.Button;
public class TextInputPromptScreen extends AbstractSimiScreen { public class TextInputPromptScreen extends AbstractSimiScreen {
private final String defaultConfirm = Lang.translate("action.confirm"); private final ITextComponent defaultConfirm = Lang.translate("action.confirm");
private final String defaultAbort = Lang.translate("action.abort"); private final ITextComponent defaultAbort = Lang.translate("action.abort");
private Consumer<String> callback; private Consumer<String> callback;
private Consumer<String> abortCallback; private Consumer<String> abortCallback;
@ -21,9 +24,9 @@ public class TextInputPromptScreen extends AbstractSimiScreen {
private Button confirm; private Button confirm;
private Button abort; private Button abort;
private String buttonTextConfirm; private ITextComponent buttonTextConfirm;
private String buttonTextAbort; private ITextComponent buttonTextAbort;
private String title; private ITextComponent title;
private boolean confirmed; private boolean confirmed;
@ -42,7 +45,7 @@ public class TextInputPromptScreen extends AbstractSimiScreen {
super.init(); super.init();
setWindowSize(AllGuiTextures.TEXT_INPUT.width, AllGuiTextures.TEXT_INPUT.height + 30); setWindowSize(AllGuiTextures.TEXT_INPUT.width, AllGuiTextures.TEXT_INPUT.height + 30);
this.nameField = new TextFieldWidget(font, guiLeft + 33, guiTop + 26, 128, 8, ""); this.nameField = new TextFieldWidget(textRenderer, guiLeft + 33, guiTop + 26, 128, 8, StringTextComponent.EMPTY);
this.nameField.setTextColor(-1); this.nameField.setTextColor(-1);
this.nameField.setDisabledTextColour(-1); this.nameField.setDisabledTextColour(-1);
this.nameField.setEnableBackgroundDrawing(false); this.nameField.setEnableBackgroundDrawing(false);
@ -52,11 +55,11 @@ public class TextInputPromptScreen extends AbstractSimiScreen {
confirm = new Button(guiLeft - 5, guiTop + 50, 100, 20, buttonTextConfirm, button -> { confirm = new Button(guiLeft - 5, guiTop + 50, 100, 20, buttonTextConfirm, button -> {
callback.accept(nameField.getText()); callback.accept(nameField.getText());
confirmed = true; confirmed = true;
minecraft.displayGuiScreen(null); client.displayGuiScreen(null);
}); });
abort = new Button(guiLeft + 100, guiTop + 50, 100, 20, buttonTextAbort, button -> { abort = new Button(guiLeft + 100, guiTop + 50, 100, 20, buttonTextAbort, button -> {
minecraft.displayGuiScreen(null); client.displayGuiScreen(null);
}); });
widgets.add(confirm); widgets.add(confirm);
@ -65,9 +68,9 @@ public class TextInputPromptScreen extends AbstractSimiScreen {
} }
@Override @Override
public void renderWindow(int mouseX, int mouseY, float partialTicks) { public void renderWindow(MatrixStack matrixStack, int mouseX, int mouseY, float partialTicks) {
AllGuiTextures.TEXT_INPUT.draw(this, guiLeft, guiTop); AllGuiTextures.TEXT_INPUT.draw(this, guiLeft, guiTop);
font.drawString(title, guiLeft + (sWidth / 2) - (font.getStringWidth(title) / 2), guiTop + 11, textRenderer.draw(matrixStack, title, guiLeft + (sWidth / 2) - (textRenderer.getWidth(title) / 2), guiTop + 11,
AllGuiTextures.FONT_COLOR); AllGuiTextures.FONT_COLOR);
} }
@ -78,15 +81,15 @@ public class TextInputPromptScreen extends AbstractSimiScreen {
super.removed(); super.removed();
} }
public void setButtonTextConfirm(String buttonTextConfirm) { public void setButtonTextConfirm(ITextComponent buttonTextConfirm) {
this.buttonTextConfirm = buttonTextConfirm; this.buttonTextConfirm = buttonTextConfirm;
} }
public void setButtonTextAbort(String buttonTextAbort) { public void setButtonTextAbort(ITextComponent buttonTextAbort) {
this.buttonTextAbort = buttonTextAbort; this.buttonTextAbort = buttonTextAbort;
} }
public void setTitle(String title) { public void setTitle(ITextComponent title) {
this.title = title; this.title = title;
} }

View file

@ -7,6 +7,7 @@ import java.util.Locale;
import com.simibubi.create.Create; import com.simibubi.create.Create;
import net.minecraft.entity.player.PlayerEntity; import net.minecraft.entity.player.PlayerEntity;
import net.minecraft.util.text.ITextComponent;
import net.minecraft.util.text.TranslationTextComponent; import net.minecraft.util.text.TranslationTextComponent;
public class Lang { public class Lang {
@ -23,8 +24,8 @@ public class Lang {
player.sendStatusMessage(createTranslationTextComponent(key, args), true); player.sendStatusMessage(createTranslationTextComponent(key, args), true);
} }
public static List<TranslationTextComponent> translatedOptions(String prefix, String... keys) { public static List<ITextComponent> translatedOptions(String prefix, String... keys) {
List<TranslationTextComponent> result = new ArrayList<>(keys.length); List<ITextComponent> result = new ArrayList<>(keys.length);
for (String key : keys) { for (String key : keys) {
result.add(translate(prefix + "." + key)); result.add(translate(prefix + "." + key));
} }

View file

@ -4,6 +4,7 @@ import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.function.Predicate; import java.util.function.Predicate;
import mcp.MethodsReturnNonnullByDefault;
import net.minecraft.block.Block; import net.minecraft.block.Block;
import net.minecraft.block.BlockState; import net.minecraft.block.BlockState;
import net.minecraft.entity.Entity; import net.minecraft.entity.Entity;
@ -11,16 +12,23 @@ import net.minecraft.entity.player.PlayerEntity;
import net.minecraft.fluid.Fluid; import net.minecraft.fluid.Fluid;
import net.minecraft.item.crafting.RecipeManager; import net.minecraft.item.crafting.RecipeManager;
import net.minecraft.scoreboard.Scoreboard; import net.minecraft.scoreboard.Scoreboard;
import net.minecraft.tags.NetworkTagManager; import net.minecraft.tags.ITagCollectionSupplier;
import net.minecraft.tileentity.TileEntity; import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.Direction;
import net.minecraft.util.SoundCategory; import net.minecraft.util.SoundCategory;
import net.minecraft.util.SoundEvent; import net.minecraft.util.SoundEvent;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
import net.minecraft.util.registry.DynamicRegistries;
import net.minecraft.world.ITickList; import net.minecraft.world.ITickList;
import net.minecraft.world.World; import net.minecraft.world.World;
import net.minecraft.world.biome.Biome; import net.minecraft.world.biome.Biome;
import net.minecraft.world.chunk.AbstractChunkProvider;
import net.minecraft.world.storage.MapData; import net.minecraft.world.storage.MapData;
import javax.annotation.ParametersAreNonnullByDefault;
@MethodsReturnNonnullByDefault
@ParametersAreNonnullByDefault
public class WrappedWorld extends World { public class WrappedWorld extends World {
protected World world; protected World world;
@ -76,6 +84,11 @@ public class WrappedWorld extends World {
return world.getPendingFluidTicks(); return world.getPendingFluidTicks();
} }
@Override
public AbstractChunkProvider getChunkProvider() {
return null;
}
@Override @Override
public void playEvent(PlayerEntity player, int type, BlockPos pos, int data) {} public void playEvent(PlayerEntity player, int type, BlockPos pos, int data) {}
@ -113,7 +126,7 @@ public class WrappedWorld extends World {
@Override @Override
public int getNextMapId() { public int getNextMapId() {
return 0; return world.getNextMapId();
} }
@Override @Override
@ -130,18 +143,22 @@ public class WrappedWorld extends World {
} }
@Override @Override
public NetworkTagManager getTags() { public ITagCollectionSupplier getTags() {
return world.getTags(); return world.getTags();
} }
@Override
public int getMaxHeight() {
return 256;
}
@Override @Override
public Biome getGeneratorStoredBiome(int p_225604_1_, int p_225604_2_, int p_225604_3_) { public Biome getGeneratorStoredBiome(int p_225604_1_, int p_225604_2_, int p_225604_3_) {
return world.getGeneratorStoredBiome(p_225604_1_, p_225604_2_, p_225604_3_); return world.getGeneratorStoredBiome(p_225604_1_, p_225604_2_, p_225604_3_);
} }
@Override
public DynamicRegistries getRegistryManager() {
return world.getRegistryManager();
}
@Override
public float getBrightness(Direction p_230487_1_, boolean p_230487_2_) {
return world.getBrightness(p_230487_1_, p_230487_2_);
}
} }

View file

@ -1,6 +1,7 @@
package com.simibubi.create.foundation.worldgen; package com.simibubi.create.foundation.worldgen;
import com.simibubi.create.content.curiosities.tools.SandPaperItem; import com.simibubi.create.content.curiosities.tools.SandPaperItem;
import com.simibubi.create.foundation.utility.BlockHelper;
import net.minecraft.block.Block; import net.minecraft.block.Block;
import net.minecraft.block.BlockState; import net.minecraft.block.BlockState;
import net.minecraft.entity.player.PlayerEntity; import net.minecraft.entity.player.PlayerEntity;
@ -19,7 +20,7 @@ import java.util.LinkedList;
import java.util.OptionalDouble; import java.util.OptionalDouble;
import java.util.Random; import java.util.Random;
public class OxidizingBlock extends MetalBlock { public class OxidizingBlock extends Block {
public static final IntegerProperty OXIDIZATION = IntegerProperty.create("oxidization", 0, 7); public static final IntegerProperty OXIDIZATION = IntegerProperty.create("oxidization", 0, 7);
private float chance; private float chance;
@ -30,12 +31,6 @@ public class OxidizingBlock extends MetalBlock {
setDefaultState(getDefaultState().with(OXIDIZATION, 0)); setDefaultState(getDefaultState().with(OXIDIZATION, 0));
} }
public OxidizingBlock(Properties properties, float chance, boolean isBeaconBaseBlock) {
super(properties, isBeaconBaseBlock);
this.chance = chance;
setDefaultState(getDefaultState().with(OXIDIZATION, 0));
}
@Override @Override
protected void fillStateContainer(Builder<Block, BlockState> builder) { protected void fillStateContainer(Builder<Block, BlockState> builder) {
super.fillStateContainer(builder.add(OXIDIZATION)); super.fillStateContainer(builder.add(OXIDIZATION));
@ -62,7 +57,7 @@ public class OxidizingBlock extends MetalBlock {
if (neighborState.func_235903_d_(OXIDIZATION).map(ox -> ox != 0).orElse(false)) { if (neighborState.func_235903_d_(OXIDIZATION).map(ox -> ox != 0).orElse(false)) {
neighbors.add(neighborState.get(OXIDIZATION)); neighbors.add(neighborState.get(OXIDIZATION));
} }
if (Block.hasSolidSide(neighborState, worldIn, neighbourPos, facing.getOpposite())) { if (BlockHelper.hasBlockSolidSide(neighborState, worldIn, neighbourPos, facing.getOpposite())) {
continue; continue;
} }
canIncrease = true; canIncrease = true;