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.

108 lines
3.6KB

  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. #pragma once
  20. #include "../jucer_JucerDocument.h"
  21. #include "jucer_ComponentLayoutEditor.h"
  22. #include "jucer_PaintRoutineEditor.h"
  23. #include "jucer_ComponentLayoutPanel.h"
  24. //==============================================================================
  25. /**
  26. */
  27. class JucerDocumentEditor : public Component,
  28. public ApplicationCommandTarget,
  29. public ChangeListener
  30. {
  31. public:
  32. //==============================================================================
  33. JucerDocumentEditor (JucerDocument* const document);
  34. ~JucerDocumentEditor();
  35. JucerDocument* getDocument() const noexcept { return document; }
  36. void refreshPropertiesPanel() const;
  37. void updateTabs();
  38. void showLayout();
  39. void showGraphics (PaintRoutine* routine);
  40. void setViewportToLastPos (Viewport* vp, EditingPanelBase& editor);
  41. void storeLastViewportPos (Viewport* vp, EditingPanelBase& editor);
  42. Image createComponentLayerSnapshot() const;
  43. //==============================================================================
  44. void paint (Graphics& g) override;
  45. void resized() override;
  46. void changeListenerCallback (ChangeBroadcaster*) override;
  47. bool keyPressed (const KeyPress&) override;
  48. //==============================================================================
  49. ApplicationCommandTarget* getNextCommandTarget() override;
  50. void getAllCommands (Array<CommandID>&) override;
  51. void getCommandInfo (CommandID, ApplicationCommandInfo&) override;
  52. bool perform (const InvocationInfo&) override;
  53. static JucerDocumentEditor* getActiveDocumentHolder();
  54. private:
  55. ScopedPointer<JucerDocument> document;
  56. ComponentLayoutPanel* compLayoutPanel = nullptr;
  57. struct JucerDocumentTabs : public TabbedComponent
  58. {
  59. JucerDocumentTabs (JucerDocument* d) : TabbedComponent (TabbedButtonBar::TabsAtTop), document (d) {}
  60. void currentTabChanged (int, const String&) override { document->refreshCustomCodeFromDocument(); }
  61. JucerDocument* document;
  62. };
  63. JucerDocumentTabs tabbedComponent;
  64. int lastViewportX = 0, lastViewportY = 0;
  65. double currentZoomLevel = 1.0;
  66. void saveLastSelectedTab() const;
  67. void restoreLastSelectedTab();
  68. bool isSomethingSelected() const;
  69. bool areMultipleThingsSelected() const;
  70. // only non-zero if a layout tab is selected
  71. ComponentLayout* getCurrentLayout() const;
  72. // only non-zero if a graphics tab is selected
  73. PaintRoutine* getCurrentPaintRoutine() const;
  74. void setZoom (double scale);
  75. double getZoom() const;
  76. void addElement (int index);
  77. void addComponent (int index);
  78. };