sandboxels/mods/solidcolor.js

147 lines
5.4 KiB
JavaScript

// all credits to nousernamefound for onecolor.js
window.addEventListener('load', function() {
console.log("attempted override");
pixelColorPick = function(pixel, customColor = null) {
var element = pixel.element;
var elementInfo = elements[element];
if (pixel.charge && elementInfo.colorOn) {
customColor = elementInfo.colorOn;
}
if (customColor != null) {
if (Array.isArray(customColor)) {
customColor = customColor[Math.floor(Math.random() * customColor.length)];
}
if (customColor.startsWith("#")) {
customColor = hexToRGB(customColor);
}
var rgb = customColor;
} else {
var rgb = elements[element].colorObject;
if (Array.isArray(rgb)) {
rgb = rgb[Math.floor(Math.random() * rgb.length)];
}
}
var coloroffset = Math.floor(Math.random() * (Math.random() > 0.5 ? -1 : 1) * Math.random() * 15);
var r = rgb.r + 0;
var g = rgb.g + 0;
var b = rgb.b + 0;
r = Math.max(0, Math.min(255, r));
g = Math.max(0, Math.min(255, g));
b = Math.max(0, Math.min(255, b));
var color = "rgb(" + r + "," + g + "," + b + ")";
return color;
}
pixelTempCheck = function(pixel) {
if (pixel.del) { return }
var elementInfo = elements[pixel.element];
if (pixel.temp < absoluteZero) {
pixel.temp = absoluteZero;
}
if (pixel.temp >= elementInfo.tempHigh) {
var result = elementInfo.stateHigh;
if (elementInfo.extraTempHigh) {
for (var extraTemp in elementInfo.extraTempHigh) {
if (pixel.temp >= extraTemp) {
result = elementInfo.extraTempHigh[extraTemp];
}
}
}
if (Array.isArray(result)) {
result = result[Math.floor(Math.random() * result.length)];
}
if (result === null) {
deletePixel(pixel.x, pixel.y);
return false;
} else {
if (elements[result].customColor) {
changePixel(pixel, result, false);
pixel.color = color;
} else if (elementInfo.stateHighColor) {
changePixel(pixel, result, false);
pixel.color = pixelColorPick(pixel, elementInfo.stateHighColor);
} else if (elementInfo.stateHighColorMultiplier) {
var color = pixel.color;
changePixel(pixel, result, false);
var rgb = color.match(/\d+/g);
var m = elementInfo.stateHighColorMultiplier;
if (Array.isArray(m)) {
m = m[0];
}
var r = Math.floor(rgb[0] * m);
var g = Math.floor(rgb[1] * m);
var b = Math.floor(rgb[2] * m);
r = Math.max(0, Math.min(255, r));
g = Math.max(0, Math.min(255, g));
b = Math.max(0, Math.min(255, b));
pixel.color = "rgb(" + r + "," + g + "," + b + ")";
} else {
changePixel(pixel, result, false);
}
if (elementInfo.fireColor && result === "fire") {
pixel.color = pixelColorPick(pixel, elementInfo.fireColor);
}
}
}
else if (pixel.temp <= elementInfo.tempLow) {
var result = elementInfo.stateLow;
if (elementInfo.extraTempLow) {
for (var extraTemp in elementInfo.extraTempLow) {
if (pixel.temp <= extraTemp) {
result = elementInfo.extraTempLow[extraTemp];
}
}
}
if (Array.isArray(result)) {
result = result[Math.floor(Math.random() * result.length)];
}
if (result === null) {
deletePixel(pixel.x, pixel.y);
return false;
} else {
if (elements[result].customColor) {
changePixel(pixel, result, false);
pixel.color = color;
} else if (elementInfo.stateLowColor) {
changePixel(pixel, result, false);
pixel.color = pixelColorPick(pixel, elementInfo.stateLowColor);
} else if (elementInfo.stateLowColorMultiplier) {
var color = pixel.color;
changePixel(pixel, result, false);
var rgb = color.match(/\d+/g);
var m = elementInfo.stateLowColorMultiplier;
if (Array.isArray(m)) {
m = m[0];
}
var r = Math.floor(rgb[0] * m);
var g = Math.floor(rgb[1] * m);
var b = Math.floor(rgb[2] * m);
r = Math.max(0, Math.min(255, r));
g = Math.max(0, Math.min(255, g));
b = Math.max(0, Math.min(255, b));
pixel.color = "rgb(" + r + "," + g + "," + b + ")";
} else {
changePixel(pixel, result, false);
}
}
}
return true;
}
});