JUCE  v5.1.1-3-g1a0b28c73
JUCE API
RelativeCoordinatePositionerBase Class Referenceabstract

Base class for Component::Positioners that are based upon relative coordinates. More...

#include <juce_RelativeCoordinatePositioner.h>

Inheritance diagram for RelativeCoordinatePositionerBase:
Collaboration diagram for RelativeCoordinatePositionerBase:

Classes

class  ComponentScope
 Used for resolving a RelativeCoordinate expression in the context of a component. More...
 

Public Member Functions

 RelativeCoordinatePositionerBase (Component &)
 
 ~RelativeCoordinatePositionerBase ()
 
bool addCoordinate (const RelativeCoordinate &)
 
bool addPoint (const RelativePoint &)
 
void apply ()
 
virtual void applyNewBounds (const Rectangle< int > &newBounds)=0
 Attempts to set the component's position to the given rectangle. More...
 
void componentBeingDeleted (Component &)
 Called when the component is in the process of being deleted. More...
 
virtual void componentBroughtToFront (Component &component)
 Called when the component is brought to the top of the z-order. More...
 
void componentChildrenChanged (Component &)
 Called when the component has children added or removed, or their z-order changes. More...
 
void componentMovedOrResized (Component &, bool, bool)
 Called when the component's position or size changes. More...
 
virtual void componentNameChanged (Component &component)
 Called when the component's name is changed. More...
 
void componentParentHierarchyChanged (Component &)
 Called to indicate that the component's parents have changed. More...
 
virtual void componentVisibilityChanged (Component &component)
 Called when the component is made visible or invisible. More...
 
ComponentgetComponent () const noexcept
 Returns the component that this positioner controls. More...
 
void markerListBeingDeleted (MarkerList *)
 Called when the given marker list is being deleted. More...
 
void markersChanged (MarkerList *)
 Called when something in the given marker list changes. More...
 

Protected Member Functions

virtual void applyToComponentBounds ()=0
 
virtual bool registerCoordinates ()=0
 

Private Member Functions

void registerComponentListener (Component &)
 
void registerMarkerListListener (MarkerList *)
 
void unregisterListeners ()
 

Private Attributes

bool registeredOk
 
Array< Component * > sourceComponents
 
Array< MarkerList * > sourceMarkerLists
 

Friends

class DependencyFinderScope
 

Detailed Description

Base class for Component::Positioners that are based upon relative coordinates.

Constructor & Destructor Documentation

◆ RelativeCoordinatePositionerBase()

RelativeCoordinatePositionerBase::RelativeCoordinatePositionerBase ( Component )

◆ ~RelativeCoordinatePositionerBase()

RelativeCoordinatePositionerBase::~RelativeCoordinatePositionerBase ( )

Member Function Documentation

◆ addCoordinate()

bool RelativeCoordinatePositionerBase::addCoordinate ( const RelativeCoordinate )

◆ addPoint()

bool RelativeCoordinatePositionerBase::addPoint ( const RelativePoint )

◆ apply()

void RelativeCoordinatePositionerBase::apply ( )

◆ applyNewBounds()

virtual void Component::Positioner::applyNewBounds ( const Rectangle< int > &  newBounds)
pure virtualinherited

Attempts to set the component's position to the given rectangle.

Unlike simply calling Component::setBounds(), this may involve the positioner being smart enough to adjust itself to fit the new bounds, e.g. a RelativeRectangle's positioner may try to reverse the expressions used to make them fit these new coordinates.

◆ applyToComponentBounds()

virtual void RelativeCoordinatePositionerBase::applyToComponentBounds ( )
protectedpure virtual

◆ componentBeingDeleted()

void RelativeCoordinatePositionerBase::componentBeingDeleted ( Component component)
virtual

Called when the component is in the process of being deleted.

This callback is made from inside the destructor, so be very, very cautious about what you do in here.

In particular, bear in mind that it's the Component base class's destructor that calls this - so if the object that's being deleted is a subclass of Component, then the subclass layers of the object will already have been destructed when it gets to this point!

Reimplemented from ComponentListener.

◆ componentBroughtToFront()

virtual void ComponentListener::componentBroughtToFront ( Component component)
virtualinherited

Called when the component is brought to the top of the z-order.

Parameters
componentthe component that was moved
See also
Component::toFront, Component::broughtToFront

Reimplemented in DropShadower.

◆ componentChildrenChanged()

void RelativeCoordinatePositionerBase::componentChildrenChanged ( Component component)
virtual

Called when the component has children added or removed, or their z-order changes.

Parameters
componentthe component whose children have changed
See also
Component::childrenChanged, Component::addChildComponent, Component::removeChildComponent

Reimplemented from ComponentListener.

◆ componentMovedOrResized()

void RelativeCoordinatePositionerBase::componentMovedOrResized ( Component component,
bool  wasMoved,
bool  wasResized 
)
virtual

Called when the component's position or size changes.

Parameters
componentthe component that was moved or resized
wasMovedtrue if the component's top-left corner has just moved
wasResizedtrue if the component's width or height has just changed
See also
Component::setBounds, Component::resized, Component::moved

Reimplemented from ComponentListener.

◆ componentNameChanged()

virtual void ComponentListener::componentNameChanged ( Component component)
virtualinherited

Called when the component's name is changed.

See also
Component::setName, Component::getName

Reimplemented in MultiDocumentPanel.

Referenced by MultiDocumentPanel::getCurrentTabbedComponent().

◆ componentParentHierarchyChanged()

void RelativeCoordinatePositionerBase::componentParentHierarchyChanged ( Component component)
virtual

Called to indicate that the component's parents have changed.

When a component is added or removed from its parent, all of its children will produce this notification (recursively - so all children of its children will also be called as well).

Parameters
componentthe component that this listener is registered with
See also
Component::parentHierarchyChanged

Reimplemented from ComponentListener.

◆ componentVisibilityChanged()

virtual void ComponentListener::componentVisibilityChanged ( Component component)
virtualinherited

Called when the component is made visible or invisible.

Parameters
componentthe component that changed
See also
Component::setVisible

Reimplemented in Label, ComponentMovementWatcher, and DropShadower.

Referenced by ComponentMovementWatcher::getComponent().

◆ getComponent()

Component& Component::Positioner::getComponent ( ) const
inlinenoexceptinherited

Returns the component that this positioner controls.

◆ markerListBeingDeleted()

void RelativeCoordinatePositionerBase::markerListBeingDeleted ( MarkerList markerList)
virtual

Called when the given marker list is being deleted.

Reimplemented from MarkerList::Listener.

◆ markersChanged()

void RelativeCoordinatePositionerBase::markersChanged ( MarkerList markerList)
virtual

Called when something in the given marker list changes.

Implements MarkerList::Listener.

◆ registerComponentListener()

void RelativeCoordinatePositionerBase::registerComponentListener ( Component )
private

◆ registerCoordinates()

virtual bool RelativeCoordinatePositionerBase::registerCoordinates ( )
protectedpure virtual

◆ registerMarkerListListener()

void RelativeCoordinatePositionerBase::registerMarkerListListener ( MarkerList )
private

◆ unregisterListeners()

void RelativeCoordinatePositionerBase::unregisterListeners ( )
private

Friends And Related Function Documentation

◆ DependencyFinderScope

friend class DependencyFinderScope
friend

Member Data Documentation

◆ registeredOk

bool RelativeCoordinatePositionerBase::registeredOk
private

◆ sourceComponents

Array<Component*> RelativeCoordinatePositionerBase::sourceComponents
private

◆ sourceMarkerLists

Array<MarkerList*> RelativeCoordinatePositionerBase::sourceMarkerLists
private

The documentation for this class was generated from the following file: