123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104 |
- /*
- ==============================================================================
- This file is part of the JUCE library.
- Copyright (c) 2015 - ROLI Ltd.
- Permission is granted to use this software under the terms of either:
- a) the GPL v2 (or any later version)
- b) the Affero GPL v3
- Details of these licenses can be found at: www.gnu.org/licenses
- JUCE is distributed in the hope that it will be useful, but WITHOUT ANY
- WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
- A PARTICULAR PURPOSE. See the GNU General Public License for more details.
- ------------------------------------------------------------------------------
- To release a closed-source product which uses JUCE, commercial licenses are
- available: visit www.juce.com for more information.
- ==============================================================================
- */
- #ifndef JUCE_DRAWABLERECTANGLE_H_INCLUDED
- #define JUCE_DRAWABLERECTANGLE_H_INCLUDED
- //==============================================================================
- /**
- A Drawable object which draws a rectangle.
- For details on how to change the fill and stroke, see the DrawableShape class.
- @see Drawable, DrawableShape
- */
- class JUCE_API DrawableRectangle : public DrawableShape
- {
- public:
- //==============================================================================
- DrawableRectangle();
- DrawableRectangle (const DrawableRectangle&);
- /** Destructor. */
- ~DrawableRectangle();
- //==============================================================================
- /** Sets the rectangle's bounds. */
- void setRectangle (const RelativeParallelogram& newBounds);
- /** Returns the rectangle's bounds. */
- const RelativeParallelogram& getRectangle() const noexcept { return bounds; }
- /** Returns the corner size to be used. */
- const RelativePoint& getCornerSize() const noexcept { return cornerSize; }
- /** Sets a new corner size for the rectangle */
- void setCornerSize (const RelativePoint& newSize);
- //==============================================================================
- /** @internal */
- Drawable* createCopy() const;
- /** @internal */
- void refreshFromValueTree (const ValueTree& tree, ComponentBuilder& builder);
- /** @internal */
- ValueTree createValueTree (ComponentBuilder::ImageProvider* imageProvider) const;
- /** @internal */
- static const Identifier valueTreeType;
- //==============================================================================
- /** Internally-used class for wrapping a DrawableRectangle's state into a ValueTree. */
- class ValueTreeWrapper : public DrawableShape::FillAndStrokeState
- {
- public:
- ValueTreeWrapper (const ValueTree& state);
- RelativeParallelogram getRectangle() const;
- void setRectangle (const RelativeParallelogram& newBounds, UndoManager*);
- void setCornerSize (const RelativePoint& cornerSize, UndoManager*);
- RelativePoint getCornerSize() const;
- Value getCornerSizeValue (UndoManager*);
- static const Identifier topLeft, topRight, bottomLeft, cornerSize;
- };
- private:
- friend class Drawable::Positioner<DrawableRectangle>;
- RelativeParallelogram bounds;
- RelativePoint cornerSize;
- void rebuildPath();
- bool registerCoordinates (RelativeCoordinatePositionerBase&);
- void recalculateCoordinates (Expression::Scope*);
- DrawableRectangle& operator= (const DrawableRectangle&);
- JUCE_LEAK_DETECTOR (DrawableRectangle)
- };
- #endif // JUCE_DRAWABLERECTANGLE_H_INCLUDED
|