mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2025-01-11 23:06:51 +01:00
3D shadow mapping fix and several other things.
This commit is contained in:
parent
67834398b4
commit
bb2bbd2fb4
20 changed files with 199 additions and 110 deletions
|
@ -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;
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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; }
|
||||||
|
|
|
@ -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);
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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
|
||||||
}
|
}
|
|
@ -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);
|
|
||||||
//}
|
|
||||||
}
|
}
|
|
@ -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(); }
|
||||||
}
|
}
|
|
@ -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
|
||||||
}
|
}
|
|
@ -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) {}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
}
|
}
|
|
@ -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) {
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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.);
|
||||||
|
|
Loading…
Reference in a new issue