Skip to content

Commit

Permalink
Improve custom portrait workflow (#2027)
Browse files Browse the repository at this point in the history
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.
  • Loading branch information
Jowan-Spooner authored Jan 20, 2024
1 parent 46c76a7 commit 42abce7
Show file tree
Hide file tree
Showing 3 changed files with 36 additions and 20 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -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")
52 changes: 33 additions & 19 deletions addons/dialogic/Editor/CharacterEditor/character_editor.gd
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,7 @@ func _open(extra_info:Variant="") -> void:
$NoCharacterScreen.show()
return

update_preview()
update_preview(true)
%PortraitChangeInfo.hide()


Expand Down Expand Up @@ -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()
Expand Down Expand Up @@ -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()) \
Expand All @@ -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
Expand All @@ -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
Expand All @@ -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()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -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():
Expand Down

0 comments on commit 42abce7

Please sign in to comment.