mirror of
https://github.com/Orama-Interactive/Pixelorama.git
synced 2025-01-18 17:19:50 +00:00
Center diagonal symmetry guides when initializing a new project
The guides appear centered, but the symmetry itself is not working properly yet
This commit is contained in:
parent
3d65e48c92
commit
d0ecf3b03d
|
@ -548,7 +548,7 @@ func get_mirrored_positions(
|
||||||
if diagonal_xy_mirror:
|
if diagonal_xy_mirror:
|
||||||
var mirror_diagonal := calculate_mirror_xy(pos, project)
|
var mirror_diagonal := calculate_mirror_xy(pos, project)
|
||||||
positions.append(mirror_diagonal)
|
positions.append(mirror_diagonal)
|
||||||
if not horizontal_mirror and not vertical_mirror:
|
if not horizontal_mirror and not vertical_mirror and diagonal_x_minus_y_mirror:
|
||||||
positions.append(calculate_mirror_x_minus_y(mirror_diagonal, project))
|
positions.append(calculate_mirror_x_minus_y(mirror_diagonal, project))
|
||||||
if diagonal_x_minus_y_mirror:
|
if diagonal_x_minus_y_mirror:
|
||||||
positions.append(calculate_mirror_x_minus_y(pos, project))
|
positions.append(calculate_mirror_x_minus_y(pos, project))
|
||||||
|
@ -564,11 +564,14 @@ func calculate_mirror_vertical(pos: Vector2i, project: Project, offset := 0) ->
|
||||||
|
|
||||||
|
|
||||||
func calculate_mirror_xy(pos: Vector2i, project: Project) -> Vector2i:
|
func calculate_mirror_xy(pos: Vector2i, project: Project) -> Vector2i:
|
||||||
return Vector2i(Vector2(pos).reflect(XY_LINE).round()) + project.size - Vector2i.ONE
|
return Vector2i(Vector2(pos).reflect(XY_LINE).round()) + Vector2i(project.xy_symmetry_point)
|
||||||
|
|
||||||
|
|
||||||
func calculate_mirror_x_minus_y(pos: Vector2i, _project: Project) -> Vector2i:
|
func calculate_mirror_x_minus_y(pos: Vector2i, project: Project) -> Vector2i:
|
||||||
return Vector2i(Vector2(pos).reflect(X_MINUS_Y_LINE).round())
|
return (
|
||||||
|
Vector2i(Vector2(pos).reflect(X_MINUS_Y_LINE).round())
|
||||||
|
+ Vector2i(project.x_minus_y_symmetry_point)
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
func set_button_size(button_size: int) -> void:
|
func set_button_size(button_size: int) -> void:
|
||||||
|
|
|
@ -69,6 +69,8 @@ var user_data := "" ## User defined data, set in the project properties.
|
||||||
|
|
||||||
var x_symmetry_point: float
|
var x_symmetry_point: float
|
||||||
var y_symmetry_point: float
|
var y_symmetry_point: float
|
||||||
|
var xy_symmetry_point: Vector2
|
||||||
|
var x_minus_y_symmetry_point: Vector2
|
||||||
var x_symmetry_axis := SymmetryGuide.new()
|
var x_symmetry_axis := SymmetryGuide.new()
|
||||||
var y_symmetry_axis := SymmetryGuide.new()
|
var y_symmetry_axis := SymmetryGuide.new()
|
||||||
var diagonal_xy_symmetry_axis := SymmetryGuide.new()
|
var diagonal_xy_symmetry_axis := SymmetryGuide.new()
|
||||||
|
@ -113,6 +115,8 @@ func _init(_frames: Array[Frame] = [], _name := tr("untitled"), _size := Vector2
|
||||||
|
|
||||||
x_symmetry_point = size.x - 1
|
x_symmetry_point = size.x - 1
|
||||||
y_symmetry_point = size.y - 1
|
y_symmetry_point = size.y - 1
|
||||||
|
xy_symmetry_point = Vector2i(size.y, size.x) - Vector2i.ONE
|
||||||
|
x_minus_y_symmetry_point = Vector2(maxi(size.x - size.y, 0), maxi(size.y - size.x, 0))
|
||||||
x_symmetry_axis.type = Guide.Types.HORIZONTAL
|
x_symmetry_axis.type = Guide.Types.HORIZONTAL
|
||||||
x_symmetry_axis.project = self
|
x_symmetry_axis.project = self
|
||||||
x_symmetry_axis.add_point(Vector2(-19999, y_symmetry_point / 2 + 0.5))
|
x_symmetry_axis.add_point(Vector2(-19999, y_symmetry_point / 2 + 0.5))
|
||||||
|
@ -128,13 +132,13 @@ func _init(_frames: Array[Frame] = [], _name := tr("untitled"), _size := Vector2
|
||||||
diagonal_xy_symmetry_axis.type = Guide.Types.XY
|
diagonal_xy_symmetry_axis.type = Guide.Types.XY
|
||||||
diagonal_xy_symmetry_axis.project = self
|
diagonal_xy_symmetry_axis.project = self
|
||||||
diagonal_xy_symmetry_axis.add_point(Vector2(19999, -19999))
|
diagonal_xy_symmetry_axis.add_point(Vector2(19999, -19999))
|
||||||
diagonal_xy_symmetry_axis.add_point(Vector2i(-19999, 19999) + size)
|
diagonal_xy_symmetry_axis.add_point(Vector2(-19999, 19999) + xy_symmetry_point + Vector2.ONE)
|
||||||
Global.canvas.add_child(diagonal_xy_symmetry_axis)
|
Global.canvas.add_child(diagonal_xy_symmetry_axis)
|
||||||
|
|
||||||
diagonal_x_minus_y_symmetry_axis.type = Guide.Types.X_MINUS_Y
|
diagonal_x_minus_y_symmetry_axis.type = Guide.Types.X_MINUS_Y
|
||||||
diagonal_x_minus_y_symmetry_axis.project = self
|
diagonal_x_minus_y_symmetry_axis.project = self
|
||||||
diagonal_x_minus_y_symmetry_axis.add_point(Vector2(-19999, -19999))
|
diagonal_x_minus_y_symmetry_axis.add_point(Vector2(-19999, -19999))
|
||||||
diagonal_x_minus_y_symmetry_axis.add_point(Vector2(19999, 19999))
|
diagonal_x_minus_y_symmetry_axis.add_point(Vector2(19999, 19999) + x_minus_y_symmetry_point)
|
||||||
Global.canvas.add_child(diagonal_x_minus_y_symmetry_axis)
|
Global.canvas.add_child(diagonal_x_minus_y_symmetry_axis)
|
||||||
|
|
||||||
if OS.get_name() == "Web":
|
if OS.get_name() == "Web":
|
||||||
|
|
|
@ -31,12 +31,13 @@ func _input(_event: InputEvent) -> void:
|
||||||
if type == Types.HORIZONTAL:
|
if type == Types.HORIZONTAL:
|
||||||
point0.y -= width * INPUT_WIDTH
|
point0.y -= width * INPUT_WIDTH
|
||||||
point1.y += width * INPUT_WIDTH
|
point1.y += width * INPUT_WIDTH
|
||||||
else:
|
elif type == Types.VERTICAL:
|
||||||
point0.x -= width * INPUT_WIDTH
|
point0.x -= width * INPUT_WIDTH
|
||||||
point1.x += width * INPUT_WIDTH
|
point1.x += width * INPUT_WIDTH
|
||||||
var rect := Rect2()
|
var rect := Rect2()
|
||||||
rect.position = point0
|
rect.position = point0
|
||||||
rect.end = point1
|
rect.end = point1
|
||||||
|
rect = rect.abs()
|
||||||
if (
|
if (
|
||||||
Input.is_action_just_pressed(&"left_mouse")
|
Input.is_action_just_pressed(&"left_mouse")
|
||||||
and Global.can_draw
|
and Global.can_draw
|
||||||
|
@ -55,7 +56,7 @@ func _input(_event: InputEvent) -> void:
|
||||||
var yy := snappedf(mouse_pos.y, 0.5)
|
var yy := snappedf(mouse_pos.y, 0.5)
|
||||||
points[0].y = yy
|
points[0].y = yy
|
||||||
points[1].y = yy
|
points[1].y = yy
|
||||||
else:
|
elif type == Types.VERTICAL:
|
||||||
var xx := snappedf(mouse_pos.x, 0.5)
|
var xx := snappedf(mouse_pos.x, 0.5)
|
||||||
points[0].x = xx
|
points[0].x = xx
|
||||||
points[1].x = xx
|
points[1].x = xx
|
||||||
|
|
Loading…
Reference in a new issue