mirror of
https://github.com/Orama-Interactive/Pixelorama.git
synced 2025-01-18 17:19:50 +00:00
[Targeted for 0.11.0] Make Onion skin update live with the "Move" tool (#862)
* Make onion skin consistent with move tool * Update OnionSkinning.gd
This commit is contained in:
parent
361fe36d7a
commit
74fea47a8c
|
@ -8,6 +8,7 @@ var rate := Global.onion_skinning_past_rate
|
|||
|
||||
|
||||
func _draw() -> void:
|
||||
var project = Global.current_project
|
||||
if !Global.onion_skinning:
|
||||
return
|
||||
rate = Global.onion_skinning_past_rate if type == PAST else Global.onion_skinning_future_rate
|
||||
|
@ -18,21 +19,26 @@ func _draw() -> void:
|
|||
var position_tmp := position
|
||||
var scale_tmp := scale
|
||||
if Global.mirror_view:
|
||||
position_tmp.x += Global.current_project.size.x
|
||||
position_tmp.x += project.size.x
|
||||
scale_tmp.x = -1
|
||||
draw_set_transform(position_tmp, rotation, scale_tmp)
|
||||
|
||||
for i in range(1, rate + 1):
|
||||
var change: int = Global.current_project.current_frame
|
||||
var change: int = project.current_frame
|
||||
change += i if type == FUTURE else -i
|
||||
if change == clamp(change, 0, Global.current_project.frames.size() - 1):
|
||||
if change == clamp(change, 0, project.frames.size() - 1):
|
||||
var layer_i := 0
|
||||
for cel in Global.current_project.frames[change].cels:
|
||||
var layer: BaseLayer = Global.current_project.layers[layer_i]
|
||||
for cel in project.frames[change].cels:
|
||||
var layer: BaseLayer = project.layers[layer_i]
|
||||
if layer.is_visible_in_hierarchy():
|
||||
# Ignore layer if it has the "_io" suffix in its name (case in-sensitive)
|
||||
if not (layer.name.to_lower().ends_with("_io")):
|
||||
color.a = 0.6 / i
|
||||
draw_texture(cel.image_texture, Vector2.ZERO, color)
|
||||
if [change, layer_i] in project.selected_cels:
|
||||
draw_texture(
|
||||
cel.image_texture, Global.canvas.move_preview_location, color
|
||||
)
|
||||
else:
|
||||
draw_texture(cel.image_texture, Vector2.ZERO, color)
|
||||
layer_i += 1
|
||||
draw_set_transform(position, rotation, scale)
|
||||
|
|
Loading…
Reference in a new issue