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.

100 lines
3.7KB

  1. /*
  2. ==============================================================================
  3. This file is part of the JUCE library.
  4. Copyright (c) 2017 - ROLI Ltd.
  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 5 End-User License
  8. Agreement and JUCE 5 Privacy Policy (both updated and effective as of the
  9. 27th April 2017).
  10. End User License Agreement: www.juce.com/juce-5-licence
  11. Privacy Policy: www.juce.com/juce-5-privacy-policy
  12. Or: You may also use this code under the terms of the GPL v3 (see
  13. www.gnu.org/licenses).
  14. JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
  15. EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
  16. DISCLAIMED.
  17. ==============================================================================
  18. */
  19. #include "../JuceLibraryCode/JuceHeader.h"
  20. #include "SpectrogramComponent.h"
  21. //==============================================================================
  22. class SimpleFFTExampleApplication : public JUCEApplication
  23. {
  24. public:
  25. //==============================================================================
  26. SimpleFFTExampleApplication() {}
  27. const String getApplicationName() override { return ProjectInfo::projectName; }
  28. const String getApplicationVersion() override { return ProjectInfo::versionString; }
  29. bool moreThanOneInstanceAllowed() override { return true; }
  30. //==============================================================================
  31. void initialise (const String& /*commandLine*/) override
  32. {
  33. mainWindow = new MainWindow();
  34. }
  35. void shutdown() override
  36. {
  37. mainWindow = nullptr; // (deletes our window)
  38. }
  39. //==============================================================================
  40. void systemRequestedQuit() override
  41. {
  42. // This is called when the app is being asked to quit: you can ignore this
  43. // request and let the app carry on running, or call quit() to allow the app to close.
  44. quit();
  45. }
  46. //==============================================================================
  47. /*
  48. This class implements the desktop window that contains an instance of
  49. our MainContentComponent class.
  50. */
  51. class MainWindow : public DocumentWindow
  52. {
  53. public:
  54. MainWindow() : DocumentWindow (ProjectInfo::projectName,
  55. LookAndFeel::getDefaultLookAndFeel()
  56. .findColour (ResizableWindow::backgroundColourId),
  57. DocumentWindow::allButtons)
  58. {
  59. setUsingNativeTitleBar (true);
  60. setContentOwned (new SpectrogramComponent(), true);
  61. setResizable (true, true);
  62. centreWithSize (getWidth(), getHeight());
  63. setVisible (true);
  64. }
  65. void closeButtonPressed() override
  66. {
  67. // This is called when the user tries to close this window. Here, we'll just
  68. // ask the app to quit when this happens, but you can change this to do
  69. // whatever you need.
  70. JUCEApplication::getInstance()->systemRequestedQuit();
  71. }
  72. private:
  73. JUCE_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR (MainWindow)
  74. };
  75. private:
  76. ScopedPointer<MainWindow> mainWindow;
  77. };
  78. //==============================================================================
  79. // This macro generates the main() routine that launches the app.
  80. START_JUCE_APPLICATION (SimpleFFTExampleApplication)