Merge pull request #1334 from redbirdly/main

This commit is contained in:
slweeb 2026-01-14 09:09:57 -05:00 committed by GitHub
commit 3ae01a8671
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
1 changed files with 50 additions and 0 deletions

50
mods/junction.js Normal file
View File

@ -0,0 +1,50 @@
// Junction.js
const connectedPairs = [
[[-1, 0], [1, 0]], // Horizontal
[[0, -1], [0, 1]] // Vertical
];
let isRisingEdge = (current, prev) => current === 2 && prev !== 2;
let isFallingEdge = (current, prev) => current !== 2 && prev === 2;
elements.junction = {
color: "#9db8b5",
category: "logic",
state: "solid",
behavior: behaviors.WALL,
tick: function (pixel) {
if (pixel.start === pixelTicks)
pixel.prevStateMap = {};
for (const pair of connectedPairs) {
let pixelA = pixelMap[pixel.x + pair[0][0]]?.[pixel.y + pair[0][1]];
let pixelB = pixelMap[pixel.x + pair[1][0]]?.[pixel.y + pair[1][1]];
if (!pixelA) continue;
if (!pixelB) continue;
if (pixelA.element !== "logic_wire") continue;
if (pixelB.element !== "logic_wire") continue;
let stateA = pixelA.lstate;
let stateB = pixelB.lstate;
let prevStateA = pixel.prevStateMap[[pixelA.x, pixelA.y]];
let prevStateB = pixel.prevStateMap[[pixelB.x, pixelB.y]];
// console.log("A:", stateA, "->", prevStateA);
// console.log("B:", stateB, "->", prevStateB);
// Set previous lstate to current lstate
pixel.prevStateMap[[pixelA.x, pixelA.y]] = pixelA.lstate;
pixel.prevStateMap[[pixelB.x, pixelB.y]] = pixelB.lstate;
// Rising edge
if (isRisingEdge(stateA, prevStateA)) pixelB.lstate = 2;
if (isRisingEdge(stateB, prevStateB)) pixelA.lstate = 2;
// Falling edge
if (isFallingEdge(stateA, prevStateA)) pixelB.lstate = -2;
if (isFallingEdge(stateB, prevStateB)) pixelA.lstate = -2;
}
}
};