The JUCE cross-platform C++ framework, with DISTRHO/KXStudio specific changes
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

81 lines
2.0KB

  1. /*
  2. ==============================================================================
  3. This file is part of the JUCE library.
  4. Copyright (c) 2022 - Raw Material Software Limited
  5. JUCE is an open source library subject to commercial or open-source
  6. licensing.
  7. By using JUCE, you agree to the terms of both the JUCE 7 End-User License
  8. Agreement and JUCE Privacy Policy.
  9. End User License Agreement: www.juce.com/juce-7-licence
  10. Privacy Policy: www.juce.com/juce-privacy-policy
  11. Or: You may also use this code under the terms of the GPL v3 (see
  12. www.gnu.org/licenses).
  13. JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
  14. EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
  15. DISCLAIMED.
  16. ==============================================================================
  17. */
  18. namespace juce
  19. {
  20. AnimatedAppComponent::AnimatedAppComponent()
  21. {
  22. setOpaque (true);
  23. }
  24. void AnimatedAppComponent::setFramesPerSecond (int framesPerSecondIn)
  25. {
  26. jassert (0 < framesPerSecond && framesPerSecond < 1000);
  27. framesPerSecond = framesPerSecondIn;
  28. updateSync();
  29. }
  30. void AnimatedAppComponent::updateSync()
  31. {
  32. if (useVBlank)
  33. {
  34. stopTimer();
  35. if (vBlankAttachment.isEmpty())
  36. vBlankAttachment = { this, [this] { timerCallback(); } };
  37. }
  38. else
  39. {
  40. vBlankAttachment = {};
  41. const auto interval = 1000 / framesPerSecond;
  42. if (getTimerInterval() != interval)
  43. startTimer (interval);
  44. }
  45. }
  46. void AnimatedAppComponent::setSynchroniseToVBlank (bool syncToVBlank)
  47. {
  48. useVBlank = syncToVBlank;
  49. updateSync();
  50. }
  51. int AnimatedAppComponent::getMillisecondsSinceLastUpdate() const noexcept
  52. {
  53. return (int) (Time::getCurrentTime() - lastUpdateTime).inMilliseconds();
  54. }
  55. void AnimatedAppComponent::timerCallback()
  56. {
  57. ++totalUpdates;
  58. update();
  59. repaint();
  60. lastUpdateTime = Time::getCurrentTime();
  61. }
  62. } // namespace juce