1
0
mirror of https://github.com/tobspr/shapez.io.git synced 2025-06-13 13:04:03 +00:00

Added shape generator ingame

This commit is contained in:
DJ1TJOO 2021-03-14 09:41:47 +01:00
parent 7ed6a9c7b6
commit 71d5ac0401
7 changed files with 7480 additions and 7570 deletions

View File

@ -0,0 +1,12 @@
#ingame_HUD_Web {
.content {
@include S(width, 500px);
height: calc(100vh - #{D(40px)});
iframe {
width: 100%;
height: 98%;
border: none;
overflow: visible;
}
}
}

View File

@ -55,6 +55,7 @@
@import "ingame_hud/sandbox_controller"; @import "ingame_hud/sandbox_controller";
@import "ingame_hud/standalone_advantages"; @import "ingame_hud/standalone_advantages";
@import "ingame_hud/cat_memes"; @import "ingame_hud/cat_memes";
@import "ingame_hud/web_viewer";
// prettier-ignore // prettier-ignore
$elements: $elements:
@ -84,6 +85,7 @@ ingame_HUD_WatermarkClicker,
ingame_HUD_Watermark, ingame_HUD_Watermark,
ingame_HUD_ColorBlindBelowTileHelper, ingame_HUD_ColorBlindBelowTileHelper,
ingame_HUD_SandboxController, ingame_HUD_SandboxController,
ingame_HUD_Web,
// Overlays // Overlays
ingame_HUD_BetaOverlay, ingame_HUD_BetaOverlay,

View File

@ -49,6 +49,7 @@ import { HUDStandaloneAdvantages } from "./parts/standalone_advantages";
import { HUDCatMemes } from "./parts/cat_memes"; import { HUDCatMemes } from "./parts/cat_memes";
import { HUDTutorialVideoOffer } from "./parts/tutorial_video_offer"; import { HUDTutorialVideoOffer } from "./parts/tutorial_video_offer";
import { HUDConstantSignalEdit } from "./parts/constant_signal_edit"; import { HUDConstantSignalEdit } from "./parts/constant_signal_edit";
import { HUDWebViewer } from "./parts/web_viewer";
export class GameHUD { export class GameHUD {
/** /**
@ -88,6 +89,7 @@ export class GameHUD {
wireInfo: new HUDWireInfo(this.root), wireInfo: new HUDWireInfo(this.root),
leverToggle: new HUDLeverToggle(this.root), leverToggle: new HUDLeverToggle(this.root),
constantSignalEdit: new HUDConstantSignalEdit(this.root), constantSignalEdit: new HUDConstantSignalEdit(this.root),
webViewer: new HUDWebViewer(this.root),
// Must always exist // Must always exist
pinnedShapes: new HUDPinnedShapes(this.root), pinnedShapes: new HUDPinnedShapes(this.root),

View File

@ -0,0 +1,74 @@
import { InputReceiver } from "../../../core/input_receiver";
import { makeDiv } from "../../../core/utils";
import { KeyActionMapper, KEYMAPPINGS } from "../../key_action_mapper";
import { BaseHUDPart } from "../base_hud_part";
import { DynamicDomAttach } from "../dynamic_dom_attach";
export class HUDWebViewer extends BaseHUDPart {
createElements(parent) {
this.background = makeDiv(parent, "ingame_HUD_Web", ["ingameDialog"]);
// DIALOG Inner / Wrapper
this.dialogInner = makeDiv(this.background, null, ["dialogInner"]);
this.title = makeDiv(this.dialogInner, null, ["title"], "Empty Web");
this.closeButton = makeDiv(this.title, null, ["closeButton"]);
this.trackClicks(this.closeButton, this.close);
this.contentDiv = makeDiv(this.dialogInner, null, ["content"]);
}
initialize() {
this.domAttach = new DynamicDomAttach(this.root, this.background, {
attachClass: "visible",
});
this.inputReciever = new InputReceiver("web_viewer");
this.keyActionMapper = new KeyActionMapper(this.root, this.inputReciever);
this.keyActionMapper.getBinding(KEYMAPPINGS.general.back).add(this.close, this);
this.keyActionMapper.getBinding(KEYMAPPINGS.ingame.menuClose).add(this.close, this);
this.root.keyMapper.getBinding(KEYMAPPINGS.ingame.shapeViewer).add(this.openViewer, this);
this.close();
}
show(url, title = null) {
this.visible = true;
this.root.app.inputMgr.makeSureAttachedAndOnTop(this.inputReciever);
this.url = url;
let ifrm = document.createElement("iframe");
ifrm.setAttribute("id", "ingame_HUD_web_iframe");
ifrm.setAttribute("src", this.url);
if (!title) {
let urlTag = document.createElement("a");
urlTag.href = this.url;
title = urlTag.hostname;
}
this.title.innerText = title;
this.closeButton = makeDiv(this.title, null, ["closeButton"]);
this.trackClicks(this.closeButton, this.close);
this.contentDiv.innerHTML = "";
this.contentDiv.appendChild(ifrm);
}
openViewer() {
this.show("https://viewer.shapez.io/", "Shapes Generator");
}
close() {
this.visible = false;
this.root.app.inputMgr.makeSureDetached(this.inputReciever);
this.update();
}
update() {
this.domAttach.update(this.visible);
}
isBlockingOverlay() {
return this.visible;
}
}

View File

@ -32,6 +32,8 @@ export const KEYMAPPINGS = {
toggleFPSInfo: { keyCode: 115 }, // F4 toggleFPSInfo: { keyCode: 115 }, // F4
switchLayers: { keyCode: key("E") }, switchLayers: { keyCode: key("E") },
shapeViewer: { keyCode: 119 }, // F8
}, },
navigation: { navigation: {

View File

@ -1102,6 +1102,7 @@ keybindings:
toggleFPSInfo: Toggle FPS and Debug Info toggleFPSInfo: Toggle FPS and Debug Info
switchLayers: Switch layers switchLayers: Switch layers
exportScreenshot: Export whole Base as Image exportScreenshot: Export whole Base as Image
shapeViewer: Open shape viewer ingame
# --- Do not translate the values in this section # --- Do not translate the values in this section
belt: *belt belt: *belt

14957
yarn.lock

File diff suppressed because it is too large Load Diff