Pixel-Composer/scripts/node_gradient_palette/node_gradient_palette.gml

74 lines
2.4 KiB
Text
Raw Normal View History

2023-03-02 07:59:14 +01:00
function Node_Gradient_Palette(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
2023-12-10 02:48:10 +01:00
name = "Palette to Gradient";
w = 96;
2023-03-02 07:59:14 +01:00
2023-07-21 12:40:20 +02:00
inputs[| 0] = nodeValue("Palette", self, JUNCTION_CONNECT.input, VALUE_TYPE.color, DEF_PALETTE )
2023-03-02 07:59:14 +01:00
.setDisplay(VALUE_DISPLAY.palette)
.setVisible(true, true);
inputs[| 1] = nodeValue("Custom positions", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, false);
inputs[| 2] = nodeValue("Positions", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, [], "Array of number indicating color position (0 - 1).")
.setVisible(true, true);
inputs[| 2].array_depth = 1;
2024-03-14 14:35:19 +01:00
inputs[| 3] = nodeValue("Color Space", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 1)
2024-02-12 10:25:23 +01:00
.setDisplay(VALUE_DISPLAY.enum_button, [ "Hard", "RGB", "HSV", "OKLAB", "sRGB" ]);
2023-03-02 07:59:14 +01:00
2023-05-28 20:00:51 +02:00
outputs[| 0] = nodeValue("Gradient", self, JUNCTION_CONNECT.output, VALUE_TYPE.gradient, new gradientObject(c_white) )
2023-03-02 07:59:14 +01:00
_pal = -1;
2023-12-10 02:48:10 +01:00
static step = function() { #region
2024-03-31 05:36:11 +02:00
var usePos = array_safe_get_fast(current_data, 1);
2023-03-02 07:59:14 +01:00
inputs[| 2].setVisible(usePos, usePos);
2023-12-10 02:48:10 +01:00
} #endregion
2023-03-02 07:59:14 +01:00
2023-12-10 02:48:10 +01:00
static processData = function(_outSurf, _data, _output_index, _array_index) { #region
2023-03-02 07:59:14 +01:00
var pal = _data[0];
var pos_use = _data[1];
var _pos = _data[2];
var type = _data[3];
var grad = new gradientObject();
2023-07-28 19:41:57 +02:00
var len = min(128, array_length(pal));
grad.keys = array_create(len);
2023-03-02 07:59:14 +01:00
2023-07-28 19:41:57 +02:00
for( var i = 0; i < len; i++ ) {
2023-03-02 07:59:14 +01:00
var clr = pal[i];
2024-03-31 05:36:11 +02:00
var pos = pos_use? array_safe_get_fast(_pos, i, 0) : i / (len - 1);
2023-03-02 07:59:14 +01:00
grad.keys[i] = new gradientKey(pos, clr);
}
2023-07-28 19:41:57 +02:00
2023-03-02 07:59:14 +01:00
switch(type) {
2024-02-10 07:03:50 +01:00
case 0 : grad.type = GRADIENT_INTER.none; break;
case 1 : grad.type = GRADIENT_INTER.smooth; break;
case 2 : grad.type = GRADIENT_INTER.hue; break;
case 3 : grad.type = GRADIENT_INTER.oklab; break;
2024-02-12 10:25:23 +01:00
case 4 : grad.type = GRADIENT_INTER.srgb; break;
2023-03-02 07:59:14 +01:00
}
return grad;
2023-12-10 02:48:10 +01:00
} #endregion
2023-03-02 07:59:14 +01:00
2023-12-10 02:48:10 +01:00
static onDrawNode = function(xx, yy, _mx, _my, _s, _hover, _focus) { #region
2023-03-02 07:59:14 +01:00
var bbox = drawGetBbox(xx, yy, _s);
if(bbox.h < 1) return;
var grad = outputs[| 0].getValue();
2023-12-10 02:48:10 +01:00
if(!is_array(grad)) grad = [ grad ];
var _h = array_length(grad) * 32;
var _y = bbox.y0;
var gh = bbox.h / array_length(grad);
for( var i = 0, n = array_length(grad); i < n; i++ ) {
grad[i].draw(bbox.x0, _y, bbox.w, gh);
_y += gh;
2023-03-02 07:59:14 +01:00
}
2023-12-10 02:48:10 +01:00
if(_h != min_h) will_setHeight = true;
min_h = _h;
} #endregion
2023-03-02 07:59:14 +01:00
}