summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2018-03-13 11:40:31 +0100
committerGitHub <noreply@github.com>2018-03-13 11:40:31 +0100
commita64f30536ef256cf031dca3c5a1a715424c7b94e (patch)
treeb7ad36163fef69435e77fed4976b374e207672d7
parent9cadef3ffbd6a952e150235c370825b6ffa6a817 (diff)
parentc223fac83be5b5be3143e17819ad0179389407f9 (diff)
Merge pull request #17390 from poke1024/fix-anim-text-overlap
Fixes overlapping text labels in animation editor timeline
-rw-r--r--editor/animation_editor.cpp13
1 files changed, 13 insertions, 0 deletions
diff --git a/editor/animation_editor.cpp b/editor/animation_editor.cpp
index 109081bc27..61a35f7a40 100644
--- a/editor/animation_editor.cpp
+++ b/editor/animation_editor.cpp
@@ -1266,8 +1266,21 @@ void AnimationKeyEditor::_track_editor_draw() {
int decimals = 2;
bool step_found = false;
+ const int period_width = font->get_char_size('.').width;
+ int max_digit_width = font->get_char_size('0').width;
+ for (int i = 1; i <= 9; i++) {
+ const int digit_width = font->get_char_size('0' + i).width;
+ max_digit_width = MAX(digit_width, max_digit_width);
+ }
+ const int max_sc = int(Math::ceil(zoomw / scale));
+ const int max_sc_width = String::num(max_sc).length() * max_digit_width;
+
while (!step_found) {
+ min = max_sc_width;
+ if (decimals > 0)
+ min += period_width + max_digit_width * decimals;
+
static const int _multp[3] = { 1, 2, 5 };
for (int i = 0; i < 3; i++) {