From e9c7d3862b270fb6566983e1a3833aac3f5b0ed5 Mon Sep 17 00:00:00 2001 From: tafode Date: Mon, 11 Mar 2024 22:34:56 +0100 Subject: [PATCH 1/2] Added Default Tools Pressure setting. - Added configuration to Settings Dialog - Circle, Line and Rectangle Tool pressure use the configured pressure instead of the constant 0.5 --- lorien/Assets/I18n/en.txt | 1 + lorien/Config.gd | 1 + lorien/InfiniteCanvas/Tools/CircleTool.gd | 7 ++-- lorien/InfiniteCanvas/Tools/LineTool.gd | 10 ++--- lorien/InfiniteCanvas/Tools/RectangleTool.gd | 9 ++--- lorien/Misc/Settings.gd | 1 + lorien/UI/Dialogs/SettingsDialog.gd | 7 ++++ lorien/UI/Dialogs/SettingsDialog.tscn | 40 ++++++++++++++++---- 8 files changed, 54 insertions(+), 22 deletions(-) diff --git a/lorien/Assets/I18n/en.txt b/lorien/Assets/I18n/en.txt index 3a74e4dc..c059e19a 100644 --- a/lorien/Assets/I18n/en.txt +++ b/lorien/Assets/I18n/en.txt @@ -80,6 +80,7 @@ SETTINGS_BRUSH_CAPS Brush Rounding Mode SETTINGS_BRUSH_CAPS_FLAT Flat SETTINGS_BRUSH_CAPS_ROUND Round SETTINGS_RESTART_NOTICE Restart required to apply the new settings +SETTINGS_TOOL_PRESSURE Default Tools Pressure # ----------------------------------------------------------------------------- # About dialog strings diff --git a/lorien/Config.gd b/lorien/Config.gd index 193d26a1..b6ff88c1 100644 --- a/lorien/Config.gd +++ b/lorien/Config.gd @@ -24,4 +24,5 @@ const DEFAULT_UI_SCALE_MODE := Types.UIScale.AUTO const DEFAULT_UI_SCALE := 1.0 const DEFAULT_GRID_PATTERN := Types.GridPattern.DOTS const DEFAULT_GRID_SIZE := 25.0 +const DEFAULT_TOOL_PRESSURE := 0.5 diff --git a/lorien/InfiniteCanvas/Tools/CircleTool.gd b/lorien/InfiniteCanvas/Tools/CircleTool.gd index 0153c067..454ff787 100644 --- a/lorien/InfiniteCanvas/Tools/CircleTool.gd +++ b/lorien/InfiniteCanvas/Tools/CircleTool.gd @@ -2,7 +2,6 @@ class_name CircleTool extends CanvasTool # ------------------------------------------------------------------------------------------------- -const PRESSURE := 0.5 const STEP_IN_MOTION := 15 const STEP_STATIC := 4 @@ -31,7 +30,7 @@ func tool_event(event: InputEvent) -> void: if performing_stroke: _cursor.set_pressure(event.pressure) remove_all_stroke_points() - _make_ellipse(PRESSURE, STEP_IN_MOTION, should_draw_circle) + _make_ellipse(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE), STEP_IN_MOTION, should_draw_circle) # Start + End elif event is InputEventMouseButton: @@ -40,10 +39,10 @@ func tool_event(event: InputEvent) -> void: start_stroke() _start_position_top_left = _cursor.global_position remove_all_stroke_points() - _make_ellipse(PRESSURE, STEP_IN_MOTION, should_draw_circle) + _make_ellipse(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE), STEP_IN_MOTION, should_draw_circle) elif !event.pressed && performing_stroke: remove_all_stroke_points() - _make_ellipse(PRESSURE, STEP_STATIC, should_draw_circle) + _make_ellipse(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE), STEP_STATIC, should_draw_circle) end_stroke() # ------------------------------------------------------------------------------------------------- diff --git a/lorien/InfiniteCanvas/Tools/LineTool.gd b/lorien/InfiniteCanvas/Tools/LineTool.gd index 5c143c97..73a0b261 100644 --- a/lorien/InfiniteCanvas/Tools/LineTool.gd +++ b/lorien/InfiniteCanvas/Tools/LineTool.gd @@ -25,20 +25,20 @@ func tool_event(event: InputEvent) -> void: _cursor.set_pressure(event.pressure) remove_last_stroke_point() if _snapping_enabled: - _tail = _add_point_at_snap_pos(0.5) + _tail = _add_point_at_snap_pos(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE)) else: - _tail = _add_point_at_mouse_pos(0.5) + _tail = _add_point_at_mouse_pos(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE)) # Start + End elif event is InputEventMouseButton: if event.button_index == BUTTON_LEFT: if event.pressed: start_stroke() - _head = _add_point_at_mouse_pos(0.5) - _tail = _add_point_at_mouse_pos(0.5) + _head = _add_point_at_mouse_pos(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE)) + _tail = _add_point_at_mouse_pos(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE)) elif !event.pressed && performing_stroke: remove_last_stroke_point() - add_subdivided_line(_head, _tail, pressure_curve.interpolate(0.5)) + add_subdivided_line(_head, _tail, pressure_curve.interpolate(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE))) end_stroke() # ------------------------------------------------------------------------------------------------- diff --git a/lorien/InfiniteCanvas/Tools/RectangleTool.gd b/lorien/InfiniteCanvas/Tools/RectangleTool.gd index a89c08f0..d205a584 100644 --- a/lorien/InfiniteCanvas/Tools/RectangleTool.gd +++ b/lorien/InfiniteCanvas/Tools/RectangleTool.gd @@ -1,9 +1,6 @@ class_name RectangleTool extends CanvasTool -# ------------------------------------------------------------------------------------------------- -const PRESSURE := 0.5 - # ------------------------------------------------------------------------------------------------- export var pressure_curve: Curve var _start_position_top_left: Vector2 @@ -16,7 +13,7 @@ func tool_event(event: InputEvent) -> void: if performing_stroke: _cursor.set_pressure(event.pressure) remove_all_stroke_points() - _make_rectangle(PRESSURE) + _make_rectangle(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE)) # Start + End elif event is InputEventMouseButton: @@ -24,10 +21,10 @@ func tool_event(event: InputEvent) -> void: if event.pressed: start_stroke() _start_position_top_left = _cursor.global_position - _make_rectangle(PRESSURE) + _make_rectangle(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE)) elif !event.pressed && performing_stroke: remove_all_stroke_points() - _make_rectangle(PRESSURE) + _make_rectangle(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE)) end_stroke() # ------------------------------------------------------------------------------------------------- diff --git a/lorien/Misc/Settings.gd b/lorien/Misc/Settings.gd index 0f5a37de..b24f2d45 100644 --- a/lorien/Misc/Settings.gd +++ b/lorien/Misc/Settings.gd @@ -18,6 +18,7 @@ const RENDERING_FOREGROUND_FPS := "rendering_foreground_fps" const RENDERING_BACKGROUND_FPS := "rendering_background_fps" const RENDERING_BRUSH_ROUNDING := "rendering_brush_rounding" const COLOR_PALETTE_UUID_LAST_USED := "color_palette_uuid_last_used" +const GENERAL_TOOL_PRESSURE := "general_tool_pressure" # ------------------------------------------------------------------------------------------------- var _config_file := ConfigFile.new() diff --git a/lorien/UI/Dialogs/SettingsDialog.gd b/lorien/UI/Dialogs/SettingsDialog.gd index 087dea8b..757312da 100644 --- a/lorien/UI/Dialogs/SettingsDialog.gd +++ b/lorien/UI/Dialogs/SettingsDialog.gd @@ -43,6 +43,7 @@ onready var _ui_scale_options: OptionButton = $MarginContainer/TabContainer/Appe onready var _ui_scale: SpinBox = $MarginContainer/TabContainer/Appearance/VBoxContainer/UIScale/HBoxContainer/UIScale onready var _grid_size: SpinBox = $MarginContainer/TabContainer/Appearance/VBoxContainer/GridSize/GridSize onready var _grid_pattern: OptionButton = $MarginContainer/TabContainer/Appearance/VBoxContainer/GridPattern/GridPattern +onready var _tool_pressure: SpinBox = $MarginContainer/TabContainer/General/VBoxContainer/DefaultToolPressure/DefaultToolPressure # ------------------------------------------------------------------------------------------------- func _ready(): @@ -72,6 +73,7 @@ func _set_values() -> void: var ui_scale = Settings.get_value(Settings.APPEARANCE_UI_SCALE, Config.DEFAULT_UI_SCALE) var grid_pattern = Settings.get_value(Settings.APPEARANCE_GRID_PATTERN, Config.DEFAULT_GRID_PATTERN) var grid_size = Settings.get_value(Settings.APPEARANCE_GRID_SIZE, Config.DEFAULT_GRID_SIZE) + var tool_pressure = Settings.get_value(Settings.GENERAL_TOOL_PRESSURE, Config.DEFAULT_TOOL_PRESSURE) match theme: Types.UITheme.DARK: _theme.selected = THEME_DARK_INDEX @@ -92,6 +94,7 @@ func _set_values() -> void: _pressure_sensitivity.value = pressure_sensitivity _brush_size.value = brush_size + _tool_pressure.value = tool_pressure _canvas_color.color = canvas_color _grid_size.value = grid_size match grid_pattern: @@ -250,3 +253,7 @@ func _on_UIScale_value_changed(value: float): Settings.set_value(Settings.APPEARANCE_UI_SCALE, value) emit_signal("ui_scale_changed") popup_centered() + +# ------------------------------------------------------------------------------------------------- +func _on_DefaultToolPressure_value_changed(value): + Settings.set_value(Settings.GENERAL_TOOL_PRESSURE, value) diff --git a/lorien/UI/Dialogs/SettingsDialog.tscn b/lorien/UI/Dialogs/SettingsDialog.tscn index bf50c55f..d372cb14 100644 --- a/lorien/UI/Dialogs/SettingsDialog.tscn +++ b/lorien/UI/Dialogs/SettingsDialog.tscn @@ -110,12 +110,36 @@ min_value = 1.0 value = 12.0 allow_greater = true -[node name="DefaultSaveDir" type="HBoxContainer" parent="MarginContainer/TabContainer/General/VBoxContainer"] +[node name="DefaultToolPressure" type="HBoxContainer" parent="MarginContainer/TabContainer/General/VBoxContainer"] margin_top = 66.0 margin_right = 496.0 margin_bottom = 87.0 size_flags_horizontal = 3 +[node name="Label" type="Label" parent="MarginContainer/TabContainer/General/VBoxContainer/DefaultToolPressure"] +margin_top = 2.0 +margin_right = 246.0 +margin_bottom = 19.0 +size_flags_horizontal = 3 +size_flags_vertical = 6 +text = "SETTINGS_TOOL_PRESSURE" + +[node name="DefaultToolPressure" type="SpinBox" parent="MarginContainer/TabContainer/General/VBoxContainer/DefaultToolPressure"] +margin_left = 250.0 +margin_right = 496.0 +margin_bottom = 21.0 +size_flags_horizontal = 3 +size_flags_vertical = 3 +max_value = 1.0 +step = 0.05 +value = 1.0 + +[node name="DefaultSaveDir" type="HBoxContainer" parent="MarginContainer/TabContainer/General/VBoxContainer"] +margin_top = 91.0 +margin_right = 496.0 +margin_bottom = 112.0 +size_flags_horizontal = 3 + [node name="Label" type="Label" parent="MarginContainer/TabContainer/General/VBoxContainer/DefaultSaveDir"] margin_top = 2.0 margin_right = 246.0 @@ -134,15 +158,15 @@ placeholder_text = "e.g. C:/Users/me/Lorien" placeholder_alpha = 0.5 [node name="HSeparator4" type="HSeparator" parent="MarginContainer/TabContainer/General/VBoxContainer"] -margin_top = 91.0 +margin_top = 116.0 margin_right = 496.0 -margin_bottom = 115.0 +margin_bottom = 140.0 custom_constants/separation = 24 [node name="Language" type="HBoxContainer" parent="MarginContainer/TabContainer/General/VBoxContainer"] -margin_top = 119.0 +margin_top = 144.0 margin_right = 496.0 -margin_bottom = 144.0 +margin_bottom = 169.0 size_flags_horizontal = 3 [node name="Label" type="Label" parent="MarginContainer/TabContainer/General/VBoxContainer/Language"] @@ -161,9 +185,9 @@ size_flags_horizontal = 3 text = "English" [node name="HSeparator" type="HSeparator" parent="MarginContainer/TabContainer/General/VBoxContainer"] -margin_top = 148.0 +margin_top = 173.0 margin_right = 496.0 -margin_bottom = 160.0 +margin_bottom = 185.0 custom_constants/separation = 12 custom_styles/separator = SubResource( 3 ) @@ -177,6 +201,7 @@ text = "SETTINGS_RESTART_NOTICE" align = 1 [node name="Appearance" type="Control" parent="MarginContainer/TabContainer"] +visible = false anchor_right = 1.0 anchor_bottom = 1.0 margin_top = 27.0 @@ -507,6 +532,7 @@ dialog_autowrap = true [connection signal="value_changed" from="MarginContainer/TabContainer/General/VBoxContainer/PressureSensitivity/PressureSensitivity" to="." method="_on_PressureSensitivity_value_changed"] [connection signal="value_changed" from="MarginContainer/TabContainer/General/VBoxContainer/DefaultBrushSize/DefaultBrushSize" to="." method="_on_DefaultBrushSize_value_changed"] +[connection signal="value_changed" from="MarginContainer/TabContainer/General/VBoxContainer/DefaultToolPressure/DefaultToolPressure" to="." method="_on_DefaultToolPressure_value_changed"] [connection signal="text_changed" from="MarginContainer/TabContainer/General/VBoxContainer/DefaultSaveDir/DefaultSaveDir" to="." method="_on_DefaultSaveDir_text_changed"] [connection signal="item_selected" from="MarginContainer/TabContainer/General/VBoxContainer/Language/OptionButton" to="." method="_on_OptionButton_item_selected"] [connection signal="item_selected" from="MarginContainer/TabContainer/Appearance/VBoxContainer/Theme/Theme" to="." method="_on_Theme_item_selected"] From 1c49d6903fbf9ac4a1d2a7468fb68c3eb05b6579 Mon Sep 17 00:00:00 2001 From: Marco Eibensteiner Date: Sun, 17 Mar 2024 20:14:38 +0100 Subject: [PATCH 2/2] Code rework, removed multiple calls of Settings.getValue for GENERAL_TOOL_PRESSURE --- lorien/InfiniteCanvas/Tools/CircleTool.gd | 8 +++++--- lorien/InfiniteCanvas/Tools/LineTool.gd | 12 +++++++----- lorien/InfiniteCanvas/Tools/RectangleTool.gd | 8 +++++--- 3 files changed, 17 insertions(+), 11 deletions(-) diff --git a/lorien/InfiniteCanvas/Tools/CircleTool.gd b/lorien/InfiniteCanvas/Tools/CircleTool.gd index 454ff787..6dba52e3 100644 --- a/lorien/InfiniteCanvas/Tools/CircleTool.gd +++ b/lorien/InfiniteCanvas/Tools/CircleTool.gd @@ -26,11 +26,13 @@ func tool_event(event: InputEvent) -> void: var should_draw_circle := Input.is_key_pressed(KEY_SHIFT) + var tool_pressure : float = Settings.get_value(Settings.GENERAL_TOOL_PRESSURE) + if event is InputEventMouseMotion: if performing_stroke: _cursor.set_pressure(event.pressure) remove_all_stroke_points() - _make_ellipse(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE), STEP_IN_MOTION, should_draw_circle) + _make_ellipse(tool_pressure, STEP_IN_MOTION, should_draw_circle) # Start + End elif event is InputEventMouseButton: @@ -39,10 +41,10 @@ func tool_event(event: InputEvent) -> void: start_stroke() _start_position_top_left = _cursor.global_position remove_all_stroke_points() - _make_ellipse(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE), STEP_IN_MOTION, should_draw_circle) + _make_ellipse(tool_pressure, STEP_IN_MOTION, should_draw_circle) elif !event.pressed && performing_stroke: remove_all_stroke_points() - _make_ellipse(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE), STEP_STATIC, should_draw_circle) + _make_ellipse(tool_pressure, STEP_STATIC, should_draw_circle) end_stroke() # ------------------------------------------------------------------------------------------------- diff --git a/lorien/InfiniteCanvas/Tools/LineTool.gd b/lorien/InfiniteCanvas/Tools/LineTool.gd index 73a0b261..5da86897 100644 --- a/lorien/InfiniteCanvas/Tools/LineTool.gd +++ b/lorien/InfiniteCanvas/Tools/LineTool.gd @@ -14,6 +14,8 @@ var _tail: Vector2 func tool_event(event: InputEvent) -> void: _cursor.set_pressure(1.0) + var tool_pressure = Settings.get_value(Settings.GENERAL_TOOL_PRESSURE) + # Snap modifier if event is InputEventKey: if event.scancode == KEY_SHIFT: @@ -25,20 +27,20 @@ func tool_event(event: InputEvent) -> void: _cursor.set_pressure(event.pressure) remove_last_stroke_point() if _snapping_enabled: - _tail = _add_point_at_snap_pos(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE)) + _tail = _add_point_at_snap_pos(tool_pressure) else: - _tail = _add_point_at_mouse_pos(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE)) + _tail = _add_point_at_mouse_pos(tool_pressure) # Start + End elif event is InputEventMouseButton: if event.button_index == BUTTON_LEFT: if event.pressed: start_stroke() - _head = _add_point_at_mouse_pos(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE)) - _tail = _add_point_at_mouse_pos(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE)) + _head = _add_point_at_mouse_pos(tool_pressure) + _tail = _add_point_at_mouse_pos(tool_pressure) elif !event.pressed && performing_stroke: remove_last_stroke_point() - add_subdivided_line(_head, _tail, pressure_curve.interpolate(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE))) + add_subdivided_line(_head, _tail, pressure_curve.interpolate(tool_pressure)) end_stroke() # ------------------------------------------------------------------------------------------------- diff --git a/lorien/InfiniteCanvas/Tools/RectangleTool.gd b/lorien/InfiniteCanvas/Tools/RectangleTool.gd index d205a584..4957b660 100644 --- a/lorien/InfiniteCanvas/Tools/RectangleTool.gd +++ b/lorien/InfiniteCanvas/Tools/RectangleTool.gd @@ -9,11 +9,13 @@ var _start_position_top_left: Vector2 func tool_event(event: InputEvent) -> void: _cursor.set_pressure(1.0) + var tool_pressure = Settings.get_value(Settings.GENERAL_TOOL_PRESSURE) + if event is InputEventMouseMotion: if performing_stroke: _cursor.set_pressure(event.pressure) remove_all_stroke_points() - _make_rectangle(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE)) + _make_rectangle(tool_pressure) # Start + End elif event is InputEventMouseButton: @@ -21,10 +23,10 @@ func tool_event(event: InputEvent) -> void: if event.pressed: start_stroke() _start_position_top_left = _cursor.global_position - _make_rectangle(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE)) + _make_rectangle(tool_pressure) elif !event.pressed && performing_stroke: remove_all_stroke_points() - _make_rectangle(Settings.get_value(Settings.GENERAL_TOOL_PRESSURE)) + _make_rectangle(tool_pressure) end_stroke() # -------------------------------------------------------------------------------------------------