mirror of
https://github.com/Orama-Interactive/Pixelorama.git
synced 2025-01-19 01:29:49 +00:00
Transform selected content of multiple selected cels
Does not work with rotation. It might be a good idea to replace this whole system with one that uses a transformation matrix, to handle rotation and skewing more easily in the future. I'm not a huge fan of this current code.
This commit is contained in:
parent
a3eb1b7ec9
commit
ac631e3e3d
|
@ -673,12 +673,13 @@ func update_recent_projects_submenu() -> void:
|
||||||
for project in recent_projects:
|
for project in recent_projects:
|
||||||
recent_projects_submenu.add_item(project.get_file())
|
recent_projects_submenu.add_item(project.get_file())
|
||||||
|
|
||||||
|
|
||||||
func use_osx_shortcuts() -> void:
|
func use_osx_shortcuts() -> void:
|
||||||
var inputmap := InputMap
|
var inputmap := InputMap
|
||||||
|
|
||||||
for action in inputmap.get_actions():
|
for action in inputmap.get_actions():
|
||||||
var event : InputEvent = inputmap.get_action_list(action)[0]
|
var event : InputEvent = inputmap.get_action_list(action)[0]
|
||||||
|
|
||||||
if event.is_action("show_pixel_grid"):
|
if event.is_action("show_pixel_grid"):
|
||||||
event.shift = true
|
event.shift = true
|
||||||
|
|
||||||
|
|
|
@ -615,16 +615,16 @@ func is_empty() -> bool:
|
||||||
return frames.size() == 1 and layers.size() == 1 and frames[0].cels[0].image.is_invisible() and animation_tags.size() == 0
|
return frames.size() == 1 and layers.size() == 1 and frames[0].cels[0].image.is_invisible() and animation_tags.size() == 0
|
||||||
|
|
||||||
|
|
||||||
func can_pixel_get_drawn(pixel : Vector2) -> bool:
|
func can_pixel_get_drawn(pixel : Vector2, bitmap : BitMap = selection_bitmap, selection_position : Vector2 = Global.canvas.selection.big_bounding_rectangle.position) -> bool:
|
||||||
if pixel.x < 0 or pixel.y < 0 or pixel.x >= size.x or pixel.y >= size.y:
|
if pixel.x < 0 or pixel.y < 0 or pixel.x >= size.x or pixel.y >= size.y:
|
||||||
return false
|
return false
|
||||||
var selection_position : Vector2 = Global.canvas.selection.big_bounding_rectangle.position
|
|
||||||
if selection_position.x < 0:
|
if selection_position.x < 0:
|
||||||
pixel.x -= selection_position.x
|
pixel.x -= selection_position.x
|
||||||
if selection_position.y < 0:
|
if selection_position.y < 0:
|
||||||
pixel.y -= selection_position.y
|
pixel.y -= selection_position.y
|
||||||
if has_selection:
|
if has_selection:
|
||||||
return selection_bitmap.get_bit(pixel)
|
return bitmap.get_bit(pixel)
|
||||||
else:
|
else:
|
||||||
return true
|
return true
|
||||||
|
|
||||||
|
|
|
@ -415,7 +415,6 @@ func select_rect(rect : Rect2, operation : int = SelectionOperation.ADD) -> void
|
||||||
self.big_bounding_rectangle = big_bounding_rectangle # call getter method
|
self.big_bounding_rectangle = big_bounding_rectangle # call getter method
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
func move_borders_start() -> void:
|
func move_borders_start() -> void:
|
||||||
undo_data = _get_undo_data(false)
|
undo_data = _get_undo_data(false)
|
||||||
|
|
||||||
|
@ -464,13 +463,25 @@ func transform_content_confirm() -> void:
|
||||||
if !is_moving_content:
|
if !is_moving_content:
|
||||||
return
|
return
|
||||||
var project : Project = Global.current_project
|
var project : Project = Global.current_project
|
||||||
if project.current_frame < project.frames.size() and project.current_layer < project.layers.size():
|
for cel_index in project.selected_cels:
|
||||||
var cel_image : Image = project.frames[project.current_frame].cels[project.current_layer].image
|
var frame : int = cel_index[0]
|
||||||
cel_image.blit_rect_mask(preview_image, preview_image, Rect2(Vector2.ZERO, project.selection_bitmap.get_size()), big_bounding_rectangle.position)
|
var layer : int = cel_index[1]
|
||||||
var selected_bitmap_copy = project.selection_bitmap.duplicate()
|
if frame < project.frames.size() and layer < project.layers.size():
|
||||||
project.move_bitmap_values(selected_bitmap_copy)
|
var cel_image : Image = project.frames[frame].cels[layer].image
|
||||||
project.selection_bitmap = selected_bitmap_copy
|
var src : Image = preview_image
|
||||||
commit_undo("Move Selection", undo_data)
|
if not (frame == project.current_frame and layer == project.current_layer):
|
||||||
|
src = get_selected_image(cel_image)
|
||||||
|
src.resize(big_bounding_rectangle.size.x, big_bounding_rectangle.size.y, Image.INTERPOLATE_NEAREST)
|
||||||
|
if temp_rect.size.x < 0:
|
||||||
|
src.flip_x()
|
||||||
|
if temp_rect.size.y < 0:
|
||||||
|
src.flip_y()
|
||||||
|
|
||||||
|
cel_image.blit_rect_mask(src, src, Rect2(Vector2.ZERO, project.selection_bitmap.get_size()), big_bounding_rectangle.position)
|
||||||
|
var selected_bitmap_copy = project.selection_bitmap.duplicate()
|
||||||
|
project.move_bitmap_values(selected_bitmap_copy)
|
||||||
|
project.selection_bitmap = selected_bitmap_copy
|
||||||
|
commit_undo("Move Selection", undo_data)
|
||||||
|
|
||||||
original_preview_image = Image.new()
|
original_preview_image = Image.new()
|
||||||
preview_image = Image.new()
|
preview_image = Image.new()
|
||||||
|
@ -506,7 +517,7 @@ func commit_undo(action : String, _undo_data : Dictionary) -> void:
|
||||||
if !_undo_data:
|
if !_undo_data:
|
||||||
print("No undo data found!")
|
print("No undo data found!")
|
||||||
return
|
return
|
||||||
var redo_data = _get_undo_data("image_data" in _undo_data)
|
var redo_data = _get_undo_data(_undo_data["undo_image"])
|
||||||
var project := Global.current_project
|
var project := Global.current_project
|
||||||
|
|
||||||
project.undos += 1
|
project.undos += 1
|
||||||
|
@ -520,13 +531,18 @@ func commit_undo(action : String, _undo_data : Dictionary) -> void:
|
||||||
project.undo_redo.add_undo_property(project, "selection_offset", _undo_data["outline_offset"])
|
project.undo_redo.add_undo_property(project, "selection_offset", _undo_data["outline_offset"])
|
||||||
|
|
||||||
|
|
||||||
if "image_data" in _undo_data:
|
if _undo_data["undo_image"]:
|
||||||
var image : Image = project.frames[project.current_frame].cels[project.current_layer].image
|
for image in redo_data:
|
||||||
project.undo_redo.add_do_property(image, "data", redo_data["image_data"])
|
if not image is Image:
|
||||||
project.undo_redo.add_undo_property(image, "data", _undo_data["image_data"])
|
continue
|
||||||
project.undo_redo.add_do_method(Global, "redo", project.current_frame, project.current_layer)
|
project.undo_redo.add_do_property(image, "data", redo_data[image])
|
||||||
|
for image in undo_data:
|
||||||
|
if not image is Image:
|
||||||
|
continue
|
||||||
|
project.undo_redo.add_undo_property(image, "data", _undo_data[image])
|
||||||
|
project.undo_redo.add_do_method(Global, "redo")
|
||||||
project.undo_redo.add_do_method(project, "selection_bitmap_changed")
|
project.undo_redo.add_do_method(project, "selection_bitmap_changed")
|
||||||
project.undo_redo.add_undo_method(Global, "undo", project.current_frame, project.current_layer)
|
project.undo_redo.add_undo_method(Global, "undo")
|
||||||
project.undo_redo.add_undo_method(project, "selection_bitmap_changed")
|
project.undo_redo.add_undo_method(project, "selection_bitmap_changed")
|
||||||
project.undo_redo.commit_action()
|
project.undo_redo.commit_action()
|
||||||
|
|
||||||
|
@ -539,16 +555,27 @@ func _get_undo_data(undo_image : bool) -> Dictionary:
|
||||||
data["selection_bitmap"] = project.selection_bitmap
|
data["selection_bitmap"] = project.selection_bitmap
|
||||||
data["big_bounding_rectangle"] = big_bounding_rectangle
|
data["big_bounding_rectangle"] = big_bounding_rectangle
|
||||||
data["outline_offset"] = Global.current_project.selection_offset
|
data["outline_offset"] = Global.current_project.selection_offset
|
||||||
|
data["undo_image"] = undo_image
|
||||||
|
|
||||||
if undo_image:
|
if undo_image:
|
||||||
var image : Image = project.frames[project.current_frame].cels[project.current_layer].image
|
var images := _get_selected_draw_images()
|
||||||
image.unlock()
|
for image in images:
|
||||||
data["image_data"] = image.data
|
image.unlock()
|
||||||
image.lock()
|
data[image] = image.data
|
||||||
|
image.lock()
|
||||||
|
|
||||||
return data
|
return data
|
||||||
|
|
||||||
|
|
||||||
|
func _get_selected_draw_images() -> Array: # Array of Images
|
||||||
|
var images := []
|
||||||
|
var project : Project = Global.current_project
|
||||||
|
for cel_index in project.selected_cels:
|
||||||
|
var cel : Cel = project.frames[cel_index[0]].cels[cel_index[1]]
|
||||||
|
images.append(cel.image)
|
||||||
|
return images
|
||||||
|
|
||||||
|
|
||||||
func cut() -> void:
|
func cut() -> void:
|
||||||
copy()
|
copy()
|
||||||
delete()
|
delete()
|
||||||
|
@ -737,3 +764,27 @@ func get_preview_image() -> void:
|
||||||
clear_image.create(original_preview_image.get_width(), original_preview_image.get_height(), false, Image.FORMAT_RGBA8)
|
clear_image.create(original_preview_image.get_width(), original_preview_image.get_height(), false, Image.FORMAT_RGBA8)
|
||||||
cel_image.blit_rect_mask(clear_image, original_preview_image, Rect2(Vector2.ZERO, Global.current_project.selection_bitmap.get_size()), big_bounding_rectangle.position)
|
cel_image.blit_rect_mask(clear_image, original_preview_image, Rect2(Vector2.ZERO, Global.current_project.selection_bitmap.get_size()), big_bounding_rectangle.position)
|
||||||
Global.canvas.update_texture(project.current_layer)
|
Global.canvas.update_texture(project.current_layer)
|
||||||
|
|
||||||
|
|
||||||
|
func get_selected_image(cel_image : Image) -> Image:
|
||||||
|
var project : Project = Global.current_project
|
||||||
|
var image := Image.new()
|
||||||
|
image = cel_image.get_rect(original_big_bounding_rectangle)
|
||||||
|
image.lock()
|
||||||
|
# For non-rectangular selections
|
||||||
|
for x in range(0, original_big_bounding_rectangle.size.x):
|
||||||
|
for y in range(0, original_big_bounding_rectangle.size.y):
|
||||||
|
var pos := Vector2(x, y)
|
||||||
|
if !project.can_pixel_get_drawn(pos + original_big_bounding_rectangle.position, original_bitmap, original_big_bounding_rectangle.position):
|
||||||
|
image.set_pixelv(pos, Color(0, 0, 0, 0))
|
||||||
|
|
||||||
|
image.unlock()
|
||||||
|
if image.is_invisible():
|
||||||
|
return image
|
||||||
|
|
||||||
|
var clear_image := Image.new()
|
||||||
|
clear_image.create(image.get_width(), image.get_height(), false, Image.FORMAT_RGBA8)
|
||||||
|
cel_image.blit_rect_mask(clear_image, image, Rect2(Vector2.ZERO, Global.current_project.selection_bitmap.get_size()), original_big_bounding_rectangle.position)
|
||||||
|
Global.canvas.update_texture(project.current_layer)
|
||||||
|
|
||||||
|
return image
|
||||||
|
|
Loading…
Reference in a new issue