diff options
author | RĂ©mi Verschelde <rverschelde@gmail.com> | 2020-09-27 23:21:21 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-09-27 23:21:21 +0200 |
commit | 80165210c31b79e12e2a59e481232ae7eeccbfac (patch) | |
tree | d770c7e49c8be2f2c70d34dedfffede1ab5755d8 /servers/rendering/rendering_server_canvas.h | |
parent | c12fc4fa048985d159b115bbd3cc400920bdf19e (diff) | |
parent | 8d3afa985b479417b46811050e9b8bd9f7861f06 (diff) |
Merge pull request #42375 from Pennycook/stable-ysort
Make YSort stable
Diffstat (limited to 'servers/rendering/rendering_server_canvas.h')
-rw-r--r-- | servers/rendering/rendering_server_canvas.h | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/servers/rendering/rendering_server_canvas.h b/servers/rendering/rendering_server_canvas.h index 59c0d1fa52..cebe32fba0 100644 --- a/servers/rendering/rendering_server_canvas.h +++ b/servers/rendering/rendering_server_canvas.h @@ -51,6 +51,7 @@ public: Color ysort_modulate; Transform2D ysort_xform; Vector2 ysort_pos; + int ysort_index; RS::CanvasItemTextureFilter texture_filter; RS::CanvasItemTextureRepeat texture_repeat; @@ -69,6 +70,7 @@ public: 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; } @@ -83,7 +85,7 @@ public: 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; |