Skip to content

Commit

Permalink
Merge pull request #42375 from Pennycook/stable-ysort
Browse files Browse the repository at this point in the history
Make YSort stable
  • Loading branch information
akien-mga authored Sep 27, 2020
2 parents c12fc4f + 8d3afa9 commit 8016521
Show file tree
Hide file tree
Showing 2 changed files with 4 additions and 1 deletion.
1 change: 1 addition & 0 deletions servers/rendering/rendering_server_canvas.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -81,6 +81,7 @@ void _collect_ysort_children(RenderingServerCanvas::Item *p_canvas_item, Transfo
child_items[i]->ysort_xform = p_transform;
child_items[i]->ysort_pos = p_transform.xform(child_items[i]->xform.elements[2]);
child_items[i]->material_owner = child_items[i]->use_parent_material ? p_material_owner : nullptr;
child_items[i]->ysort_index = r_index;
}

r_index++;
Expand Down
4 changes: 3 additions & 1 deletion servers/rendering/rendering_server_canvas.h
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,7 @@ class RenderingServerCanvas {
Color ysort_modulate;
Transform2D ysort_xform;
Vector2 ysort_pos;
int ysort_index;
RS::CanvasItemTextureFilter texture_filter;
RS::CanvasItemTextureRepeat texture_repeat;

Expand All @@ -69,6 +70,7 @@ class RenderingServerCanvas {
ysort_children_count = -1;
ysort_xform = Transform2D();
ysort_pos = Vector2();
ysort_index = 0;
texture_filter = RS::CANVAS_ITEM_TEXTURE_FILTER_DEFAULT;
texture_repeat = RS::CANVAS_ITEM_TEXTURE_REPEAT_DEFAULT;
}
Expand All @@ -83,7 +85,7 @@ class RenderingServerCanvas {
struct ItemPtrSort {
_FORCE_INLINE_ bool operator()(const Item *p_left, const Item *p_right) const {
if (Math::is_equal_approx(p_left->ysort_pos.y, p_right->ysort_pos.y)) {
return p_left->ysort_pos.x < p_right->ysort_pos.x;
return p_left->ysort_index < p_right->ysort_index;
}

return p_left->ysort_pos.y < p_right->ysort_pos.y;
Expand Down

0 comments on commit 8016521

Please sign in to comment.