mirror of
https://github.com/Orama-Interactive/Pixelorama.git
synced 2025-01-18 09:09:47 +00:00
Add an offset slider for GradientEdit's selected point
This commit is contained in:
parent
5cfc22a3ad
commit
bbc93e3f82
|
@ -7,11 +7,21 @@ extends Control
|
||||||
signal updated(gradient: Gradient, cc: bool)
|
signal updated(gradient: Gradient, cc: bool)
|
||||||
|
|
||||||
var continuous_change := true
|
var continuous_change := true
|
||||||
var active_cursor: GradientCursor ## Showing a color picker popup to change a cursor's color
|
var active_cursor: GradientCursor: ## Showing a color picker popup to change a cursor's color
|
||||||
|
set(value):
|
||||||
|
active_cursor = value
|
||||||
|
if is_instance_valid(active_cursor):
|
||||||
|
await get_tree().process_frame
|
||||||
|
offset_value_slider.set_value_no_signal_update_display(
|
||||||
|
active_cursor.get_cursor_offset()
|
||||||
|
)
|
||||||
|
for i in texture_rect.get_children():
|
||||||
|
i.queue_redraw()
|
||||||
var texture := GradientTexture2D.new()
|
var texture := GradientTexture2D.new()
|
||||||
var gradient := Gradient.new()
|
var gradient := Gradient.new()
|
||||||
|
|
||||||
@onready var x_offset: float = size.x - GradientCursor.WIDTH
|
@onready var x_offset: float = size.x - GradientCursor.WIDTH
|
||||||
|
@onready var offset_value_slider := %OffsetValueSlider as ValueSlider
|
||||||
@onready var texture_rect := $TextureRect as TextureRect
|
@onready var texture_rect := $TextureRect as TextureRect
|
||||||
@onready var color_picker := $Popup.get_node("ColorPicker") as ColorPicker
|
@onready var color_picker := $Popup.get_node("ColorPicker") as ColorPicker
|
||||||
@onready var divide_dialog := $DivideConfirmationDialog as ConfirmationDialog
|
@onready var divide_dialog := $DivideConfirmationDialog as ConfirmationDialog
|
||||||
|
@ -27,28 +37,39 @@ class GradientCursor:
|
||||||
var sliding := false
|
var sliding := false
|
||||||
|
|
||||||
@onready var parent: TextureRect = get_parent()
|
@onready var parent: TextureRect = get_parent()
|
||||||
@onready var grand_parent: Container = parent.get_parent()
|
@onready var grand_parent: GradientEditNode = parent.get_parent()
|
||||||
@onready var label: Label = parent.get_node("Value")
|
|
||||||
|
|
||||||
func _ready() -> void:
|
func _ready() -> void:
|
||||||
position = Vector2(0, 15)
|
size = Vector2(WIDTH, get_parent().size.y)
|
||||||
size = Vector2(WIDTH, 15)
|
|
||||||
|
|
||||||
func _draw() -> void:
|
func _draw() -> void:
|
||||||
var polygon := PackedVector2Array(
|
var polygon := PackedVector2Array(
|
||||||
[
|
[
|
||||||
Vector2(0, 5),
|
Vector2(0, size.y * 0.75),
|
||||||
Vector2(WIDTH / 2.0, 0),
|
Vector2(WIDTH * 0.5, size.y * 0.5),
|
||||||
Vector2(WIDTH, 5),
|
Vector2(WIDTH, size.y * 0.75),
|
||||||
Vector2(WIDTH, 15),
|
Vector2(WIDTH, size.y),
|
||||||
Vector2(0, 15),
|
Vector2(0, size.y),
|
||||||
Vector2(0, 5)
|
Vector2(0, size.y * 0.75)
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
var c := color
|
var c := color
|
||||||
c.a = 1.0
|
c.a = 1.0
|
||||||
draw_colored_polygon(polygon, c)
|
draw_colored_polygon(polygon, c)
|
||||||
draw_polyline(polygon, Color(0.0, 0.0, 0.0) if color.v > 0.5 else Color(1.0, 1.0, 1.0))
|
var outline_color := Color.BLACK if (color.get_luminance() > 0.5) else Color.WHITE
|
||||||
|
draw_polyline(polygon, outline_color)
|
||||||
|
draw_dashed_line(Vector2(WIDTH * 0.5, 0), Vector2(WIDTH * 0.5, size.y * 0.5), outline_color)
|
||||||
|
# Draw the TRIANGLE (house roof) shape
|
||||||
|
if grand_parent.active_cursor == self:
|
||||||
|
var active_polygon: PackedVector2Array = PackedVector2Array(
|
||||||
|
[
|
||||||
|
Vector2(0, size.y * 0.75),
|
||||||
|
Vector2(WIDTH * 0.5, size.y * 0.5),
|
||||||
|
Vector2(WIDTH, size.y * 0.75),
|
||||||
|
Vector2(0, size.y * 0.75)
|
||||||
|
]
|
||||||
|
)
|
||||||
|
draw_colored_polygon(active_polygon, outline_color)
|
||||||
|
|
||||||
func _gui_input(ev: InputEvent) -> void:
|
func _gui_input(ev: InputEvent) -> void:
|
||||||
if ev is InputEventMouseButton:
|
if ev is InputEventMouseButton:
|
||||||
|
@ -56,36 +77,46 @@ class GradientCursor:
|
||||||
if ev.double_click:
|
if ev.double_click:
|
||||||
grand_parent.select_color(self, ev.global_position)
|
grand_parent.select_color(self, ev.global_position)
|
||||||
elif ev.pressed:
|
elif ev.pressed:
|
||||||
|
grand_parent.active_cursor = self
|
||||||
grand_parent.continuous_change = false
|
grand_parent.continuous_change = false
|
||||||
sliding = true
|
sliding = true
|
||||||
label.visible = true
|
|
||||||
label.text = "%.03f" % get_caret_column()
|
|
||||||
else:
|
else:
|
||||||
sliding = false
|
sliding = false
|
||||||
label.visible = false
|
|
||||||
elif (
|
elif (
|
||||||
ev.button_index == MOUSE_BUTTON_RIGHT
|
ev.button_index == MOUSE_BUTTON_RIGHT
|
||||||
and grand_parent.get_sorted_cursors().size() > 2
|
and grand_parent.get_sorted_cursors().size() > 2
|
||||||
):
|
):
|
||||||
|
var node_index := get_index()
|
||||||
parent.remove_child(self)
|
parent.remove_child(self)
|
||||||
|
queue_free()
|
||||||
|
if grand_parent.active_cursor == self:
|
||||||
|
if node_index > 0:
|
||||||
|
node_index -= 1
|
||||||
|
grand_parent.active_cursor = parent.get_child(node_index)
|
||||||
grand_parent.continuous_change = false
|
grand_parent.continuous_change = false
|
||||||
grand_parent.update_from_value()
|
grand_parent.update_from_value()
|
||||||
queue_free()
|
|
||||||
elif (
|
elif (
|
||||||
ev is InputEventMouseMotion
|
ev is InputEventMouseMotion
|
||||||
and (ev.button_mask & MOUSE_BUTTON_MASK_LEFT) != 0
|
and (ev.button_mask & MOUSE_BUTTON_MASK_LEFT) != 0
|
||||||
and sliding
|
and sliding
|
||||||
):
|
):
|
||||||
position.x += get_local_mouse_position().x
|
move_to(position.x + get_local_mouse_position().x, true, ev.ctrl_pressed)
|
||||||
if ev.ctrl_pressed:
|
|
||||||
position.x = (roundi(get_caret_column() * 20.0) * 0.05 * (parent.size.x - WIDTH))
|
|
||||||
position.x = mini(maxi(0, position.x), parent.size.x - size.x)
|
|
||||||
grand_parent.update_from_value()
|
|
||||||
label.text = "%.03f" % get_caret_column()
|
|
||||||
|
|
||||||
func get_caret_column() -> float:
|
func move_to(pos: float, update_slider: bool, snap := false) -> void:
|
||||||
|
position.x = pos
|
||||||
|
if snap:
|
||||||
|
position.x = (roundi(get_cursor_offset() * 20.0) * 0.05 * (parent.size.x - WIDTH))
|
||||||
|
position.x = mini(maxi(0, position.x), parent.size.x - size.x)
|
||||||
|
grand_parent.update_from_value()
|
||||||
|
if update_slider:
|
||||||
|
grand_parent.offset_value_slider.value = get_cursor_offset()
|
||||||
|
|
||||||
|
func get_cursor_offset() -> float:
|
||||||
return position.x / (parent.size.x - WIDTH)
|
return position.x / (parent.size.x - WIDTH)
|
||||||
|
|
||||||
|
func get_cursor_position_from_offset(offset: float) -> float:
|
||||||
|
return offset * (parent.size.x - WIDTH)
|
||||||
|
|
||||||
func set_color(c: Color) -> void:
|
func set_color(c: Color) -> void:
|
||||||
color = c
|
color = c
|
||||||
grand_parent.update_from_value()
|
grand_parent.update_from_value()
|
||||||
|
@ -141,12 +172,12 @@ func update_from_value() -> void:
|
||||||
func add_cursor(x: float, color: Color) -> void:
|
func add_cursor(x: float, color: Color) -> void:
|
||||||
var cursor := GradientCursor.new()
|
var cursor := GradientCursor.new()
|
||||||
texture_rect.add_child(cursor)
|
texture_rect.add_child(cursor)
|
||||||
|
active_cursor = cursor
|
||||||
cursor.position.x = x
|
cursor.position.x = x
|
||||||
cursor.color = color
|
cursor.color = color
|
||||||
|
|
||||||
|
|
||||||
func select_color(cursor: GradientCursor, pos: Vector2) -> void:
|
func select_color(cursor: GradientCursor, pos: Vector2) -> void:
|
||||||
active_cursor = cursor
|
|
||||||
color_picker.color = cursor.color
|
color_picker.color = cursor.color
|
||||||
if pos.x > global_position.x + (size.x / 2.0):
|
if pos.x > global_position.x + (size.x / 2.0):
|
||||||
pos.x = global_position.x + size.x
|
pos.x = global_position.x + size.x
|
||||||
|
@ -194,6 +225,12 @@ func _on_GradientEdit_resized() -> void:
|
||||||
_create_cursors()
|
_create_cursors()
|
||||||
|
|
||||||
|
|
||||||
|
func _on_offset_value_slider_value_changed(value: float) -> void:
|
||||||
|
var cursor_pos := active_cursor.get_cursor_position_from_offset(value)
|
||||||
|
if cursor_pos != active_cursor.get_cursor_offset():
|
||||||
|
active_cursor.move_to(cursor_pos, false)
|
||||||
|
|
||||||
|
|
||||||
func _on_InterpolationOptionButton_item_selected(index: Gradient.InterpolationMode) -> void:
|
func _on_InterpolationOptionButton_item_selected(index: Gradient.InterpolationMode) -> void:
|
||||||
gradient.interpolation_mode = index
|
gradient.interpolation_mode = index
|
||||||
updated.emit(gradient, continuous_change)
|
updated.emit(gradient, continuous_change)
|
||||||
|
|
|
@ -1,7 +1,8 @@
|
||||||
[gd_scene load_steps=3 format=3 uid="uid://bn4aw27dj7pwi"]
|
[gd_scene load_steps=4 format=3 uid="uid://bn4aw27dj7pwi"]
|
||||||
|
|
||||||
[ext_resource type="Script" path="res://src/UI/Nodes/GradientEdit.gd" id="1"]
|
[ext_resource type="Script" path="res://src/UI/Nodes/GradientEdit.gd" id="1"]
|
||||||
[ext_resource type="Texture2D" uid="uid://cis71foi5jt31" path="res://assets/graphics/misc/settings.svg" id="2_2dyyb"]
|
[ext_resource type="Texture2D" uid="uid://cis71foi5jt31" path="res://assets/graphics/misc/settings.svg" id="2_2dyyb"]
|
||||||
|
[ext_resource type="Script" path="res://src/UI/Nodes/Sliders/ValueSlider.gd" id="2_y6708"]
|
||||||
|
|
||||||
[node name="GradientEdit" type="VBoxContainer"]
|
[node name="GradientEdit" type="VBoxContainer"]
|
||||||
anchors_preset = 15
|
anchors_preset = 15
|
||||||
|
@ -12,6 +13,24 @@ script = ExtResource("1")
|
||||||
[node name="InterpolationContainer" type="HBoxContainer" parent="."]
|
[node name="InterpolationContainer" type="HBoxContainer" parent="."]
|
||||||
layout_mode = 2
|
layout_mode = 2
|
||||||
|
|
||||||
|
[node name="OffsetValueSlider" type="TextureProgressBar" parent="InterpolationContainer"]
|
||||||
|
unique_name_in_owner = true
|
||||||
|
layout_mode = 2
|
||||||
|
size_flags_horizontal = 3
|
||||||
|
focus_mode = 2
|
||||||
|
mouse_filter = 0
|
||||||
|
mouse_default_cursor_shape = 2
|
||||||
|
theme_type_variation = &"ValueSlider"
|
||||||
|
max_value = 1.0
|
||||||
|
step = 0.001
|
||||||
|
nine_patch_stretch = true
|
||||||
|
stretch_margin_left = 3
|
||||||
|
stretch_margin_top = 3
|
||||||
|
stretch_margin_right = 3
|
||||||
|
stretch_margin_bottom = 3
|
||||||
|
script = ExtResource("2_y6708")
|
||||||
|
snap_step = 0.1
|
||||||
|
|
||||||
[node name="InterpolationOptionButton" type="OptionButton" parent="InterpolationContainer"]
|
[node name="InterpolationOptionButton" type="OptionButton" parent="InterpolationContainer"]
|
||||||
unique_name_in_owner = true
|
unique_name_in_owner = true
|
||||||
layout_mode = 2
|
layout_mode = 2
|
||||||
|
@ -61,17 +80,6 @@ layout_mode = 2
|
||||||
size_flags_vertical = 3
|
size_flags_vertical = 3
|
||||||
expand_mode = 1
|
expand_mode = 1
|
||||||
|
|
||||||
[node name="Value" type="Label" parent="TextureRect"]
|
|
||||||
layout_mode = 0
|
|
||||||
anchor_left = 0.5
|
|
||||||
anchor_top = 0.5
|
|
||||||
anchor_right = 0.5
|
|
||||||
anchor_bottom = 0.5
|
|
||||||
offset_left = -20.0
|
|
||||||
offset_top = -7.0
|
|
||||||
offset_right = 20.0
|
|
||||||
offset_bottom = 7.0
|
|
||||||
|
|
||||||
[node name="Popup" type="PopupPanel" parent="."]
|
[node name="Popup" type="PopupPanel" parent="."]
|
||||||
unresizable = false
|
unresizable = false
|
||||||
borderless = false
|
borderless = false
|
||||||
|
@ -118,6 +126,7 @@ mouse_default_cursor_shape = 2
|
||||||
text = "Add point at the end"
|
text = "Add point at the end"
|
||||||
|
|
||||||
[connection signal="resized" from="." to="." method="_on_GradientEdit_resized"]
|
[connection signal="resized" from="." to="." method="_on_GradientEdit_resized"]
|
||||||
|
[connection signal="value_changed" from="InterpolationContainer/OffsetValueSlider" to="." method="_on_offset_value_slider_value_changed"]
|
||||||
[connection signal="item_selected" from="InterpolationContainer/InterpolationOptionButton" to="." method="_on_InterpolationOptionButton_item_selected"]
|
[connection signal="item_selected" from="InterpolationContainer/InterpolationOptionButton" to="." method="_on_InterpolationOptionButton_item_selected"]
|
||||||
[connection signal="item_selected" from="InterpolationContainer/ColorSpaceOptionButton" to="." method="_on_color_space_option_button_item_selected"]
|
[connection signal="item_selected" from="InterpolationContainer/ColorSpaceOptionButton" to="." method="_on_color_space_option_button_item_selected"]
|
||||||
[connection signal="color_changed" from="Popup/ColorPicker" to="." method="_on_ColorPicker_color_changed"]
|
[connection signal="color_changed" from="Popup/ColorPicker" to="." method="_on_ColorPicker_color_changed"]
|
||||||
|
|
|
@ -255,6 +255,11 @@ func _confirm_text(confirm := true) -> void:
|
||||||
_reset_display(true)
|
_reset_display(true)
|
||||||
|
|
||||||
|
|
||||||
|
func set_value_no_signal_update_display(new_value: float) -> void:
|
||||||
|
set_value_no_signal(new_value)
|
||||||
|
_reset_display()
|
||||||
|
|
||||||
|
|
||||||
func _reset_display(theme_has_changed := false) -> void:
|
func _reset_display(theme_has_changed := false) -> void:
|
||||||
_line_edit.selecting_enabled = false # Remove the selection
|
_line_edit.selecting_enabled = false # Remove the selection
|
||||||
_line_edit.editable = false
|
_line_edit.editable = false
|
||||||
|
|
Loading…
Reference in a new issue