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.

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