- [3D Object] Fix weird behaviour on other noeds when created.

This commit is contained in:
Tanasart 2024-07-02 14:15:42 +07:00
parent 1cabe20a00
commit 5e2eb0a352
5 changed files with 17 additions and 6 deletions

View file

@ -1,7 +1,6 @@
function Node_3D(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor { function Node_3D(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
name = "3D"; name = "3D";
is_3D = NODE_3D.polygon; is_3D = NODE_3D.polygon;
surface_depth_disable(false);
mesh_prev_surface = surface_create(64, 64); mesh_prev_surface = surface_create(64, 64);
@ -35,6 +34,7 @@ function Node_3D(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constr
static refreshPreview = function() { #region static refreshPreview = function() { #region
var _prev_obj = getPreviewObjects(); var _prev_obj = getPreviewObjects();
surface_depth_disable(false);
mesh_prev_surface = surface_verify(mesh_prev_surface, PREFERENCES.node_3d_preview_size, PREFERENCES.node_3d_preview_size); mesh_prev_surface = surface_verify(mesh_prev_surface, PREFERENCES.node_3d_preview_size, PREFERENCES.node_3d_preview_size);
surface_set_target(mesh_prev_surface); surface_set_target(mesh_prev_surface);
DRAW_CLEAR DRAW_CLEAR
@ -63,6 +63,7 @@ function Node_3D(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constr
D3D_GLOBAL_PREVIEW.submitUI(_prev); D3D_GLOBAL_PREVIEW.submitUI(_prev);
} }
surface_reset_target(); surface_reset_target();
surface_depth_disable(true);
D3D_GLOBAL_PREVIEW.camera.resetCamera(); D3D_GLOBAL_PREVIEW.camera.resetCamera();
} #endregion } #endregion

View file

@ -242,6 +242,8 @@ function Node_3D_Camera(_x, _y, _group = noone) : Node_3D_Object(_x, _y, _group)
var _qi3 = new BBMOD_Quaternion().FromAxisAngle(new BBMOD_Vec3(1, 0, 0), 90); var _qi3 = new BBMOD_Quaternion().FromAxisAngle(new BBMOD_Vec3(1, 0, 0), 90);
#endregion #endregion
surface_depth_disable(false);
switch(_posm) { #region ++++ camera positioning ++++ switch(_posm) { #region ++++ camera positioning ++++
case 0 : case 0 :
camera.useFocus = false; camera.useFocus = false;
@ -377,6 +379,8 @@ function Node_3D_Camera(_x, _y, _group = noone) : Node_3D_Object(_x, _y, _group)
surface_free(_render); surface_free(_render);
#endregion #endregion
surface_depth_disable(true);
return [ _finalRender, _normal, _depth ]; return [ _finalRender, _normal, _depth ];
} #endregion } #endregion

View file

@ -42,7 +42,7 @@ function Node_3D_Mesh_Cube(_x, _y, _group = noone) : Node_3D_Mesh(_x, _y, _group
inputs[| in_mesh + 6].setVisible(_mat_side, _mat_side); inputs[| in_mesh + 6].setVisible(_mat_side, _mat_side);
} #endregion } #endregion
static processData = function(_output, _data, _output_index, _array_index = 0) { #region static processData = function(_output, _data, _output_index, _array_index = 0) {
var _mat_side = _data[in_mesh + 0]; var _mat_side = _data[in_mesh + 0];
var _mat_1 = _data[in_mesh + 1]; var _mat_1 = _data[in_mesh + 1];
var _mat_2 = _data[in_mesh + 2]; var _mat_2 = _data[in_mesh + 2];
@ -63,7 +63,7 @@ function Node_3D_Mesh_Cube(_x, _y, _group = noone) : Node_3D_Mesh(_x, _y, _group
setTransform(object, _data); setTransform(object, _data);
return object; return object;
} #endregion }
static getPreviewValues = function() { return array_safe_get_fast(all_inputs, in_mesh + 1, noone); } static getPreviewValues = function() { return array_safe_get_fast(all_inputs, in_mesh + 1, noone); }
} }

View file

@ -118,11 +118,13 @@ function Node_Posterize(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
var _ssh = surface_get_height(_sMax); var _ssh = surface_get_height(_sMax);
var _max = [ 0, 0, 0 ]; var _max = [ 0, 0, 0 ];
var _min = [ 1, 1, 1 ]; var _min = [ 1, 1, 1 ];
var _bMax = buffer_from_surface(_sMax, false); var _bMax = buffer_from_surface(_sMax, false);
var _bMin = buffer_from_surface(_sMin, false); var _bMin = buffer_from_surface(_sMin, false);
buffer_seek(_bMax, buffer_seek_start, 0); buffer_to_start(_bMax);
buffer_seek(_bMin, buffer_seek_start, 0); buffer_to_start(_bMin);
repeat(_ssw * _ssh) { repeat(_ssw * _ssh) {
var _cc = buffer_read(_bMax, buffer_u32); var _cc = buffer_read(_bMax, buffer_u32);
_max[0] = max(_max[0], _color_get_red(_cc)); _max[0] = max(_max[0], _color_get_red(_cc));
@ -135,6 +137,7 @@ function Node_Posterize(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
_min[2] = min(_min[2], _color_get_blue(_cc)); _min[2] = min(_min[2], _color_get_blue(_cc));
} }
buffer_delete(_bMax); buffer_delete(_bMax);
buffer_delete(_bMin); buffer_delete(_bMin);
#endregion #endregion
@ -148,6 +151,10 @@ function Node_Posterize(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
draw_surface_safe(_surf); draw_surface_safe(_surf);
surface_reset_shader(); surface_reset_shader();
// surface_set_shader(_outSurf);
// draw_surface_safe(_sMax);
// surface_reset_shader();
} }
return _outSurf; return _outSurf;

View file

@ -1140,7 +1140,6 @@ function NodeValue(_name, _node, _connect, _type, _value, _tooltip = "") constru
if(connect_type == JUNCTION_CONNECT.output) if(connect_type == JUNCTION_CONNECT.output)
return val; return val;
if(type == VALUE_TYPE.integer || type == VALUE_TYPE.float) print($"{typ == VALUE_TYPE.surface}");
if(typ == VALUE_TYPE.surface && (type == VALUE_TYPE.integer || type == VALUE_TYPE.float)) { #region Dimension conversion if(typ == VALUE_TYPE.surface && (type == VALUE_TYPE.integer || type == VALUE_TYPE.float)) { #region Dimension conversion
if(is_array(val)) { if(is_array(val)) {
var eqSize = true; var eqSize = true;