First Steps

This commit is contained in:
simibubi 2021-02-09 22:34:14 +01:00
parent 4a5479838c
commit 6836bd97f4
18 changed files with 663 additions and 38 deletions

View file

@ -16,6 +16,8 @@ import com.simibubi.create.foundation.block.render.CustomBlockModels;
import com.simibubi.create.foundation.block.render.SpriteShifter; import com.simibubi.create.foundation.block.render.SpriteShifter;
import com.simibubi.create.foundation.item.CustomItemModels; import com.simibubi.create.foundation.item.CustomItemModels;
import com.simibubi.create.foundation.item.CustomRenderedItems; import com.simibubi.create.foundation.item.CustomRenderedItems;
import com.simibubi.create.foundation.metadoc.MetaDocs;
import com.simibubi.create.foundation.metadoc.WorldSectionElement;
import com.simibubi.create.foundation.utility.SuperByteBufferCache; import com.simibubi.create.foundation.utility.SuperByteBufferCache;
import com.simibubi.create.foundation.utility.outliner.Outliner; import com.simibubi.create.foundation.utility.outliner.Outliner;
@ -66,6 +68,7 @@ public class CreateClient {
bufferCache = new SuperByteBufferCache(); bufferCache = new SuperByteBufferCache();
bufferCache.registerCompartment(KineticTileEntityRenderer.KINETIC_TILE); bufferCache.registerCompartment(KineticTileEntityRenderer.KINETIC_TILE);
bufferCache.registerCompartment(ContraptionRenderer.CONTRAPTION, 20); bufferCache.registerCompartment(ContraptionRenderer.CONTRAPTION, 20);
bufferCache.registerCompartment(WorldSectionElement.DOC_WORLD_SECTION, 20);
AllKeys.register(); AllKeys.register();
AllContainerTypes.registerScreenFactories(); AllContainerTypes.registerScreenFactories();
@ -73,6 +76,7 @@ public class CreateClient {
AllEntityTypes.registerRenderers(); AllEntityTypes.registerRenderers();
getColorHandler().init(); getColorHandler().init();
AllFluids.assignRenderLayers(); AllFluids.assignRenderLayers();
MetaDocs.register();
IResourceManager resourceManager = Minecraft.getInstance() IResourceManager resourceManager = Minecraft.getInstance()
.getResourceManager(); .getResourceManager();

View file

@ -26,7 +26,7 @@ import com.simibubi.create.content.logistics.block.mechanicalArm.ArmInteractionP
import com.simibubi.create.foundation.config.AllConfigs; import com.simibubi.create.foundation.config.AllConfigs;
import com.simibubi.create.foundation.gui.ScreenOpener; import com.simibubi.create.foundation.gui.ScreenOpener;
import com.simibubi.create.foundation.item.TooltipHelper; import com.simibubi.create.foundation.item.TooltipHelper;
import com.simibubi.create.foundation.metadoc.MetaDocHandler; import com.simibubi.create.foundation.metadoc.MetaDocTooltipHandler;
import com.simibubi.create.foundation.networking.AllPackets; import com.simibubi.create.foundation.networking.AllPackets;
import com.simibubi.create.foundation.networking.LeftClickPacket; import com.simibubi.create.foundation.networking.LeftClickPacket;
import com.simibubi.create.foundation.renderState.SuperRenderTypeBuffer; import com.simibubi.create.foundation.renderState.SuperRenderTypeBuffer;
@ -88,7 +88,7 @@ public class ClientEvents {
CapabilityMinecartController.tick(world); CapabilityMinecartController.tick(world);
CouplingPhysics.tick(world); CouplingPhysics.tick(world);
MetaDocHandler.tick(); MetaDocTooltipHandler.tick();
ScreenOpener.tick(); ScreenOpener.tick();
ServerSpeedProvider.clientTick(); ServerSpeedProvider.clientTick();
BeltConnectorHandler.tick(); BeltConnectorHandler.tick();
@ -150,7 +150,7 @@ public class ClientEvents {
@SubscribeEvent @SubscribeEvent
public static void getItemTooltipColor(RenderTooltipEvent.Color event) { public static void getItemTooltipColor(RenderTooltipEvent.Color event) {
MetaDocHandler.handleTooltipColor(event); MetaDocTooltipHandler.handleTooltipColor(event);
} }
@SubscribeEvent @SubscribeEvent
@ -175,7 +175,7 @@ public class ClientEvents {
itemTooltip.addAll(0, toolTip); itemTooltip.addAll(0, toolTip);
} }
MetaDocHandler.addToTooltip(event.getToolTip(), stack); MetaDocTooltipHandler.addToTooltip(event.getToolTip(), stack);
} }
@SubscribeEvent @SubscribeEvent

View file

@ -0,0 +1,43 @@
package com.simibubi.create.foundation.metadoc;
import com.mojang.blaze3d.matrix.MatrixStack;
import com.simibubi.create.foundation.utility.LerpedFloat;
import com.simibubi.create.foundation.utility.MatrixStacker;
import net.minecraft.client.Minecraft;
import net.minecraft.client.renderer.IRenderTypeBuffer;
import net.minecraft.util.math.Vec3d;
public abstract class AnimatedSceneElement extends MetaDocSceneElement {
protected Vec3d fadeVec;
protected LerpedFloat fade;
public AnimatedSceneElement() {
fade = LerpedFloat.linear()
.startWithValue(0);
}
public void setFade(float fade) {
this.fade.setValue(fade);
}
public void setFadeVec(Vec3d fadeVec) {
this.fadeVec = fadeVec;
}
@Override
public final void render(MetaDocWorld world, IRenderTypeBuffer buffer, MatrixStack ms) {
ms.push();
float currentFade = fade.getValue(Minecraft.getInstance()
.getRenderPartialTicks());
if (fadeVec != null)
MatrixStacker.of(ms)
.translate(fadeVec.scale(-1 + currentFade));
render(world, buffer, ms, currentFade);
ms.pop();
}
protected abstract void render(MetaDocWorld world, IRenderTypeBuffer buffer, MatrixStack ms, float fade);
}

View file

@ -0,0 +1,13 @@
package com.simibubi.create.foundation.metadoc;
public abstract class MetaDocInstruction {
public boolean isBlocking() {
return false;
}
public abstract boolean isComplete();
public abstract void tick(MetaDocScene scene);
}

View file

@ -0,0 +1,117 @@
package com.simibubi.create.foundation.metadoc;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.IdentityHashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Set;
import com.mojang.blaze3d.matrix.MatrixStack;
import com.simibubi.create.foundation.metadoc.instructions.DelayInstruction;
import com.simibubi.create.foundation.metadoc.instructions.DisplayWorldSectionInstruction;
import com.simibubi.create.foundation.metadoc.instructions.ShowCompleteSchematicInstruction;
import net.minecraft.client.renderer.IRenderTypeBuffer;
import net.minecraft.util.Direction;
import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.MutableBoundingBox;
import net.minecraft.util.math.Vec3i;
public class MetaDocScene {
List<MetaDocInstruction> schedule, activeSchedule;
Set<MetaDocSceneElement> elements;
Map<Object, Set<MetaDocSceneElement>> groups;
MetaDocWorld world;
public MetaDocScene(MetaDocWorld world) {
this.world = world;
elements = new HashSet<>();
groups = new IdentityHashMap<>();
schedule = new ArrayList<>();
activeSchedule = new ArrayList<>();
}
public void begin() {
activeSchedule.clear();
activeSchedule.addAll(schedule);
}
public void render(IRenderTypeBuffer buffer, MatrixStack ms) {
ms.push();
MutableBoundingBox bounds = world.getBounds();
ms.translate(bounds.getXSize() / -2f, -.5f, bounds.getZSize() / -2f);
elements.forEach(e -> {
if (e.visible)
e.render(world, buffer, ms);
});
ms.pop();
}
public void tick() {
for (Iterator<MetaDocInstruction> iterator = activeSchedule.iterator(); iterator.hasNext();) {
MetaDocInstruction metaDocInstruction = iterator.next();
metaDocInstruction.tick(this);
if (metaDocInstruction.isComplete()) {
iterator.remove();
continue;
}
if (metaDocInstruction.isBlocking())
break;
}
}
public void addElement(MetaDocSceneElement e) {
elements.add(e);
}
public MetaDocWorld getWorld() {
return world;
}
public MutableBoundingBox getBounds() {
return world.getBounds();
}
public SceneBuilder builder() {
return new SceneBuilder();
}
public class SceneBuilder {
public SceneBuilder showBasePlate() {
Vec3i length = getBounds().getLength();
return showSection(BlockPos.ZERO, new Vec3i(length.getX(), 0, length.getZ()), Direction.UP);
}
public SceneBuilder showSection(BlockPos origin, Vec3i size, Direction fadeInDirection) {
return addInstruction(
new DisplayWorldSectionInstruction(10, fadeInDirection, new WorldSectionElement.Cuboid(origin, size)));
}
public SceneBuilder showSection(WorldSectionElement element, Direction fadeInDirection) {
return addInstruction(new DisplayWorldSectionInstruction(10, fadeInDirection, element));
}
public SceneBuilder debugSchematic() {
return addInstruction(new ShowCompleteSchematicInstruction());
}
public SceneBuilder idle(int ticks) {
return addInstruction(new DelayInstruction(ticks));
}
public SceneBuilder idleSeconds(int seconds) {
return idle(seconds * 20);
}
public SceneBuilder addInstruction(MetaDocInstruction instruction) {
schedule.add(instruction);
return this;
}
}
}

View file

@ -0,0 +1,13 @@
package com.simibubi.create.foundation.metadoc;
import com.mojang.blaze3d.matrix.MatrixStack;
import net.minecraft.client.renderer.IRenderTypeBuffer;
public abstract class MetaDocSceneElement {
boolean visible = true;
public abstract void render(MetaDocWorld world, IRenderTypeBuffer buffer, MatrixStack ms);
}

View file

@ -1,29 +1,86 @@
package com.simibubi.create.foundation.metadoc; package com.simibubi.create.foundation.metadoc;
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.foundation.gui.AbstractSimiScreen; import com.simibubi.create.foundation.gui.AbstractSimiScreen;
import com.simibubi.create.foundation.gui.GuiGameElement; import com.simibubi.create.foundation.gui.AllIcons;
import com.simibubi.create.foundation.utility.AnimationTickHolder; import com.simibubi.create.foundation.renderState.SuperRenderTypeBuffer;
import com.simibubi.create.foundation.utility.LerpedFloat;
import com.simibubi.create.foundation.utility.LerpedFloat.Chaser;
import com.simibubi.create.foundation.utility.MatrixStacker;
import net.minecraft.block.Blocks;
import net.minecraftforge.fml.client.gui.GuiUtils; import net.minecraftforge.fml.client.gui.GuiUtils;
public class MetaDocScreen extends AbstractSimiScreen { public class MetaDocScreen extends AbstractSimiScreen {
private List<MetaDocScene> stories;
private int index = 0;
private LerpedFloat fadeIn;
public MetaDocScreen(List<MetaDocScene> stories) {
this.stories = stories;
fadeIn = LerpedFloat.linear()
.startWithValue(0)
.chase(1, .5f, Chaser.EXP);
}
@Override
public void tick() {
fadeIn.tickChaser();
stories.get(index)
.tick();
}
@Override @Override
protected void renderWindow(int mouseX, int mouseY, float partialTicks) { protected void renderWindow(int mouseX, int mouseY, float partialTicks) {
RenderSystem.enableBlend();
renderStory();
renderWidgets(partialTicks);
}
int tooltipX = 50; protected void renderStory() {
int tooltipY = 50; MetaDocScene story = stories.get(index);
int tooltipTextWidth = width - 100; MatrixStack ms = new MatrixStack();
int backgroundColor = GuiUtils.DEFAULT_BACKGROUND_COLOR; ms.push();
int borderColorStart = GuiUtils.DEFAULT_BORDER_COLOR_START;
int borderColorEnd = GuiUtils.DEFAULT_BORDER_COLOR_END;
int zLevel = 100;
int tooltipHeight = height - 100;
drawString(font, "MetaDoc Experimental 0", tooltipX, tooltipY - 16, 0xffffff); ms.translate(width / 2, height / 2, 200);
MatrixStacker.of(ms)
.rotateX(-45)
.rotateY(45);
ms.scale(30, -30, 30);
SuperRenderTypeBuffer buffer = SuperRenderTypeBuffer.getInstance();
story.render(buffer, ms);
buffer.draw();
ms.pop();
}
protected void renderWidgets(float pt) {
float fade = fadeIn.getValue(pt);
int textColor = 0xeeeeee;
drawString(font, "MetaDoc Experimental 0", 50, 50 - 16, textColor);
RenderSystem.pushMatrix();
if (fade < 1)
RenderSystem.translated(0, (1 - fade) * 5, 0);
int closeWidth = 24;
int closeHeight = 24;
int closeX = (width - closeWidth) / 2;
int closeY = height - closeHeight - 31;
renderBox(closeX, closeY, closeWidth, closeHeight, 0xdd000000, 0x30eebb00, 0x10eebb00);
AllIcons.I_CONFIRM.draw(closeX + 4, closeY + 4);
RenderSystem.popMatrix();
}
protected void renderBox(int tooltipX, int tooltipY, int tooltipTextWidth, int tooltipHeight, int backgroundColor,
int borderColorStart, int borderColorEnd) {
int zLevel = 400;
GuiUtils.drawGradientRect(zLevel, tooltipX - 3, tooltipY - 4, tooltipX + tooltipTextWidth + 3, tooltipY - 3, GuiUtils.drawGradientRect(zLevel, tooltipX - 3, tooltipY - 4, tooltipX + tooltipTextWidth + 3, tooltipY - 3,
backgroundColor, backgroundColor); backgroundColor, backgroundColor);
GuiUtils.drawGradientRect(zLevel, tooltipX - 3, tooltipY + tooltipHeight + 3, tooltipX + tooltipTextWidth + 3, GuiUtils.drawGradientRect(zLevel, tooltipX - 3, tooltipY + tooltipHeight + 3, tooltipX + tooltipTextWidth + 3,
@ -42,15 +99,6 @@ public class MetaDocScreen extends AbstractSimiScreen {
borderColorStart, borderColorStart); borderColorStart, borderColorStart);
GuiUtils.drawGradientRect(zLevel, tooltipX - 3, tooltipY + tooltipHeight + 2, tooltipX + tooltipTextWidth + 3, GuiUtils.drawGradientRect(zLevel, tooltipX - 3, tooltipY + tooltipHeight + 2, tooltipX + tooltipTextWidth + 3,
tooltipY + tooltipHeight + 3, borderColorEnd, borderColorEnd); tooltipY + tooltipHeight + 3, borderColorEnd, borderColorEnd);
RenderSystem.pushMatrix();
RenderSystem.translated(width/2, height/2, 200);
GuiGameElement.of(Blocks.DIAMOND_BLOCK.getDefaultState())
.rotate(22.5, AnimationTickHolder.getRenderTick() % 360f, 0)
.scale(50)
.render();
RenderSystem.popMatrix();
} }
} }

View file

@ -0,0 +1,13 @@
package com.simibubi.create.foundation.metadoc;
import com.simibubi.create.foundation.metadoc.MetaDocScene.SceneBuilder;
import net.minecraft.util.math.Vec3i;
public abstract class MetaDocStoryBoard {
public abstract String getSchematicName();
public abstract void program(SceneBuilder scene, Vec3i worldSize);
}

View file

@ -18,7 +18,7 @@ import net.minecraft.util.text.StringTextComponent;
import net.minecraft.util.text.TextFormatting; import net.minecraft.util.text.TextFormatting;
import net.minecraftforge.client.event.RenderTooltipEvent; import net.minecraftforge.client.event.RenderTooltipEvent;
public class MetaDocHandler { public class MetaDocTooltipHandler {
static LerpedFloat holdWProgress = LerpedFloat.linear() static LerpedFloat holdWProgress = LerpedFloat.linear()
.startWithValue(0); .startWithValue(0);
@ -38,21 +38,27 @@ public class MetaDocHandler {
return; return;
ItemStack stack = slotUnderMouse.getStack(); ItemStack stack = slotUnderMouse.getStack();
if (!MetaDocs.all.containsKey(stack.getItem()
.getRegistryName()))
return;
if (prevStack != stack) if (prevStack != stack)
holdWProgress.startWithValue(0); holdWProgress.startWithValue(0);
float value = holdWProgress.getValue(); float value = holdWProgress.getValue();
if (InputMappings.isKeyDown(instance.getWindow() int keyCode = instance.gameSettings.keyBindForward.getKey()
.getHandle(), .getKeyCode();
instance.gameSettings.keyBindForward.getKey() long window = instance.getWindow()
.getKeyCode())) { .getHandle();
// if (AllKeys.altDown()) {
if (InputMappings.isKeyDown(window, keyCode)) {
if (value >= 1) if (value >= 1)
ScreenOpener.open(new MetaDocScreen()); ScreenOpener.open(new MetaDocScreen(MetaDocs.compile(stack.getItem()
.getRegistryName())));
holdWProgress.setValue(Math.min(1, value + Math.max(.25f, value) * .25f)); holdWProgress.setValue(Math.min(1, value + Math.max(.25f, value) * .25f));
} else { } else
holdWProgress.setValue(Math.max(0, value - .05f)); holdWProgress.setValue(Math.max(0, value - .05f));
}
lastHoveredStack = stack; lastHoveredStack = stack;
} }
@ -88,7 +94,7 @@ public class MetaDocHandler {
return ColorHelper.mixColors(0x5000FF, 5592575, progress * 2); return ColorHelper.mixColors(0x5000FF, 5592575, progress * 2);
// if (progress < .75f) // if (progress < .75f)
// return ColorHelper.mixColors(16733695, 5636095, (progress - .5f) * 4); // return ColorHelper.mixColors(16733695, 5636095, (progress - .5f) * 4);
return ColorHelper.mixColors(5592575, 5636095, (progress - .5f) * 2); return ColorHelper.mixColors(5592575, 0xffffff, (progress - .5f) * 2);
} }
private static ITextComponent makeProgressBar(float progress) { private static ITextComponent makeProgressBar(float progress) {
@ -98,11 +104,11 @@ public class MetaDocHandler {
if (progress < 1) if (progress < 1)
bar += Strings.repeat("\u2592", 12 - filledLength); bar += Strings.repeat("\u2592", 12 - filledLength);
TextFormatting color = TextFormatting.GRAY; TextFormatting color = TextFormatting.DARK_GRAY;
if (progress > 0) if (progress > 0)
color = TextFormatting.BLUE; color = TextFormatting.GRAY;
if (progress == 1f) if (progress == 1f)
color = TextFormatting.AQUA; color = TextFormatting.WHITE;
ITextComponent leftBr = new StringTextComponent("").applyTextStyle(TextFormatting.WHITE); ITextComponent leftBr = new StringTextComponent("").applyTextStyle(TextFormatting.WHITE);
ITextComponent rightBr = new StringTextComponent("").applyTextStyle(TextFormatting.WHITE); ITextComponent rightBr = new StringTextComponent("").applyTextStyle(TextFormatting.WHITE);

View file

@ -0,0 +1,14 @@
package com.simibubi.create.foundation.metadoc;
import com.simibubi.create.content.schematics.SchematicWorld;
import net.minecraft.util.math.BlockPos;
import net.minecraft.world.World;
public class MetaDocWorld extends SchematicWorld {
public MetaDocWorld(BlockPos anchor, World original) {
super(anchor, original);
}
}

View file

@ -0,0 +1,73 @@
package com.simibubi.create.foundation.metadoc;
import java.io.BufferedInputStream;
import java.io.DataInputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
import java.util.zip.GZIPInputStream;
import com.simibubi.create.AllBlocks;
import com.simibubi.create.Create;
import com.simibubi.create.foundation.metadoc.stories.CogwheelStory;
import com.tterrag.registrate.util.entry.ItemProviderEntry;
import net.minecraft.client.Minecraft;
import net.minecraft.nbt.CompoundNBT;
import net.minecraft.nbt.CompressedStreamTools;
import net.minecraft.nbt.NBTSizeTracker;
import net.minecraft.util.ResourceLocation;
import net.minecraft.util.math.BlockPos;
import net.minecraft.world.gen.feature.template.PlacementSettings;
import net.minecraft.world.gen.feature.template.Template;
public class MetaDocs {
static Map<ResourceLocation, List<MetaDocStoryBoard>> all = new HashMap<>();
public static void register() {
addStoryBoard(AllBlocks.COGWHEEL, new CogwheelStory());
}
private static void addStoryBoard(ItemProviderEntry<?> component, MetaDocStoryBoard storyBoard) {
ResourceLocation id = component.getId();
all.computeIfAbsent(id, $ -> new ArrayList<>())
.add(storyBoard);
}
public static List<MetaDocScene> compile(ResourceLocation id) {
return all.get(id)
.stream()
.map(sb -> {
Template activeTemplate = loadSchematic(sb.getSchematicName());
MetaDocWorld world = new MetaDocWorld(BlockPos.ZERO, Minecraft.getInstance().world);
activeTemplate.addBlocksToWorld(world, BlockPos.ZERO, new PlacementSettings());
MetaDocScene scene = new MetaDocScene(world);
sb.program(scene.builder(), world.getBounds()
.getLength());
scene.begin();
return scene;
})
.collect(Collectors.toList());
}
public static Template loadSchematic(String path) {
Template t = new Template();
String filepath = "doc/" + path + ".nbt";
try (DataInputStream stream =
new DataInputStream(new BufferedInputStream(new GZIPInputStream(Create.class.getClassLoader()
.getResourceAsStream(filepath))))) {
CompoundNBT nbt = CompressedStreamTools.read(stream, new NBTSizeTracker(0x20000000L));
t.read(nbt);
} catch (IOException e) {
Create.logger.warn("Failed to read metadoc schematic", e);
}
return t;
}
}

View file

@ -0,0 +1,152 @@
package com.simibubi.create.foundation.metadoc;
import java.util.ArrayList;
import java.util.List;
import java.util.Objects;
import java.util.Random;
import java.util.function.Predicate;
import java.util.stream.Stream;
import org.apache.commons.lang3.tuple.Pair;
import org.lwjgl.opengl.GL11;
import com.mojang.blaze3d.matrix.MatrixStack;
import com.simibubi.create.CreateClient;
import com.simibubi.create.foundation.utility.SuperByteBuffer;
import com.simibubi.create.foundation.utility.SuperByteBufferCache;
import com.simibubi.create.foundation.utility.SuperByteBufferCache.Compartment;
import com.simibubi.create.foundation.utility.TileEntityRenderHelper;
import net.minecraft.block.BlockRenderType;
import net.minecraft.block.BlockState;
import net.minecraft.client.Minecraft;
import net.minecraft.client.renderer.BlockModelRenderer;
import net.minecraft.client.renderer.BlockRendererDispatcher;
import net.minecraft.client.renderer.BufferBuilder;
import net.minecraft.client.renderer.IRenderTypeBuffer;
import net.minecraft.client.renderer.RenderType;
import net.minecraft.client.renderer.RenderTypeLookup;
import net.minecraft.client.renderer.model.IBakedModel;
import net.minecraft.client.renderer.texture.OverlayTexture;
import net.minecraft.client.renderer.vertex.DefaultVertexFormats;
import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.MutableBoundingBox;
import net.minecraft.util.math.Vec3i;
import net.minecraftforge.client.ForgeHooksClient;
import net.minecraftforge.client.model.data.EmptyModelData;
public abstract class WorldSectionElement extends AnimatedSceneElement implements Predicate<BlockPos> {
public static final Compartment<Pair<Integer, Integer>> DOC_WORLD_SECTION = new Compartment<>();
List<TileEntity> renderedTileEntities;
@Override
public void render(MetaDocWorld world, IRenderTypeBuffer buffer, MatrixStack ms, float fade) {
renderTileEntities(world, ms, buffer);
if (buffer instanceof IRenderTypeBuffer.Impl)
((IRenderTypeBuffer.Impl) buffer).draw();
renderStructure(world, ms, buffer, fade);
}
@Override
public abstract int hashCode();
public abstract Stream<BlockPos> all();
public static class Cuboid extends WorldSectionElement {
MutableBoundingBox bb;
Vec3i origin;
Vec3i size;
public Cuboid(BlockPos origin, Vec3i size) {
bb = new MutableBoundingBox(origin, origin.add(size));
this.origin = origin;
this.size = size;
}
@Override
public boolean test(BlockPos t) {
return bb.isVecInside(t);
}
@Override
public Stream<BlockPos> all() {
return BlockPos.func_229383_a_(bb);
}
@Override
public int hashCode() {
return origin.hashCode() ^ size.hashCode();
}
}
protected void renderStructure(MetaDocWorld world, MatrixStack ms, IRenderTypeBuffer buffer, float fade) {
SuperByteBufferCache bufferCache = CreateClient.bufferCache;
List<RenderType> blockLayers = RenderType.getBlockLayers();
int code = hashCode();
buffer.getBuffer(RenderType.getSolid());
for (int i = 0; i < blockLayers.size(); i++) {
RenderType layer = blockLayers.get(i);
Pair<Integer, Integer> key = Pair.of(code, i);
SuperByteBuffer contraptionBuffer =
bufferCache.get(DOC_WORLD_SECTION, key, () -> buildStructureBuffer(world, layer));
if (contraptionBuffer.isEmpty())
continue;
int light = 0xF000F0;
if (fade != 1) {
light = (int) (0xF * fade);
light = light << 4 | light << 20;
}
contraptionBuffer.light(light)
.renderInto(ms, buffer.getBuffer(layer));
}
}
private void renderTileEntities(MetaDocWorld world, MatrixStack ms, IRenderTypeBuffer buffer) {
if (renderedTileEntities == null) {
renderedTileEntities = new ArrayList<>();
all().map(world::getTileEntity)
.filter(Objects::nonNull)
.forEach(renderedTileEntities::add);
}
TileEntityRenderHelper.renderTileEntities(world, renderedTileEntities, ms, new MatrixStack(), buffer);
}
private SuperByteBuffer buildStructureBuffer(MetaDocWorld world, RenderType layer) {
ForgeHooksClient.setRenderLayer(layer);
MatrixStack ms = new MatrixStack();
BlockRendererDispatcher dispatcher = Minecraft.getInstance()
.getBlockRendererDispatcher();
BlockModelRenderer blockRenderer = dispatcher.getBlockModelRenderer();
Random random = new Random();
BufferBuilder builder = new BufferBuilder(DefaultVertexFormats.BLOCK.getIntegerSize());
builder.begin(GL11.GL_QUADS, DefaultVertexFormats.BLOCK);
all().forEach(pos -> {
BlockState state = world.getBlockState(pos);
if (state.getRenderType() == BlockRenderType.ENTITYBLOCK_ANIMATED)
return;
if (!RenderTypeLookup.canRenderInLayer(state, layer))
return;
IBakedModel originalModel = dispatcher.getModelForState(state);
ms.push();
ms.translate(pos.getX(), pos.getY(), pos.getZ());
blockRenderer.renderModel(world, originalModel, state, pos, ms, builder, true, random, 42,
OverlayTexture.DEFAULT_UV, EmptyModelData.INSTANCE);
ms.pop();
});
builder.finishDrawing();
return new SuperByteBuffer(builder);
}
}

View file

@ -0,0 +1,9 @@
package com.simibubi.create.foundation.metadoc.instructions;
public class DelayInstruction extends TickingInstruction {
public DelayInstruction(int ticks) {
super(true, ticks);
}
}

View file

@ -0,0 +1,37 @@
package com.simibubi.create.foundation.metadoc.instructions;
import com.simibubi.create.foundation.metadoc.MetaDocScene;
import com.simibubi.create.foundation.metadoc.WorldSectionElement;
import net.minecraft.util.Direction;
import net.minecraft.util.math.Vec3d;
public class DisplayWorldSectionInstruction extends TickingInstruction {
private Direction fadeInFrom;
private WorldSectionElement element;
public DisplayWorldSectionInstruction(int fadeInTicks, Direction fadeInFrom, WorldSectionElement element) {
super(false, fadeInTicks);
this.fadeInFrom = fadeInFrom;
this.element = element;
}
@Override
protected void firstTick(MetaDocScene scene) {
super.firstTick(scene);
scene.addElement(element);
element.setFade(0);
element.setFadeVec(new Vec3d(fadeInFrom.getDirectionVec()).scale(.5f));
}
@Override
public void tick(MetaDocScene scene) {
super.tick(scene);
float fade = (remainingTicks / (float) totalTicks);
element.setFade(1 - fade * fade);
if (remainingTicks == 0)
element.setFade(1);
}
}

View file

@ -0,0 +1,22 @@
package com.simibubi.create.foundation.metadoc.instructions;
import com.simibubi.create.foundation.metadoc.MetaDocInstruction;
import com.simibubi.create.foundation.metadoc.MetaDocScene;
import com.simibubi.create.foundation.metadoc.WorldSectionElement;
import net.minecraft.util.math.BlockPos;
public class ShowCompleteSchematicInstruction extends MetaDocInstruction {
@Override
public void tick(MetaDocScene scene) {
scene.addElement(new WorldSectionElement.Cuboid(BlockPos.ZERO, scene.getBounds()
.getLength()));
}
@Override
public boolean isComplete() {
return true;
}
}

View file

@ -0,0 +1,37 @@
package com.simibubi.create.foundation.metadoc.instructions;
import com.simibubi.create.foundation.metadoc.MetaDocInstruction;
import com.simibubi.create.foundation.metadoc.MetaDocScene;
public abstract class TickingInstruction extends MetaDocInstruction {
private boolean blocking;
protected int totalTicks;
protected int remainingTicks;
public TickingInstruction(boolean blocking, int ticks) {
this.blocking = blocking;
remainingTicks = totalTicks = ticks;
}
protected void firstTick(MetaDocScene scene) {}
@Override
public void tick(MetaDocScene scene) {
if (remainingTicks == totalTicks)
firstTick(scene);
if (remainingTicks > 0)
remainingTicks--;
}
@Override
public boolean isComplete() {
return remainingTicks == 0;
}
@Override
public boolean isBlocking() {
return blocking;
}
}

View file

@ -0,0 +1,24 @@
package com.simibubi.create.foundation.metadoc.stories;
import com.simibubi.create.foundation.metadoc.MetaDocScene.SceneBuilder;
import com.simibubi.create.foundation.metadoc.MetaDocStoryBoard;
import net.minecraft.util.Direction;
import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.Vec3i;
public class CogwheelStory extends MetaDocStoryBoard {
@Override
public String getSchematicName() {
return "cogwheel/test";
}
@Override
public void program(SceneBuilder scene, Vec3i worldSize) {
scene.showBasePlate()
.idle(5)
.showSection(BlockPos.ZERO.up(), worldSize, Direction.DOWN);
}
}

Binary file not shown.