Audio plugin host https://kx.studio/carla
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.

104 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. namespace juce
  20. {
  21. //==============================================================================
  22. /**
  23. A Drawable object which draws a rectangle.
  24. For details on how to change the fill and stroke, see the DrawableShape class.
  25. @see Drawable, DrawableShape
  26. */
  27. class JUCE_API DrawableRectangle : public DrawableShape
  28. {
  29. public:
  30. //==============================================================================
  31. DrawableRectangle();
  32. DrawableRectangle (const DrawableRectangle&);
  33. /** Destructor. */
  34. ~DrawableRectangle();
  35. //==============================================================================
  36. /** Sets the rectangle's bounds. */
  37. void setRectangle (const RelativeParallelogram& newBounds);
  38. /** Returns the rectangle's bounds. */
  39. const RelativeParallelogram& getRectangle() const noexcept { return bounds; }
  40. /** Returns the corner size to be used. */
  41. const RelativePoint& getCornerSize() const noexcept { return cornerSize; }
  42. /** Sets a new corner size for the rectangle */
  43. void setCornerSize (const RelativePoint& newSize);
  44. //==============================================================================
  45. /** @internal */
  46. Drawable* createCopy() const;
  47. /** @internal */
  48. void refreshFromValueTree (const ValueTree& tree, ComponentBuilder& builder);
  49. /** @internal */
  50. ValueTree createValueTree (ComponentBuilder::ImageProvider* imageProvider) const;
  51. /** @internal */
  52. static const Identifier valueTreeType;
  53. //==============================================================================
  54. /** Internally-used class for wrapping a DrawableRectangle's state into a ValueTree. */
  55. class ValueTreeWrapper : public DrawableShape::FillAndStrokeState
  56. {
  57. public:
  58. ValueTreeWrapper (const ValueTree& state);
  59. RelativeParallelogram getRectangle() const;
  60. void setRectangle (const RelativeParallelogram& newBounds, UndoManager*);
  61. void setCornerSize (const RelativePoint& cornerSize, UndoManager*);
  62. RelativePoint getCornerSize() const;
  63. Value getCornerSizeValue (UndoManager*);
  64. static const Identifier topLeft, topRight, bottomLeft, cornerSize;
  65. };
  66. private:
  67. friend class Drawable::Positioner<DrawableRectangle>;
  68. RelativeParallelogram bounds;
  69. RelativePoint cornerSize;
  70. void rebuildPath();
  71. bool registerCoordinates (RelativeCoordinatePositionerBase&);
  72. void recalculateCoordinates (Expression::Scope*);
  73. DrawableRectangle& operator= (const DrawableRectangle&);
  74. JUCE_LEAK_DETECTOR (DrawableRectangle)
  75. };
  76. } // namespace juce