Pixel-Composer/scripts/__raymarching/__raymarching.gml
2024-06-15 13:02:10 +07:00

245 lines
No EOL
6 KiB
Text

function RM_Object() constructor {
id = UUID_generate();
shapeAmount = 0;
shape = [];
size = [];
radius = [];
thickness = [];
crop = [];
angle = [];
height = [];
radRange = [];
sizeUni = [];
elongate = [];
rounded = [];
corner = [];
size2D = [];
sides = [];
waveAmp = [];
waveInt = [];
waveShift = [];
twistAxis = [];
twistAmount = [];
position = [];
rotation = [];
objectScale = [];
tileSize = [];
tileAmount = [];
diffuseColor = [];
reflective = [];
volumetric = [];
volumeDensity = [];
texture = [];
useTexture = [];
textureScale = [];
triplanar = [];
opmap = -1;
oparg = -1;
uniformKeys = [ "shape", "size", "radius", "thickness", "crop", "angle", "height", "radRange", "sizeUni", "elongate", "rounded", "corner", "size2D", "sides",
"waveAmp", "waveInt", "waveShift",
"twistAxis", "twistAmount",
"position", "rotation", "objectScale",
"tileSize", "tileAmount",
"diffuseColor", "reflective",
"volumetric", "volumeDensity",
"texture", "useTexture", "textureScale", "triplanar"
];
textureAtl = noone;
static setTexture = function(textureAtlas) {
var tx = 1024;
surface_set_shader(textureAtlas);
for (var i = 0; i < shapeAmount; i++)
draw_surface_stretched_safe(texture[i], tx * (i % 8), tx * floor(i / 8), tx, tx);
surface_reset_shader();
textureAtl = textureAtlas;
}
static apply = function() {
// print(self);
shader_set_i("shapeAmount", shapeAmount);
if(shapeAmount <= 0) return;
shader_set_i("operations", opmap);
shader_set_f("opArgument", oparg);
shader_set_i("opLength", array_safe_length(opmap));
shader_set_i("shape", shape);
shader_set_f("size", size);
shader_set_f("radius", radius);
shader_set_f("thickness", thickness);
shader_set_f("crop", crop);
shader_set_f("angle", angle);
shader_set_f("height", height);
shader_set_f("radRange", radRange);
shader_set_f("sizeUni", sizeUni);
shader_set_f("elongate", elongate);
shader_set_f("rounded", rounded);
shader_set_f("corner", corner);
shader_set_f("size2D", size2D);
shader_set_i("sides", sides);
shader_set_f("waveAmp", waveAmp);
shader_set_f("waveInt", waveInt);
shader_set_f("waveShift", waveShift);
shader_set_i("twistAxis", twistAxis);
shader_set_f("twistAmount", twistAmount);
shader_set_f("position", position);
shader_set_f("rotation", rotation);
shader_set_f("objectScale", objectScale);
shader_set_f("tileSize", tileSize);
shader_set_f("tileAmount", tileAmount);
shader_set_f("diffuseColor", diffuseColor);
shader_set_f("reflective", reflective);
shader_set_i("volumetric", volumetric);
shader_set_f("volumeDensity", volumeDensity);
///////////////////////////////////////////////////////////////
shader_set_surface("texture1", textureAtl);
shader_set_i("useTexture", useTexture);
shader_set_f("textureScale", textureScale);
shader_set_f("triplanar", triplanar);
}
static serialize = function() { return ""};
static deserialize = function() { };
}
function RM_Operation(type, left, right) : RM_Object() constructor {
self.type = type;
self.left = left;
self.right = right;
merge = 0;
static reset = function() {
for (var i = 0, n = array_length(uniformKeys); i < n; i++)
self[$ uniformKeys[i]] = [];
}
static add = function(rmObject) {
for (var i = 0, n = array_length(uniformKeys); i < n; i++)
array_append(self[$ uniformKeys[i]], rmObject[$ uniformKeys[i]]);
}
static __flatten = function(node) {
if(is_instanceof(node, RM_Shape))
return node;
var _op = node.type;
var _l = node.left;
var _r = node.right;
var _arr = [ ];
array_append(_arr, __flatten(_l));
array_append(_arr, __flatten(_r));
array_push(_arr, _op);
return _arr;
}
static flatten = function() {
var _arr = __flatten(self);
var _nodes = [];
for (var i = 0, n = array_length(_arr); i < n; i++) {
var _a = _arr[i];
if(!is_struct(_a)) continue;
if(array_exists(_nodes, _a)) continue;
_a.flatten_index = array_length(_nodes);
array_push(_nodes, _a);
}
opmap = [];
oparg = [];
for (var i = 0, n = array_length(_arr); i < n; i++) {
var _a = _arr[i];
if(is_string(_a)) {
switch(_a) {
case "combine" : array_push(opmap, 100); break;
case "union" : array_push(opmap, 101); break;
case "subtract" : array_push(opmap, 102); break;
case "intersect" : array_push(opmap, 103); break;
}
array_push(oparg, merge);
} else if(is_struct(_a)) {
array_push(opmap, _a.flatten_index);
array_push(oparg, 0);
}
}
shapeAmount = array_length(_nodes);
reset();
for (var i = 0, n = array_length(_nodes); i < n; i++)
add(_nodes[i]);
}
}
function RM_Shape() : RM_Object() constructor {
}
function RM_Environment() constructor {
surface = noone;
bgEnv = noone;
projection = 0;
fov = 0;
orthoScale = 1;
viewRange = [ 0, 1 ];
depthInt = 0;
bgColor = c_black;
bgDraw = false;
ambInten = 0;
light = [ 1, 0.5, 0 ];
static apply = function() {
shader_set_surface($"texture0", surface);
shader_set_i("ortho", projection);
shader_set_f("fov", fov);
shader_set_f("orthoScale", orthoScale);
shader_set_f("viewRange", viewRange);
shader_set_f("depthInt", depthInt);
shader_set_i("drawBg", bgColor);
shader_set_color("background", bgDraw);
shader_set_f("ambientIntns", ambInten);
shader_set_f("lightPosition", light);
shader_set_i("useEnv", is_surface(bgEnv));
}
}