From a61ec597a170fe8922285d355a1f4248aab58a99 Mon Sep 17 00:00:00 2001 From: fox <12120644+foxydevloper@users.noreply.github.com> Date: Tue, 25 May 2021 17:12:21 -0400 Subject: [PATCH] Make easing properties drawn with anti aliasing (cherry picked from commit 36236843f6fb5e5d312b759c72c3e5e668eea312) --- editor/editor_properties.cpp | 17 ++++++----------- 1 file changed, 6 insertions(+), 11 deletions(-) diff --git a/editor/editor_properties.cpp b/editor/editor_properties.cpp index 6cbf4889f9b..f448354749a 100644 --- a/editor/editor_properties.cpp +++ b/editor/editor_properties.cpp @@ -988,9 +988,8 @@ void EditorPropertyEasing::_draw_easing() { Size2 s = easing_draw->get_size(); - const int points = 48; + const int point_count = 48; - float prev = 1.0; const float exp = get_edited_object()->get(get_edited_property()); const Ref f = get_font("font", "Label"); @@ -1002,24 +1001,20 @@ void EditorPropertyEasing::_draw_easing() { line_color = get_color("font_color", "Label") * Color(1, 1, 1, 0.9); } - Vector lines; - for (int i = 1; i <= points; i++) { - float ifl = i / float(points); - float iflp = (i - 1) / float(points); + Vector points; + for (int i = 0; i <= point_count; i++) { + float ifl = i / float(point_count); const float h = 1.0 - Math::ease(ifl, exp); if (flip) { ifl = 1.0 - ifl; - iflp = 1.0 - iflp; } - lines.push_back(Point2(ifl * s.width, h * s.height)); - lines.push_back(Point2(iflp * s.width, prev * s.height)); - prev = h; + points.push_back(Point2(ifl * s.width, h * s.height)); } - easing_draw->draw_multiline(lines, line_color, 1.0, true); + easing_draw->draw_polyline(points, line_color, 1.0, true); // Draw more decimals for small numbers since higher precision is usually required for fine adjustments. int decimals; if (Math::abs(exp) < 0.1 - CMP_EPSILON) {