| 
							- /*
 -   ==============================================================================
 - 
 -    This file is part of the JUCE 6 technical preview.
 -    Copyright (c) 2017 - ROLI Ltd.
 - 
 -    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 component that draws an outline around itself and has an optional title at
 -     the top, for drawing an outline around a group of controls.
 - 
 - 
 -     @tags{GUI}
 - */
 - class JUCE_API  GroupComponent    : public Component
 - {
 - public:
 -     //==============================================================================
 -     /** Creates a GroupComponent.
 - 
 -         @param componentName    the name to give the component
 -         @param labelText        the text to show at the top of the outline
 -     */
 -     GroupComponent (const String& componentName = {},
 -                     const String& labelText = {});
 - 
 -     /** Destructor. */
 -     ~GroupComponent() override;
 - 
 -     //==============================================================================
 -     /** Changes the text that's shown at the top of the component. */
 -     void setText (const String& newText);
 - 
 -     /** Returns the currently displayed text label. */
 -     String getText() const;
 - 
 -     /** Sets the positioning of the text label.
 -         (The default is Justification::left)
 -         @see getTextLabelPosition
 -     */
 -     void setTextLabelPosition (Justification justification);
 - 
 -     /** Returns the current text label position.
 -         @see setTextLabelPosition
 -     */
 -     Justification getTextLabelPosition() const noexcept           { return justification; }
 - 
 -     //==============================================================================
 -     /** A set of colour IDs to use to change the colour of various aspects of the component.
 - 
 -         These constants can be used either via the Component::setColour(), or LookAndFeel::setColour()
 -         methods.
 - 
 -         @see Component::setColour, Component::findColour, LookAndFeel::setColour, LookAndFeel::findColour
 -     */
 -     enum ColourIds
 -     {
 -         outlineColourId     = 0x1005400,    /**< The colour to use for drawing the line around the edge. */
 -         textColourId        = 0x1005410     /**< The colour to use to draw the text label. */
 -     };
 - 
 -     //==============================================================================
 -     /** This abstract base class is implemented by LookAndFeel classes. */
 -     struct JUCE_API  LookAndFeelMethods
 -     {
 -         virtual ~LookAndFeelMethods() = default;
 - 
 -         virtual void drawGroupComponentOutline (Graphics&, int w, int h, const String& text,
 -                                                 const Justification&, GroupComponent&) = 0;
 -     };
 - 
 -     //==============================================================================
 -     /** @internal */
 -     void paint (Graphics&) override;
 -     /** @internal */
 -     void enablementChanged() override;
 -     /** @internal */
 -     void colourChanged() override;
 - 
 - private:
 -     String text;
 -     Justification justification;
 - 
 -     JUCE_DECLARE_NON_COPYABLE (GroupComponent)
 - };
 - 
 - } // namespace juce
 
 
  |