From 42abce79fe9695f1091ed8c123c6f51057ff5cdc Mon Sep 17 00:00:00 2001 From: Jowan-Spooner <42868150+Jowan-Spooner@users.noreply.github.com> Date: Sat, 20 Jan 2024 12:53:51 +0100 Subject: [PATCH] Improve custom portrait workflow (#2027) This makes it so a custom layout will auto-reload when it's script was changed. Unfortunately it's pretty hard to listen to a scene getting saved right now, but that will be implemented in the future, once it's easily doable. Also makes sure the simple_highlight_portrait doesn't dim in editor. --- .../char_edit_p_section_main.gd | 1 + .../CharacterEditor/character_editor.gd | 52 ++++++++++++------- .../portraits/simple_highlight_portrait.gd | 3 +- 3 files changed, 36 insertions(+), 20 deletions(-) diff --git a/addons/dialogic/Editor/CharacterEditor/char_edit_p_section_main.gd b/addons/dialogic/Editor/CharacterEditor/char_edit_p_section_main.gd index 77bb61d11..9a1c1867b 100644 --- a/addons/dialogic/Editor/CharacterEditor/char_edit_p_section_main.gd +++ b/addons/dialogic/Editor/CharacterEditor/char_edit_p_section_main.gd @@ -33,3 +33,4 @@ func _on_scene_picker_value_changed(prop_name:String, value:String) -> void: func _on_open_scene_button_pressed(): if !%ScenePicker.current_value.is_empty() and FileAccess.file_exists(%ScenePicker.current_value): DialogicUtil.get_dialogic_plugin().get_editor_interface().open_scene_from_path(%ScenePicker.current_value) + EditorInterface.set_main_screen_editor("2D") diff --git a/addons/dialogic/Editor/CharacterEditor/character_editor.gd b/addons/dialogic/Editor/CharacterEditor/character_editor.gd index d8838422b..3637d31ac 100644 --- a/addons/dialogic/Editor/CharacterEditor/character_editor.gd +++ b/addons/dialogic/Editor/CharacterEditor/character_editor.gd @@ -89,7 +89,7 @@ func _open(extra_info:Variant="") -> void: $NoCharacterScreen.show() return - update_preview() + update_preview(true) %PortraitChangeInfo.hide() @@ -138,6 +138,8 @@ func _ready() -> void: if get_parent() is SubViewport: return + DialogicUtil.get_dialogic_plugin().resource_saved.connect(_on_some_resource_saved) + $NoCharacterScreen.color = get_theme_color("dark_color_2", "Editor") $NoCharacterScreen.show() setup_portrait_list_tab() @@ -531,18 +533,14 @@ func report_name_change(item:TreeItem) -> void: ########### PREVIEW ############################################################ #region Preview -func update_preview() -> void: +func update_preview(force:=false) -> void: %ScenePreviewWarning.hide() if selected_item and is_instance_valid(selected_item) and selected_item.get_metadata(0) != null and !selected_item.get_metadata(0).has('group'): %PreviewLabel.text = 'Preview of "'+%PortraitTree.get_full_item_name(selected_item)+'"' var current_portrait_data: Dictionary = selected_item.get_metadata(0) - var mirror:bool = current_portrait_data.get('mirror', false) != current_resource.mirror - var scale:float = current_portrait_data.get('scale', 1) * current_resource.scale - if current_portrait_data.get('ignore_char_scale', false): - scale = current_portrait_data.get('scale', 1) - var offset:Vector2 =current_portrait_data.get('offset', Vector2()) + current_resource.offset - if current_previewed_scene != null \ + + if not force and current_previewed_scene != null \ and current_previewed_scene.get_meta('path', '') == current_portrait_data.get('scene') \ and current_previewed_scene.has_method('_should_do_portrait_update') \ and is_instance_valid(current_previewed_scene.get_script()) \ @@ -551,23 +549,31 @@ func update_preview() -> void: else: for node in %RealPreviewPivot.get_children(): node.queue_free() + current_previewed_scene = null - if current_portrait_data.get('scene', '').is_empty(): - if FileAccess.file_exists(def_portrait_path): - current_previewed_scene = load(def_portrait_path).instantiate() - current_previewed_scene.set_meta('path', '') - else: - if FileAccess.file_exists(current_portrait_data.get('scene')): - current_previewed_scene = load(current_portrait_data.get('scene')).instantiate() - current_previewed_scene.set_meta('path', current_portrait_data.get('scene')) + + var scene_path := def_portrait_path + if not current_portrait_data.get('scene', '').is_empty(): + scene_path = current_portrait_data.get('scene') + + if FileAccess.file_exists(scene_path): + current_previewed_scene = load(scene_path).instantiate() + if current_previewed_scene: %RealPreviewPivot.add_child(current_previewed_scene) if current_previewed_scene != null: - var scene = current_previewed_scene + var scene: Node = current_previewed_scene + scene.show_behind_parent = true DialogicUtil.apply_scene_export_overrides(scene, current_portrait_data.get('export_overrides', {})) + var mirror: bool = current_portrait_data.get('mirror', false) != current_resource.mirror + var scale: float = current_portrait_data.get('scale', 1) * current_resource.scale + if current_portrait_data.get('ignore_char_scale', false): + scale = current_portrait_data.get('scale', 1) + var offset: Vector2 = current_portrait_data.get('offset', Vector2()) + current_resource.offset + if is_instance_valid(scene.get_script()) and scene.script.is_tool(): if scene.has_method('_update_portrait'): ## Create a fake duplicate resource that has all the portrait changes applied already @@ -576,13 +582,14 @@ func update_preview() -> void: scene._update_portrait(preview_character, %PortraitTree.get_full_item_name(selected_item)) if scene.has_method('_set_mirror'): scene._set_mirror(mirror) + if !%FitPreview_Toggle.button_pressed: scene.position = Vector2() + offset scene.scale = Vector2(1,1)*scale else: if is_instance_valid(scene.get_script()) and scene.script.is_tool() and scene.has_method('_get_covered_rect'): - var rect :Rect2= scene._get_covered_rect() - var available_rect:Rect2 = %FullPreviewAvailableRect.get_rect() + var rect: Rect2= scene._get_covered_rect() + var available_rect: Rect2 = %FullPreviewAvailableRect.get_rect() scene.scale = Vector2(1,1) * min(available_rect.size.x/rect.size.x, available_rect.size.y/rect.size.y) %RealPreviewPivot.position = (rect.position)*-1*scene.scale %RealPreviewPivot.position.x = %FullPreviewAvailableRect.size.x/2 @@ -601,6 +608,13 @@ func update_preview() -> void: current_previewed_scene = null +func _on_some_resource_saved(file:Resource) -> void: + # TODO, this only works for scripts right, so check again, there might be a + # good way to listen to Scene Saves in the future. + if file.resource_path == current_previewed_scene.get_meta("path", "") or file == current_previewed_scene.script: + update_preview(true) + + func _on_full_preview_available_rect_resized(): if %FitPreview_Toggle.button_pressed: update_preview() diff --git a/addons/dialogic/Example Assets/portraits/simple_highlight_portrait.gd b/addons/dialogic/Example Assets/portraits/simple_highlight_portrait.gd index 0a10b6918..b3bc64fb0 100644 --- a/addons/dialogic/Example Assets/portraits/simple_highlight_portrait.gd +++ b/addons/dialogic/Example Assets/portraits/simple_highlight_portrait.gd @@ -15,7 +15,8 @@ func _update_portrait(passed_character:DialogicCharacter, passed_portrait:String func _ready() -> void: - self.modulate = unhighlighted_color + if not Engine.is_editor_hint(): + self.modulate = unhighlighted_color func _highlight():