2023-09-26 04:32:09 -04:00
|
|
|
elements.flipflop = {
|
2023-09-26 04:38:08 -04:00
|
|
|
powerstate: "false",
|
2023-09-26 04:32:09 -04:00
|
|
|
name: "Flip Flop",
|
2023-09-26 04:38:08 -04:00
|
|
|
color: "#CF300D",
|
2023-09-26 04:32:09 -04:00
|
|
|
state: "solid",
|
2023-09-26 04:38:08 -04:00
|
|
|
category: "machines",
|
2023-09-26 04:32:09 -04:00
|
|
|
conduct: 1,
|
|
|
|
|
tick: function(pixel) {
|
|
|
|
|
doHeat(pixel)
|
|
|
|
|
doBurning(pixel)
|
|
|
|
|
doElectricity(pixel)
|
|
|
|
|
|
2023-09-26 04:38:08 -04:00
|
|
|
let Output = pixelMap[pixel.x+1][pixel.y]
|
|
|
|
|
let Input = pixelMap[pixel.x-1][pixel.y]
|
2023-09-26 06:32:36 -04:00
|
|
|
if (typeof Output !== "undefined" && typeof Input !== "undefined"){
|
2023-09-26 06:05:49 -04:00
|
|
|
Output.charge = 0
|
2023-09-26 06:53:49 -04:00
|
|
|
if (pixel.powerstate == "true" && Input.charge > 0.2) {
|
|
|
|
|
pixel.powerstate = "false"
|
2023-09-26 06:05:49 -04:00
|
|
|
pixel.color = "#CF300D"
|
|
|
|
|
Output.charge = 0
|
2023-09-26 06:53:49 -04:00
|
|
|
} else if (pixel.powerstate == "false" && Input.charge > 0.2) {
|
|
|
|
|
pixel.powerstate = "true"
|
2023-09-26 06:05:49 -04:00
|
|
|
pixel.color = "#94CF0D"
|
|
|
|
|
Output.charge = 5
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-09-26 04:32:09 -04:00
|
|
|
}
|
|
|
|
|
};
|