/* ============================================================================== This file is part of the JUCE 6 technical preview. Copyright (c) 2020 - Raw Material Software Limited You may use this code under the terms of the GPL v3 (see www.gnu.org/licenses). For this technical preview, this file is not subject to commercial licensing. JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE DISCLAIMED. ============================================================================== */ namespace juce { //============================================================================== /** A Drawable object which draws a rectangle. For details on how to change the fill and stroke, see the DrawableShape class. @see Drawable, DrawableShape @tags{GUI} */ class JUCE_API DrawableRectangle : public DrawableShape { public: //============================================================================== DrawableRectangle(); DrawableRectangle (const DrawableRectangle&); /** Destructor. */ ~DrawableRectangle() override; //============================================================================== /** Sets the rectangle's bounds. */ void setRectangle (Parallelogram newBounds); /** Returns the rectangle's bounds. */ Parallelogram getRectangle() const noexcept { return bounds; } /** Returns the corner size to be used. */ Point getCornerSize() const noexcept { return cornerSize; } /** Sets a new corner size for the rectangle */ void setCornerSize (Point newSize); //============================================================================== /** @internal */ std::unique_ptr createCopy() const override; private: Parallelogram bounds; Point cornerSize; void rebuildPath(); DrawableRectangle& operator= (const DrawableRectangle&); JUCE_LEAK_DETECTOR (DrawableRectangle) }; } // namespace juce