Added undo redo support form mat maker gd's gradient editor. This also fixes seamless color editing with it.

This commit is contained in:
Relintai 2022-03-08 12:08:30 +01:00
parent 0ac7e7a2b6
commit b17b7bb583
3 changed files with 57 additions and 5 deletions

View File

@ -85,6 +85,8 @@ func add_slot_image_path_universal(property : MMNodeUniversalProperty, getter :
func add_slot_gradient() -> int: func add_slot_gradient() -> int:
var ge : Control = gradient_editor_scene.instance() var ge : Control = gradient_editor_scene.instance()
ge.graph_node = self
ge.set_undo_redo(_undo_redo)
var slot_idx : int = add_slot(MMNodeUniversalProperty.SlotTypes.SLOT_TYPE_NONE, MMNodeUniversalProperty.SlotTypes.SLOT_TYPE_NONE, "", "", ge) var slot_idx : int = add_slot(MMNodeUniversalProperty.SlotTypes.SLOT_TYPE_NONE, MMNodeUniversalProperty.SlotTypes.SLOT_TYPE_NONE, "", "", ge)

View File

@ -27,12 +27,17 @@ class GradientCursor:
if ev is InputEventMouseButton: if ev is InputEventMouseButton:
if ev.button_index == BUTTON_LEFT: if ev.button_index == BUTTON_LEFT:
if ev.doubleclick: if ev.doubleclick:
get_parent().save_color_state()
get_parent().select_color(self, ev.global_position) get_parent().select_color(self, ev.global_position)
elif ev.pressed: elif ev.pressed:
get_parent().save_color_state()
sliding = true sliding = true
label.visible = true label.visible = true
label.text = "%.03f" % get_cursor_position() label.text = "%.03f" % get_cursor_position()
else: else:
if sliding:
get_parent().undo_redo_save_color_state()
sliding = false sliding = false
label.visible = false label.visible = false
elif ev.button_index == BUTTON_RIGHT and get_parent().get_sorted_cursors().size() > 2: elif ev.button_index == BUTTON_RIGHT and get_parent().get_sorted_cursors().size() > 2:
@ -65,15 +70,50 @@ class GradientCursor:
func drop_data(_position, data) -> void: func drop_data(_position, data) -> void:
set_color(data) set_color(data)
var graph_node = null
var value = null setget set_value var value = null setget set_value
export var embedded : bool = true export var embedded : bool = true
var _undo_redo : UndoRedo = null
signal updated(value) signal updated(value)
var _saved_points : PoolRealArray = PoolRealArray()
func _init(): func _init():
connect("resized", self, "on_resized") connect("resized", self, "on_resized")
func ignore_changes(val):
graph_node.ignore_changes(val)
func save_color_state():
var p : PoolRealArray = value.points
_saved_points.resize(0)
for v in p:
_saved_points.push_back(v)
ignore_changes(true)
func undo_redo_save_color_state():
var op : PoolRealArray
var np : PoolRealArray
for v in _saved_points:
op.push_back(v)
for v in value.get_points():
np.push_back(v)
_undo_redo.create_action("MMGD: gradient colors changed")
_undo_redo.add_do_method(value, "set_points", np)
_undo_redo.add_undo_method(value, "set_points", op)
_undo_redo.commit_action()
ignore_changes(false)
func set_undo_redo(ur : UndoRedo) -> void:
_undo_redo = ur
#func get_gradient_from_data(data): #func get_gradient_from_data(data):
# if typeof(data) == TYPE_ARRAY: # if typeof(data) == TYPE_ARRAY:
# return data # return data
@ -124,8 +164,20 @@ func update_value() -> void:
var sc : Array = get_sorted_cursors() var sc : Array = get_sorted_cursors()
var points : PoolRealArray = PoolRealArray()
for c in sc: for c in sc:
value.add_point(c.rect_position.x/(rect_size.x-GradientCursor.WIDTH), c.color)
points.push_back(c.rect_position.x/(rect_size.x-GradientCursor.WIDTH))
var color : Color = c.color
points.push_back(color.r)
points.push_back(color.g)
points.push_back(color.b)
points.push_back(color.a)
value.set_points(points)
update_preview() update_preview()
@ -163,6 +215,7 @@ func select_color(cursor, position) -> void:
color_picker.color = cursor.color color_picker.color = cursor.color
color_picker.connect("color_changed", cursor, "set_color") color_picker.connect("color_changed", cursor, "set_color")
color_picker_popup.rect_position = position color_picker_popup.rect_position = position
color_picker_popup.connect("popup_hide", self, "undo_redo_save_color_state")
color_picker_popup.connect("popup_hide", color_picker_popup, "queue_free") color_picker_popup.connect("popup_hide", color_picker_popup, "queue_free")
color_picker_popup.popup() color_picker_popup.popup()

View File

@ -41,9 +41,6 @@ margin_bottom = 30.0
rect_min_size = Vector2( 120, 32 ) rect_min_size = Vector2( 120, 32 )
focus_mode = 1 focus_mode = 1
script = ExtResource( 1 ) script = ExtResource( 1 )
__meta__ = {
"_edit_use_anchors_": false
}
[node name="Background" type="ColorRect" parent="."] [node name="Background" type="ColorRect" parent="."]
material = SubResource( 2 ) material = SubResource( 2 )