3D shadow mapping fix and several other things.

This commit is contained in:
Tanasart 2023-11-21 17:54:45 +07:00
parent 67834398b4
commit bb2bbd2fb4
20 changed files with 199 additions and 110 deletions

View file

@ -296,8 +296,21 @@ event_inherited();
} }
BLEND_NORMAL BLEND_NORMAL
var cc = COLORS._main_text_inner;
switch(name) {
case "All" :
case "New" :
case "Favourites" :
case "Action" :
case "Custom" :
case "Extra" :
cc = COLORS._main_text_sub;
break;
}
if(i == ADD_NODE_PAGE) draw_set_text(f_p0b, fa_left, fa_center, COLORS._main_text_accent); if(i == ADD_NODE_PAGE) draw_set_text(f_p0b, fa_left, fa_center, COLORS._main_text_accent);
else draw_set_text(f_p0, fa_left, fa_center, COLORS._main_text_inner); else draw_set_text(f_p0, fa_left, fa_center, cc);
var _is_extra = name == "Extra"; var _is_extra = name == "Extra";
name = __txt(name); name = __txt(name);
@ -314,7 +327,7 @@ event_inherited();
draw_sprite_ext(s_patreon_supporter, 0, _cx, _cy, 1, 1, 0, _hov? COLORS._main_icon_dark : COLORS.panel_bg_clear, 1); draw_sprite_ext(s_patreon_supporter, 0, _cx, _cy, 1, 1, 0, _hov? COLORS._main_icon_dark : COLORS.panel_bg_clear, 1);
gpu_set_colorwriteenable(1, 1, 1, 1); gpu_set_colorwriteenable(1, 1, 1, 1);
draw_sprite_ext(s_patreon_supporter, 1, _cx, _cy, 1, 1, 0, i == ADD_NODE_PAGE? COLORS._main_text_accent : COLORS._main_text_inner, 1); draw_sprite_ext(s_patreon_supporter, 1, _cx, _cy, 1, 1, 0, i == ADD_NODE_PAGE? COLORS._main_text_accent : cc, 1);
} }
hh += hg; hh += hg;

View file

@ -22,8 +22,9 @@ if(!MOUSE_WRAPPING) {
var _ady = slide_dy - mouse_my; var _ady = slide_dy - mouse_my;
var _s = tb.slide_speed; var _s = tb.slide_speed;
if(key_mod_press(CTRL)) _s *= 10; var sc = 10;
if(key_mod_press(ALT)) _s /= 10; if(key_mod_press(CTRL)) _s *= sc;
if(key_mod_press(ALT)) _s /= sc;
var spd = (slide_da? _ady : _adx) * _s; var spd = (slide_da? _ady : _adx) * _s;
var _val = value_snap(tb.slide_sv + spd, _s); var _val = value_snap(tb.slide_sv + spd, _s);

View file

@ -46,6 +46,8 @@
METADATA = __getdefaultMetaData(); METADATA = __getdefaultMetaData();
APP_LOCATION = program_directory; APP_LOCATION = program_directory;
if(string_pos("GameMakerStudio2\\Cache\\runtimes", APP_LOCATION))
APP_LOCATION = working_directory;
//print($"===================== WORKING DIRECTORIES =====================\n\t{working_directory}\n\t{DIRECTORY}"); //print($"===================== WORKING DIRECTORIES =====================\n\t{working_directory}\n\t{DIRECTORY}");
#endregion #endregion

View file

@ -246,8 +246,7 @@ function BBMOD_Quaternion(_x=0.0, _y=0.0, _z=0.0, _w=1.0) constructor
_forward = new BBMOD_Vec3(_forward); _forward = new BBMOD_Vec3(_forward);
_up = new BBMOD_Vec3(_up); _up = new BBMOD_Vec3(_up);
if (!_forward.Orthonormalize(_up)) if (!_forward.Orthonormalize(_up)) {
{
X = 0.0; X = 0.0;
Y = 0.0; Y = 0.0;
Z = 0.0; Z = 0.0;
@ -257,8 +256,8 @@ function BBMOD_Quaternion(_x=0.0, _y=0.0, _z=0.0, _w=1.0) constructor
var _right = _up.Cross(_forward); var _right = _up.Cross(_forward);
var _w = sqrt(abs(1.0 + _right.X + _up.Y + _forward.Z)) * 0.5; var _w = sqrt(abs(1.0 + _right.X + _up.Y + _forward.Z)) * 0.5;
var _w4Recip = 1.0 / (4.0 * _w); var _w4Recip = _w == 0? 0 : 1.0 / (4.0 * _w);
X = (_up.Z - _forward.Y) * _w4Recip; X = (_up.Z - _forward.Y) * _w4Recip;
Y = (_forward.X - _right.Z) * _w4Recip; Y = (_forward.X - _right.Z) * _w4Recip;
Z = (_right.Y - _up.X) * _w4Recip; Z = (_right.Y - _up.X) * _w4Recip;
@ -309,7 +308,7 @@ function BBMOD_Quaternion(_x=0.0, _y=0.0, _z=0.0, _w=1.0) constructor
/// @return {Struct.BBMOD_Quaternion} The created quaternion. /// @return {Struct.BBMOD_Quaternion} The created quaternion.
static Inverse = function () { static Inverse = function () {
INLINE INLINE
return Conjugate().Scale(1.0 / Length()); return Length() == 0? new BBMOD_Quaternion() : Conjugate().Scale(1.0 / Length());
}; };
/// @func Length() /// @func Length()
@ -412,6 +411,7 @@ function BBMOD_Quaternion(_x=0.0, _y=0.0, _z=0.0, _w=1.0) constructor
static Normalize = function () { static Normalize = function () {
INLINE INLINE
var _lengthSqr = LengthSqr(); var _lengthSqr = LengthSqr();
if(_lengthSqr == 0) if(_lengthSqr == 0)
return new BBMOD_Quaternion(); return new BBMOD_Quaternion();
@ -628,6 +628,8 @@ function BBMOD_Quaternion(_x=0.0, _y=0.0, _z=0.0, _w=1.0) constructor
_dest ??= matrix_build_identity(); _dest ??= matrix_build_identity();
if(is_nan(X)) return _dest;
var _norm = Normalize(); var _norm = Normalize();
var _temp0, _temp1, _temp2; var _temp0, _temp1, _temp2;

View file

@ -1,26 +1,29 @@
function colorFromRGBArray(arr) { function colorFromRGBArray(arr) { #region
var r = round(real(arr[0]) * 255); var r = round(real(arr[0]) * 255);
var g = round(real(arr[1]) * 255); var g = round(real(arr[1]) * 255);
var b = round(real(arr[2]) * 255); var b = round(real(arr[2]) * 255);
return make_color_rgb(r, g, b); return make_color_rgb(r, g, b);
} } #endregion
function color_get_alpha(color) { function color_get_alpha(color) { #region
INLINE
return (color & (0xFF << 24)) >> 24; return (color & (0xFF << 24)) >> 24;
} } #endregion
function colorArrayFromReal(clr) { function colorArrayFromReal(clr) { #region
INLINE
return [color_get_red(clr) / 255, color_get_green(clr) / 255, color_get_blue(clr) / 255 ]; return [color_get_red(clr) / 255, color_get_green(clr) / 255, color_get_blue(clr) / 255 ];
} } #endregion
function colorBrightness(clr, normalize = true) { function colorBrightness(clr, normalize = true) { #region
INLINE
var r2 = color_get_red(clr) / (normalize? 255 : 1); var r2 = color_get_red(clr) / (normalize? 255 : 1);
var g2 = color_get_green(clr) / (normalize? 255 : 1); var g2 = color_get_green(clr) / (normalize? 255 : 1);
var b2 = color_get_blue(clr) / (normalize? 255 : 1); var b2 = color_get_blue(clr) / (normalize? 255 : 1);
return 0.299 * r2 + 0.587 * g2 + 0.224 * b2; return 0.299 * r2 + 0.587 * g2 + 0.224 * b2;
} } #endregion
function colorMultiply(c1, c2) { function colorMultiply(c1, c2) { #region
if(c1 * c2 == 0) return 0; if(c1 * c2 == 0) return 0;
if(c1 == c_white) return c2; if(c1 == c_white) return c2;
if(c2 == c_white) return c1; if(c2 == c_white) return c1;
@ -34,9 +37,9 @@ function colorMultiply(c1, c2) {
var b2 = color_get_blue(c2); var b2 = color_get_blue(c2);
return make_color_rgb((r1 * r2) / 255, (g1 * g2) / 255, (b1 * b2) / 255); return make_color_rgb((r1 * r2) / 255, (g1 * g2) / 255, (b1 * b2) / 255);
} } #endregion
function colorAdd(c1, c2) { function colorAdd(c1, c2) { #region
if(c1 == 0) return c2; if(c1 == 0) return c2;
if(c2 == 0) return c1; if(c2 == 0) return c1;
@ -49,9 +52,9 @@ function colorAdd(c1, c2) {
var b2 = color_get_blue(c2); var b2 = color_get_blue(c2);
return make_color_rgb(min(r1 + r2, 255), min(g1 + g2, 255), min(b1 + b2, 255)); return make_color_rgb(min(r1 + r2, 255), min(g1 + g2, 255), min(b1 + b2, 255));
} } #endregion
function color_diff(c1, c2, fast = false, alpha = false) { function color_diff(c1, c2, fast = false, alpha = false) { #region
var _c1_r = color_get_red(c1); var _c1_r = color_get_red(c1);
var _c1_g = color_get_green(c1); var _c1_g = color_get_green(c1);
var _c1_b = color_get_blue(c1); var _c1_b = color_get_blue(c1);
@ -74,13 +77,17 @@ function color_diff(c1, c2, fast = false, alpha = false) {
if(fast) return abs(_c1_r - _c2_r) + abs(_c1_g - _c2_g) + abs(_c1_b - _c2_b) + abs(_c1_a - _c2_a); if(fast) return abs(_c1_r - _c2_r) + abs(_c1_g - _c2_g) + abs(_c1_b - _c2_b) + abs(_c1_a - _c2_a);
return sqrt(sqr(_c1_r - _c2_r) + sqr(_c1_g - _c2_g) + sqr(_c1_b - _c2_b) + sqr(_c1_a - _c2_a)); return sqrt(sqr(_c1_r - _c2_r) + sqr(_c1_g - _c2_g) + sqr(_c1_b - _c2_b) + sqr(_c1_a - _c2_a));
} } #endregion
function color_get_brightness(col) { function color_get_brightness(col) { #region
INLINE INLINE
return (0.299 * color_get_red(col) + 0.587 * color_get_green(col) + 0.114 * color_get_blue(col)) / 255; return (0.299 * color_get_red(col) + 0.587 * color_get_green(col) + 0.114 * color_get_blue(col)) / 255;
} } #endregion
function color_rgb(col) { #region
INLINE
return [ color_get_red(col) / 255, color_get_green(col) / 255, color_get_blue(col) / 255 ];
} #endregion
#region sorting functions #region sorting functions
function __valHSV(c, h, s, v) { return color_get_hue(c) * h + color_get_saturation(c) * s + color_get_value(c) * v; } function __valHSV(c, h, s, v) { return color_get_hue(c) * h + color_get_saturation(c) * s + color_get_value(c) * v; }

View file

@ -45,7 +45,9 @@ function __3dCamera_object() : __3dObject() constructor {
function d3d_PolarToCart(camFx, camFy, camFz, camAx, camAy, camDist) { function d3d_PolarToCart(camFx, camFy, camFz, camAx, camAy, camDist) {
var pos = new __vec3(); var pos = new __vec3();
if(camAy % 90 == 0) camAy += 0.01; if(camAy % 90 == 0) camAy += 0.1;
if(camAx % 90 == 0) camAx += 0.1;
var radAx = degtorad(camAx); var radAx = degtorad(camAx);
var radAy = degtorad(camAy); var radAy = degtorad(camAy);

View file

@ -216,8 +216,10 @@ function __3dScene(camera, name = "New scene") constructor {
shader_set_f("light_dir_color", lightDir_color); shader_set_f("light_dir_color", lightDir_color);
shader_set_f("light_dir_intensity", lightDir_intensity); shader_set_f("light_dir_intensity", lightDir_intensity);
shader_set_i("light_dir_shadow_active", lightDir_shadow); shader_set_i("light_dir_shadow_active", lightDir_shadow);
for( var i = 0, n = array_length(lightDir_shadowMap); i < n; i++ ) for( var i = 0, n = array_length(lightDir_shadowMap); i < n; i++ ) {
shader_set_surface($"light_dir_shadowmap_{i}", lightDir_shadowMap[i], true); var _sid = shader_set_surface($"light_dir_shadowmap_{i}", lightDir_shadowMap[i], true);
gpu_set_tex_repeat_ext(_sid, false);
}
shader_set_f("light_dir_view", lightDir_viewMat); shader_set_f("light_dir_view", lightDir_viewMat);
shader_set_f("light_dir_proj", lightDir_projMat); shader_set_f("light_dir_proj", lightDir_projMat);
shader_set_f("light_dir_shadow_bias", lightDir_shadowBias); shader_set_f("light_dir_shadow_bias", lightDir_shadowBias);
@ -230,8 +232,10 @@ function __3dScene(camera, name = "New scene") constructor {
shader_set_f("light_pnt_intensity", lightPnt_intensity); shader_set_f("light_pnt_intensity", lightPnt_intensity);
shader_set_f("light_pnt_radius", lightPnt_radius); shader_set_f("light_pnt_radius", lightPnt_radius);
shader_set_i("light_pnt_shadow_active", lightPnt_shadow); shader_set_i("light_pnt_shadow_active", lightPnt_shadow);
for( var i = 0, n = array_length(lightPnt_shadowMap); i < n; i++ ) for( var i = 0, n = array_length(lightPnt_shadowMap); i < n; i++ ) {
shader_set_surface($"light_pnt_shadowmap_{i}", lightPnt_shadowMap[i], true, true); var _sid = shader_set_surface($"light_pnt_shadowmap_{i}", lightPnt_shadowMap[i], true, true);
gpu_set_tex_repeat_ext(_sid, false);
}
shader_set_f("light_pnt_view", lightPnt_viewMat); shader_set_f("light_pnt_view", lightPnt_viewMat);
shader_set_f("light_pnt_proj", lightPnt_projMat); shader_set_f("light_pnt_proj", lightPnt_projMat);
shader_set_f("light_pnt_shadow_bias", lightPnt_shadowBias); shader_set_f("light_pnt_shadow_bias", lightPnt_shadowBias);

View file

@ -261,8 +261,7 @@ function Node_3D_Camera(_x, _y, _group = noone) : Node_3D_Object(_x, _y, _group)
camera.up = camera.getUp()._multiply(-1); camera.up = camera.getUp()._multiply(-1);
var _for = camera.focus.subtract(camera.position); var _for = camera.focus.subtract(camera.position);
if(!_for.isZero()) if(!_for.isZero()) camera.rotation = new BBMOD_Quaternion().FromLookRotation(_for, camera.up.multiply(-1)).Mul(_qi1).Mul(_qi3);
camera.rotation = new BBMOD_Quaternion().FromLookRotation(_for, camera.up.multiply(-1)).Mul(_qi1).Mul(_qi3);
lookat.transform.position.set(_look); lookat.transform.position.set(_look);
lookLine = new __3dGizmoLineDashed(camera.position, camera.focus, 0.25, c_gray, 1); lookLine = new __3dGizmoLineDashed(camera.position, camera.focus, 0.25, c_gray, 1);

View file

@ -21,7 +21,30 @@ function Node_3D_Light_Directional(_x, _y, _group = noone) : Node_3D_Light(_x, _
tool_settings = []; tool_settings = [];
tool_attribute.context = 1; tool_attribute.context = 1;
static processData = function(_output, _data, _output_index, _array_index = 0) { //static drawOverlay3D = function(active, params, _mx, _my, _snx, _sny, _panel) { #region
// var object = getObject(0);
// var _outSurf = object.shadow_map;
// if(!is_surface(_outSurf)) return;
// var _w = _panel.w;
// var _h = _panel.h - _panel.toolbar_height;
// var _pw = surface_get_width_safe(_outSurf);
// var _ph = surface_get_height_safe(_outSurf);
// var _ps = min(128 / _ph, 160 / _pw);
// var _pws = _pw * _ps;
// var _phs = _ph * _ps;
// var _px = _w - 16 - _pws;
// var _py = _h - 16 - _phs;
// draw_surface_ext_safe(_outSurf, _px, _py, _ps, _ps);
// draw_set_color(COLORS._main_icon);
// draw_rectangle(_px, _py, _px + _pws, _py + _phs, true);
//} #endregion
static processData = function(_output, _data, _output_index, _array_index = 0) { #region
var _active = _data[in_d3d + 0]; var _active = _data[in_d3d + 0];
if(!_active) return noone; if(!_active) return noone;
@ -41,5 +64,5 @@ function Node_3D_Light_Directional(_x, _y, _group = noone) : Node_3D_Light(_x, _
object.transform.rotation.FromEuler(_rot.x, _rot.y, _rot.z); object.transform.rotation.FromEuler(_rot.x, _rot.y, _rot.z);
return object; return object;
} } #endregion
} }

View file

@ -21,7 +21,7 @@ function Node_3D_Light_Point(_x, _y, _group = noone) : Node_3D_Light(_x, _y, _gr
tool_settings = []; tool_settings = [];
tool_attribute.context = 1; tool_attribute.context = 1;
static processData = function(_output, _data, _output_index, _array_index = 0) { static processData = function(_output, _data, _output_index, _array_index = 0) { #region
var _active = _data[in_d3d + 0]; var _active = _data[in_d3d + 0];
if(!_active) return noone; if(!_active) return noone;
@ -39,10 +39,5 @@ function Node_3D_Light_Point(_x, _y, _group = noone) : Node_3D_Light(_x, _y, _gr
object.shadow_bias = _shadow_bias; object.shadow_bias = _shadow_bias;
return object; return object;
} } #endregion
//static onDrawNode = function(xx, yy, _mx, _my, _s, _hover, _focus) {
// var object = getObject(0);
// draw_surface_stretched_safe(object.shadow_map, xx, yy, 96, 96);
//}
} }

View file

@ -244,4 +244,6 @@ function __Node_Cache(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
draw_set_alpha(1); draw_set_alpha(1);
} #endregion } #endregion
static onDestroy = function() { enableNodeGroup(); }
} }

View file

@ -38,7 +38,7 @@ function Node_Camera(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) co
temp_surface = [ noone, noone ]; temp_surface = [ noone, noone ];
static createNewInput = function() { static createNewInput = function() { #region
var index = ds_list_size(inputs); var index = ds_list_size(inputs);
var _s = floor((index - input_fix_len) / data_length); var _s = floor((index - input_fix_len) / data_length);
@ -52,10 +52,9 @@ function Node_Camera(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) co
.setDisplay(VALUE_DISPLAY.enum_scroll, [ "Empty", "Repeat", "Repeat X", "Repeat Y" ]); .setDisplay(VALUE_DISPLAY.enum_scroll, [ "Empty", "Repeat", "Repeat X", "Repeat Y" ]);
array_append(input_display_list, [ index + 0, index + 1, index + 2 ]); array_append(input_display_list, [ index + 0, index + 1, index + 2 ]);
} } if(!LOADING && !APPENDING) createNewInput(); #endregion
if(!LOADING && !APPENDING) createNewInput();
static refreshDynamicInput = function() { static refreshDynamicInput = function() { #region
var _in = ds_list_create(); var _in = ds_list_create();
for( var i = 0; i < input_fix_len; i++ ) for( var i = 0; i < input_fix_len; i++ )
@ -86,18 +85,18 @@ function Node_Camera(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) co
inputs = _in; inputs = _in;
createNewInput(); createNewInput();
} } #endregion
static onValueFromUpdate = function(index) { static onValueFromUpdate = function(index) { #region
if(index < input_fix_len) return; if(index < input_fix_len) return;
if(LOADING || APPENDING) return; if(LOADING || APPENDING) return;
refreshDynamicInput(); refreshDynamicInput();
} } #endregion
static getPreviewValues = function() { return getInputData(0); } static getPreviewValues = function() { return getInputData(0); }
static drawOverlay = function(active, _x, _y, _s, _mx, _my, _snx, _sny) { static drawOverlay = function(active, _x, _y, _s, _mx, _my, _snx, _sny) { #region
if(array_length(current_data) == 0) return; if(array_length(current_data) == 0) return;
var _out = outputs[| 0].getValue(); var _out = outputs[| 0].getValue();
@ -117,9 +116,9 @@ function Node_Camera(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) co
var y1 = y0 + _area[3] * 2 * _zoom * _s; var y1 = y0 + _area[3] * 2 * _zoom * _s;
draw_rectangle_dashed(x0, y0, x1, y1); draw_rectangle_dashed(x0, y0, x1, y1);
} } #endregion
static processData = function(_outSurf, _data, _output_index, _array_index) { static processData = function(_outSurf, _data, _output_index, _array_index) { #region
if(!is_surface(_data[0])) return; if(!is_surface(_data[0])) return;
var _area = _data[1]; var _area = _data[1];
var _zoom = _data[2]; var _zoom = _data[2];
@ -223,5 +222,5 @@ function Node_Camera(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) co
surface_reset_target(); surface_reset_target();
return _outSurf; return _outSurf;
} } #endregion
} }

View file

@ -595,19 +595,28 @@ function Node(_x, _y, _group = PANEL_GRAPH.getCurrentContext()) : __Node_Base(_x
LOG_BLOCK_END(); LOG_BLOCK_END();
} #endregion } #endregion
static cacheCheck = function() { #region
INLINE
if(cache_group) cache_group.enableNodeGroup();
if(group != noone) group.cacheCheck();
} #endregion
static valueUpdate = function(index) { #region static valueUpdate = function(index) { #region
if(error_update_enabled && error_noti_update == noone) if(error_update_enabled && error_noti_update == noone)
error_noti_update = noti_error(getFullName() + " node require manual execution.",, self); error_noti_update = noti_error(getFullName() + " node require manual execution.",, self);
onValueUpdate(index); onValueUpdate(index);
if(cache_group) cache_group.enableNodeGroup();
if(is_dynamic_input) will_setHeight = true; if(is_dynamic_input) will_setHeight = true;
cacheCheck();
} #endregion } #endregion
static valueFromUpdate = function(index) { #region static valueFromUpdate = function(index) { #region
onValueFromUpdate(index); onValueFromUpdate(index);
if(cache_group) cache_group.enableNodeGroup();
if(is_dynamic_input) will_setHeight = true; if(is_dynamic_input) will_setHeight = true;
cacheCheck();
} #endregion } #endregion
static onValueUpdate = function(index = 0) {} static onValueUpdate = function(index = 0) {}

View file

@ -741,6 +741,7 @@ function Node_Export(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
if(render_process_id != 0) { if(render_process_id != 0) {
var res = ProcIdExists(render_process_id); var res = ProcIdExists(render_process_id);
if(res == 0) { if(res == 0) {
var noti = log_message("EXPORT", $"Export {render_type} as {render_target}", THEME.noti_icon_tick, COLORS._main_value_positive, false); var noti = log_message("EXPORT", $"Export {render_type} as {render_target}", THEME.noti_icon_tick, COLORS._main_value_positive, false);
noti.path = filename_dir(render_target); noti.path = filename_dir(render_target);
@ -749,6 +750,9 @@ function Node_Export(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
render_process_id = 0; render_process_id = 0;
array_remove(RENDERING, node_id); array_remove(RENDERING, node_id);
} else {
//var stdOut = ExecutedProcessReadFromStandardOutput(render_process_id);
//print(stdOut);
} }
} }
} #endregion } #endregion

View file

@ -14,6 +14,10 @@ function Node_Palette_Extract(_x, _y, _group = noone) : Node(_x, _y, _group) con
.setDisplay(VALUE_DISPLAY.enum_scroll, { data: [ "K-mean", "Frequency", "All colors" ], update_hover: false }) .setDisplay(VALUE_DISPLAY.enum_scroll, { data: [ "K-mean", "Frequency", "All colors" ], update_hover: false })
.rejectArray(); .rejectArray();
inputs[| 4] = nodeValue("Color Space", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 1)
.setDisplay(VALUE_DISPLAY.enum_scroll, { data: [ "RGB", "HSV" ], update_hover: false })
.rejectArray();
outputs[| 0] = nodeValue("Palette", self, JUNCTION_CONNECT.output, VALUE_TYPE.color, [ ]) outputs[| 0] = nodeValue("Palette", self, JUNCTION_CONNECT.output, VALUE_TYPE.color, [ ])
.setDisplay(VALUE_DISPLAY.palette); .setDisplay(VALUE_DISPLAY.palette);
@ -21,7 +25,7 @@ function Node_Palette_Extract(_x, _y, _group = noone) : Node(_x, _y, _group) con
input_display_list = [ input_display_list = [
["Surfaces", true], 0, ["Surfaces", true], 0,
["Palette", false], 3, 1, 2, ["Palette", false], 3, 4, 1, 2,
] ]
current_palette = []; current_palette = [];
@ -29,7 +33,7 @@ function Node_Palette_Extract(_x, _y, _group = noone) : Node(_x, _y, _group) con
attribute_surface_depth(); attribute_surface_depth();
function sortPalette(pal) { function sortPalette(pal) { #region
array_sort(pal, function(c0, c1) { array_sort(pal, function(c0, c1) {
var r0 = color_get_red(c0) / 255; var r0 = color_get_red(c0) / 255;
var r1 = color_get_red(c1) / 255; var r1 = color_get_red(c1) / 255;
@ -56,23 +60,19 @@ function Node_Palette_Extract(_x, _y, _group = noone) : Node(_x, _y, _group) con
return s0 * v0 > s1 * v1; return s0 * v0 > s1 * v1;
}) })
} } #endregion
function extractKmean(_surfFull, _size, _seed) { function extractKmean(_surfFull, _size, _seed) { #region
var _surf = surface_create_valid(min(32, surface_get_width_safe(_surfFull)), min(32, surface_get_height_safe(_surfFull)), attrDepth()); var _space = getInputData(4);
var _surf = surface_create_valid(min(32, surface_get_width_safe(_surfFull)), min(32, surface_get_height_safe(_surfFull)), attrDepth());
_size = max(1, _size); _size = max(1, _size);
var ww = surface_get_width_safe(_surf); var ww = surface_get_width_safe(_surf);
var hh = surface_get_height_safe(_surf); var hh = surface_get_height_safe(_surf);
surface_set_target(_surf); surface_set_shader(_surf, noone);
DRAW_CLEAR draw_surface_stretched_safe(_surfFull, 0, 0, ww, hh);
BLEND_OVERRIDE; surface_reset_shader();
gpu_set_texfilter(true);
draw_surface_stretched_safe(_surfFull, 0, 0, ww, hh);
gpu_set_texfilter(false);
BLEND_NORMAL;
surface_reset_target();
var c_buffer = buffer_create(ww * hh * 4, buffer_fixed, 2); var c_buffer = buffer_create(ww * hh * 4, buffer_fixed, 2);
var colors = []; var colors = [];
@ -82,14 +82,20 @@ function Node_Palette_Extract(_x, _y, _group = noone) : Node(_x, _y, _group) con
var _min = [ 1, 1, 1 ]; var _min = [ 1, 1, 1 ];
var _max = [ 0, 0, 0 ]; var _max = [ 0, 0, 0 ];
var a, b, c, col;
for( var i = 0; i < ww * hh; i++ ) { for( var i = 0; i < ww * hh; i++ ) {
var b = buffer_read(c_buffer, buffer_u32); b = buffer_read(c_buffer, buffer_u32);
var c = b & ~(0b11111111 << 24); c = b & ~(0b11111111 << 24);
var a = b & (0b11111111 << 24); a = b & (0b11111111 << 24);
if(a == 0) continue; if(a == 0) continue;
var col = [ color_get_hue(c) / 255, color_get_saturation(c) / 255, color_get_value(c) / 255, 0 ]; switch(_space) {
case 0 : col = [ color_get_red(c) / 255, color_get_green(c) / 255, color_get_blue(c) / 255, 0 ]; break;
case 1 : col = [ color_get_hue(c) / 255, color_get_saturation(c) / 255, color_get_value(c) / 255, 0 ]; break;
case 2 : col = [ color_get_hue(c) / 255, color_get_saturation(c) / 255, color_get_value(c) / 255, 0 ]; break;
}
array_push(colors, col); array_push(colors, col);
for( var j = 0; j < 3; j++ ) { for( var j = 0; j < 3; j++ ) {
_min[j] = min(_min[j], col[j]); _min[j] = min(_min[j], col[j]);
@ -155,6 +161,7 @@ function Node_Palette_Extract(_x, _y, _group = noone) : Node(_x, _y, _group) con
} }
var palette = []; var palette = [];
var clr;
for( var i = 0; i < _size; i++ ) { for( var i = 0; i < _size; i++ ) {
var closet = 0; var closet = 0;
@ -171,18 +178,22 @@ function Node_Palette_Extract(_x, _y, _group = noone) : Node(_x, _y, _group) con
} }
} }
var clr = make_color_hsv(colors[closet][0] * 255, colors[closet][1] * 255, colors[closet][2] * 255); switch(_space) {
if(!array_exists(palette, clr)) case 0 : clr = make_color_rgb(colors[closet][0] * 255, colors[closet][1] * 255, colors[closet][2] * 255); break;
array_push(palette, clr); case 1 : clr = make_color_hsv(colors[closet][0] * 255, colors[closet][1] * 255, colors[closet][2] * 255); break;
case 2 : clr = make_color_hsv(colors[closet][0] * 255, colors[closet][1] * 255, colors[closet][2] * 255); break;
}
array_push_unique(palette, clr);
} }
surface_free(_surf); surface_free(_surf);
sortPalette(palette); sortPalette(palette);
return palette; return palette;
} } #endregion
function extractAll(_surfFull) { function extractAll(_surfFull) { #region
var ww = surface_get_width_safe(_surfFull); var ww = surface_get_width_safe(_surfFull);
var hh = surface_get_height_safe(_surfFull); var hh = surface_get_height_safe(_surfFull);
@ -205,9 +216,9 @@ function Node_Palette_Extract(_x, _y, _group = noone) : Node(_x, _y, _group) con
buffer_delete(c_buffer); buffer_delete(c_buffer);
return palette; return palette;
} } #endregion
function extractFrequence(_surfFull, _size) { function extractFrequence(_surfFull, _size) { #region
var msize = 128; var msize = 128;
var _surf = surface_create_valid(min(msize, surface_get_width_safe(_surfFull)), min(msize, surface_get_height_safe(_surfFull))); var _surf = surface_create_valid(min(msize, surface_get_width_safe(_surfFull)), min(msize, surface_get_height_safe(_surfFull)));
_size = max(1, _size); _size = max(1, _size);
@ -262,16 +273,17 @@ function Node_Palette_Extract(_x, _y, _group = noone) : Node(_x, _y, _group) con
ds_priority_destroy(pr); ds_priority_destroy(pr);
ds_map_destroy(clrs); ds_map_destroy(clrs);
return palette; return palette;
} } #endregion
static step = function() { static step = function() { #region
var _algo = getInputData(3); var _algo = getInputData(3);
inputs[| 1].setVisible(_algo != 2); inputs[| 1].setVisible(_algo != 2);
inputs[| 2].setVisible(_algo == 0); inputs[| 2].setVisible(_algo == 0);
} inputs[| 4].setVisible(_algo == 0);
} #endregion
static extractPalette = function(_surf, _algo, _size, _seed) { static extractPalette = function(_surf, _algo, _size, _seed) { #region
if(!is_surface(_surf)) return []; if(!is_surface(_surf)) return [];
switch(_algo) { switch(_algo) {
@ -281,9 +293,9 @@ function Node_Palette_Extract(_x, _y, _group = noone) : Node(_x, _y, _group) con
} }
return []; return [];
} } #endregion
static extractPalettes = function() { static extractPalettes = function() { #region
var _surf = getInputData(0); var _surf = getInputData(0);
var _size = getInputData(1); var _size = getInputData(1);
var _seed = getInputData(2); var _seed = getInputData(2);
@ -299,20 +311,18 @@ function Node_Palette_Extract(_x, _y, _group = noone) : Node(_x, _y, _group) con
} }
outputs[| 0].setValue(res); outputs[| 0].setValue(res);
} } #endregion
static onInspector1Update = function() { extractPalettes(); triggerRender(); } static onInspector1Update = function() { extractPalettes(); triggerRender(); }
static onValueUpdate = function() { extractPalettes(); } static onValueUpdate = function() { extractPalettes(); }
static onValueFromUpdate = function() { extractPalettes(); } static onValueFromUpdate = function() { extractPalettes(); }
static update = function() { static update = function() { extractPalettes(); }
extractPalettes();
}
static onDrawNode = function(xx, yy, _mx, _my, _s, _hover, _focus) { static onDrawNode = function(xx, yy, _mx, _my, _s, _hover, _focus) { #region
var bbox = drawGetBbox(xx, yy, _s); var bbox = drawGetBbox(xx, yy, _s);
if(bbox.h < 1) return; if(bbox.h < 1) return;
drawPalette(outputs[| 0].getValue(), bbox.x0, bbox.y0, bbox.w, bbox.h); drawPalette(outputs[| 0].getValue(), bbox.x0, bbox.y0, bbox.w, bbox.h);
} } #endregion
} }

View file

@ -92,6 +92,8 @@ function shader_set_surface(sampler, surface, linear = false, _repeat = false) {
texture_set_stage(t, surface_get_texture(surface)); texture_set_stage(t, surface_get_texture(surface));
gpu_set_tex_filter_ext(t, linear); gpu_set_tex_filter_ext(t, linear);
gpu_set_tex_repeat_ext(t, _repeat); gpu_set_tex_repeat_ext(t, _repeat);
return t;
} }
//function shader_set_surface_ext(sampler, surface, linear = false, _repeat = false) { //function shader_set_surface_ext(sampler, surface, linear = false, _repeat = false) {

View file

@ -1,4 +1,4 @@
function string_hexadecimal(str){ function string_hexadecimal(str) {
static HEX = "0123456789ABCDEF"; static HEX = "0123456789ABCDEF";
var i = string_length(str); var i = string_length(str);

View file

@ -307,8 +307,9 @@ function surface_size_lim(surface, width, height) {
} }
function surface_size_to(surface, width, height, format = noone, skipCheck = false) { function surface_size_to(surface, width, height, format = noone, skipCheck = false) {
if(!skipCheck && !is_surface(surface)) return surface; if(!skipCheck && !is_surface(surface)) return surface;
if(width < 1 && height < 1) return surface; if(!is_numeric(width) || !is_numeric(height)) return surface;
if(width < 1 && height < 1) return surface;
if(format != noone && format != surface_get_format(surface)) { if(format != noone && format != surface_get_format(surface)) {
surface_free(surface); surface_free(surface);

View file

@ -223,7 +223,16 @@ function textBox(_input, _onModify) : textInput(_input, _onModify) constructor {
if(keyboard_check_pressed(vk_left)) onKey(vk_left); if(keyboard_check_pressed(vk_left)) onKey(vk_left);
if(keyboard_check_pressed(vk_right)) onKey(vk_right); if(keyboard_check_pressed(vk_right)) onKey(vk_right);
if(input == TEXTBOX_INPUT.number) {
var _inc = 1;
if(key_mod_press(CTRL)) _inc *= 10;
if(key_mod_press(ALT)) _inc /= 10;
if(KEYBOARD_PRESSED == vk_up || keyboard_check_pressed(vk_up)) { _input_text = string(toNumber(_input_text) + _inc); apply(); }
if(KEYBOARD_PRESSED == vk_down || keyboard_check_pressed(vk_down)) { _input_text = string(toNumber(_input_text) - _inc); apply(); }
}
if(keyboard_check_pressed(vk_home)) { if(keyboard_check_pressed(vk_home)) {
if(key_mod_press(SHIFT)) { if(key_mod_press(SHIFT)) {
if(cursor_select == -1) if(cursor_select == -1)

View file

@ -220,15 +220,18 @@ void main() {
float v_lightDistance = screenSpace.z / screenSpace.w; float v_lightDistance = screenSpace.z / screenSpace.w;
vec2 lightMapPosition = (screenSpace.xy / screenSpace.w * 0.5) + 0.5; vec2 lightMapPosition = (screenSpace.xy / screenSpace.w * 0.5) + 0.5;
light_map_depth = sampleDirShadowMap(shadow_map_index, lightMapPosition);
shadow_map_index++;
lightDistance = v_lightDistance;
float shadowFactor = dot(normal, lightVector);
float bias = mix(light_dir_shadow_bias[i], 0., shadowFactor);
if(lightDistance > light_map_depth + bias) if(lightMapPosition.x >= 0. && lightMapPosition.x <= 1. && lightMapPosition.y >= 0. && lightMapPosition.y <= 1.) {
continue; light_map_depth = sampleDirShadowMap(shadow_map_index, lightMapPosition);
shadow_map_index++;
lightDistance = v_lightDistance;
float shadowFactor = dot(normal, lightVector);
float bias = mix(light_dir_shadow_bias[i], 0., shadowFactor);
if(lightDistance > light_map_depth + bias)
continue;
}
} }
vec3 light_phong = phongLight(normal, lightVector, viewDirection, light_dir_color[i].rgb); vec3 light_phong = phongLight(normal, lightVector, viewDirection, light_dir_color[i].rgb);
@ -264,14 +267,16 @@ void main() {
float v_lightDistance = screenSpace.z / screenSpace.w; float v_lightDistance = screenSpace.z / screenSpace.w;
vec2 lightMapPosition = (screenSpace.xy / screenSpace.w * 0.5) + 0.5; vec2 lightMapPosition = (screenSpace.xy / screenSpace.w * 0.5) + 0.5;
float shadowFactor = dot(normal, lightVector); if(lightMapPosition.x >= 0. && lightMapPosition.x <= 1. && lightMapPosition.y >= 0. && lightMapPosition.y <= 1.) {
float bias = mix(light_pnt_shadow_bias[i], 0., shadowFactor); float shadowFactor = dot(normal, lightVector);
float bias = mix(light_pnt_shadow_bias[i], 0., shadowFactor);
light_map_depth = samplePntShadowMap(shadow_map_index, lightMapPosition, side); light_map_depth = samplePntShadowMap(shadow_map_index, lightMapPosition, side);
shadow_map_index++; shadow_map_index++;
if(v_lightDistance > light_map_depth + bias) if(v_lightDistance > light_map_depth + bias)
continue; continue;
}
} }
light_attenuation = 1. - pow(light_distance / light_pnt_radius[i], 2.); light_attenuation = 1. - pow(light_distance / light_pnt_radius[i], 2.);