LuciadCPillar 2024.0.04
luciad::PointEditHandle Class Referencefinal

This handle represents a Point on the Map and can be visualized using an icon. More...

#include <luciad/edit/handles/PointEditHandle.h>

Inheritance diagram for luciad::PointEditHandle:
luciad::IEditHandle

Classes

class  IVisualAidProvider
 This interface allows to calculate a visual aid line based on the location of the handle. More...
 

Public Member Functions

 PointEditHandle (const PointEditHandle &other)=delete
 
 PointEditHandle (std::shared_ptr< Observable< std::shared_ptr< Point > > > locationProvider)
 Creates a new PointEditHandle without associated actions. More...
 
 PointEditHandle (std::shared_ptr< Point > initialLocation)
 Creates a new PointEditHandle without associated actions. More...
 
 ~PointEditHandle () override
 
void addEditStateObserver (std::shared_ptr< IInvalidationCallback > observer) override
 Adds an observer that is called when the edit state of this handle has changed. More...
 
EditActionBinderaddOnClickAction (std::shared_ptr< IPointEditAction > action, size_t clickCount)
 Adds an action that will be triggered when the handle is clicked or tapped (touch). More...
 
EditActionBinderaddOnDragAction (std::shared_ptr< IPointEditAction > action)
 Adds an action that will be triggered when the handle is dragged. More...
 
EditActionBinderaddOnMouseMoveAction (std::shared_ptr< IPointEditAction > action)
 Adds an action that will be executed on every mouse move. More...
 
EditActionBinderaddOnTouchLongPressAction (std::shared_ptr< IPointEditAction > action)
 Adds an action that will be triggered when a long press is performed on a handle. More...
 
std::shared_ptr< luciad::IIcongetActiveIcon () const
 Returns the icon to paint when the handle is in an active state. More...
 
const std::optional< ComplexStrokeLineStyle > & getActiveVisualAidComplexStrokeLineStyle () const
 Returns the visual aid line style to use when this handle is in an active state. More...
 
const std::optional< LineStyle > & getActiveVisualAidLineStyle () const
 Returns the visual aid line style to use when this handle is in an active state. More...
 
EditHandleState getEditState () const override
 Returns the current state of this handle. More...
 
std::shared_ptr< luciad::IIcongetHighlightedIcon () const
 Returns the icon to paint when the handle is in a highlighted state. More...
 
const std::optional< ComplexStrokeLineStyle > & getHighlightedVisualAidComplexStrokeLineStyle () const
 Returns the visual aid complex stroke line style to use when this handle is in a highlighted state. More...
 
const std::optional< LineStyle > & getHighlightedVisualAidLineStyle () const
 Returns the visual aid line style to use when this handle is in a highlighted state. More...
 
std::shared_ptr< PointgetLocation () const
 Returns the current location of this handle. More...
 
std::shared_ptr< Observable< std::shared_ptr< Point > > > getLocationProvider () const
 Returns the location provider of this handle. More...
 
std::shared_ptr< Observable< std::shared_ptr< Point > > > getLocationProviderWhenActive () const
 Returns the location provider to use when the handle is active. More...
 
std::optional< MouseCursorgetMouseCursor () const override
 Returns the current mouse cursor that should be displayed for this handle. More...
 
EditMoveConstraint getMoveConstraint () const
 Returns the move constraint of this point handle. More...
 
std::shared_ptr< luciad::IIcongetRegularIcon () const
 Returns the icon to paint when the handle is in a regular state. More...
 
const std::optional< ComplexStrokeLineStyle > & getRegularVisualAidComplexStrokeLineStyle () const
 Returns the visual aid complex stroke line style to use when this handle is in an inactive state. More...
 
const std::optional< LineStyle > & getRegularVisualAidLineStyle () const
 Returns the visual aid line style to use when this handle is in an inactive state. More...
 
std::shared_ptr< IVisualAidProvidergetVisualAidLineProvider () const
 Returns the visual aid line provider that allows to paint a visual aid line together with this handle. More...
 
ZOrder getZOrder () const
 Returns the Z-order that is used for this handle's paint calls to the FeatureCanvas. More...
 
bool isUseFeatureAsHandle () const
 Returns whether this handle should paint any icons itself. More...
 
EventResult onEvent (const std::shared_ptr< IInputEvent > &inputEvent, const std::shared_ptr< FeatureEditContext > &context) override
 Handles the given event, and returns if the event was consumed or not. More...
 
PointEditHandleoperator= (const PointEditHandle &other)=delete
 
void paint (FeatureCanvas &canvas, const std::shared_ptr< FeatureEditContext > &context) const override
 Paints this handle on the given canvas. More...
 
void removeEditStateObserver (const std::shared_ptr< IInvalidationCallback > &observer) override
 Removes the given observer. More...
 
void setActiveIcon (std::shared_ptr< IIcon > icon)
 Sets the icon to paint when the handle is in an active state. More...
 
void setActiveVisualAidComplexStrokeLineStyle (std::optional< ComplexStrokeLineStyle > lineStyle)
 Sets the visual aid line style to use when this handle is in an active state. More...
 
void setActiveVisualAidLineStyle (std::optional< LineStyle > lineStyle)
 Sets the visual aid line style to use when this handle is in an active state. More...
 
void setHighlightedIcon (std::shared_ptr< IIcon > icon)
 Sets the icon to paint when the handle is in a highlighted state. More...
 
void setHighlightedVisualAidComplexStrokeLineStyle (std::optional< ComplexStrokeLineStyle > lineStyle)
 Sets the visual aid complex stroke line style to use when this handle is in a highlighted state. More...
 
void setHighlightedVisualAidLineStyle (std::optional< LineStyle > lineStyle)
 Sets the visual aid line style to use when this handle is in a highlighted state. More...
 
void setInvalidationCallback (std::shared_ptr< IInvalidationCallback > invalidationCallback) override
 Sets the callback for the handle to call when its visual representation or cursor has changed. More...
 
void setLocationProviderWhenActive (std::shared_ptr< Observable< std::shared_ptr< Point > > > locationProviderWhenActive)
 Sets the location provider to use when the handle is active. More...
 
void setMoveConstraint (EditMoveConstraint moveConstraint)
 Sets the move constraint of this point handle. More...
 
void setRegularIcon (std::shared_ptr< IIcon > icon)
 Sets the icon to paint when the handle is in a regular state. More...
 
void setRegularVisualAidComplexStrokeLineStyle (std::optional< ComplexStrokeLineStyle > lineStyle)
 Sets the visual aid complex stroke line style to use when this handle is in an inactive state. More...
 
void setRegularVisualAidLineStyle (std::optional< LineStyle > lineStyle)
 Sets the visual aid line style to use when this handle is in an inactive state. More...
 
void setUseFeatureAsHandle (bool useFeatureAsHandle)
 Sets whether this handle should paint any icons itself. More...
 
void setVisualAidLineProvider (std::shared_ptr< IVisualAidProvider > provider)
 Sets the visual aid line provider that allows to paint a visual aid line together with this handle. More...
 
void setZOrder (ZOrder zOrder)
 Sets the Z-order that is used for this handle's paint calls to the FeatureCanvas. More...
 
- Public Member Functions inherited from luciad::IEditHandle
 IEditHandle ()
 Creates a new edit handle instance. More...
 
virtual ~IEditHandle ()=default
 
virtual void addEditStateObserver (std::shared_ptr< IInvalidationCallback > observer)=0
 Adds an observer that is called when the edit state of this handle has changed. More...
 
virtual EditHandleState getEditState () const =0
 Returns the current state of this handle. More...
 
virtual std::optional< MouseCursorgetMouseCursor () const =0
 Returns the current mouse cursor that should be displayed for this handle. More...
 
virtual EventResult onEvent (const std::shared_ptr< IInputEvent > &inputEvent, const std::shared_ptr< FeatureEditContext > &context)=0
 Handles the given event, and returns if the event was consumed or not. More...
 
virtual void paint (FeatureCanvas &canvas, const std::shared_ptr< FeatureEditContext > &context) const =0
 Paints this handle on the given canvas. More...
 
virtual void removeEditStateObserver (const std::shared_ptr< IInvalidationCallback > &observer)=0
 Removes the given observer. More...
 
virtual void setInvalidationCallback (std::shared_ptr< IInvalidationCallback > invalidationCallback)=0
 Sets the callback for the handle to call when its visual representation or cursor has changed. More...
 

Detailed Description

This handle represents a Point on the Map and can be visualized using an icon.

It can be moved around, or react to mouse events.

The handle executes IPointEditAction, based on mouse input events. IEditHandles implementations configure concrete IPointEditAction implementations on this handle to make sure they result in geometry or feature changes. For example, when this handle is dragged around on the Map, an IEditHandles implementation for polylines can make sure that the second point of the polyline is moved.

This class supports the following gestures:

This handle is painted using an icon at its current location.

Since
2020.1

Constructor & Destructor Documentation

◆ PointEditHandle() [1/3]

luciad::PointEditHandle::PointEditHandle ( std::shared_ptr< Point initialLocation)
explicit

Creates a new PointEditHandle without associated actions.

Parameters
initialLocationthe initial location of the handle, cannot be nullptr

◆ PointEditHandle() [2/3]

luciad::PointEditHandle::PointEditHandle ( std::shared_ptr< Observable< std::shared_ptr< Point > > >  locationProvider)
explicit

Creates a new PointEditHandle without associated actions.

Parameters
locationProviderthe location provider of the handle. The handle assumes the location of this point upon construction, while also observing the point to adjust its own location whenever the observable point changes; cannot be nullptr.

◆ PointEditHandle() [3/3]

luciad::PointEditHandle::PointEditHandle ( const PointEditHandle other)
delete

◆ ~PointEditHandle()

luciad::PointEditHandle::~PointEditHandle ( )
override

Member Function Documentation

◆ addEditStateObserver()

void luciad::PointEditHandle::addEditStateObserver ( std::shared_ptr< IInvalidationCallback observer)
overridevirtual

Adds an observer that is called when the edit state of this handle has changed.

Adding the same observer twice is forbidden, and will cause an exception to be thrown.

Parameters
observeran observer
Exceptions
InvalidArgumentExceptionwhen the observer was already added.
Since
2023.1

Implements luciad::IEditHandle.

◆ addOnClickAction()

EditActionBinder & luciad::PointEditHandle::addOnClickAction ( std::shared_ptr< IPointEditAction action,
size_t  clickCount 
)

Adds an action that will be triggered when the handle is clicked or tapped (touch).

Parameters
actionthe action to be performed on click, cannot be nullptr.
clickCountthe action will only be performed when an event is received with this click count
Returns
an object on which more options or requirements can be specified regarding the given on-click action, such as the mouse buttons that need to be pressed for the action to be executed.

◆ addOnDragAction()

EditActionBinder & luciad::PointEditHandle::addOnDragAction ( std::shared_ptr< IPointEditAction action)

Adds an action that will be triggered when the handle is dragged.

The given action is executed at least when the drag gesture starts and ends, and if EditActionBinder::performOnIntermediateEvents is set to true, it also gets executed on every intermediate drag event. The action is always called with an EventStatus parameter corresponding to the drag event.

Parameters
actionthe action to be performed on drag, cannot be nullptr.
Returns
an object on which more options or requirements can be specified regarding the given on-drag action, such as the mouse buttons that need to be pressed for the action to be executed.

◆ addOnMouseMoveAction()

EditActionBinder & luciad::PointEditHandle::addOnMouseMoveAction ( std::shared_ptr< IPointEditAction action)

Adds an action that will be executed on every mouse move.

Parameters
actionthe action to be performed during the mouse move, cannot be nullptr.
Returns
an object on which more options or requirements can be specified regarding the given action, such as the modifier keys that need to be pressed for the action to be executed.

◆ addOnTouchLongPressAction()

EditActionBinder & luciad::PointEditHandle::addOnTouchLongPressAction ( std::shared_ptr< IPointEditAction action)

Adds an action that will be triggered when a long press is performed on a handle.

Parameters
actionthe action to be performed, cannot be nullptr.
Returns
an object on which more options or requirements can be specified regarding the given on-drag action
Since
2022.1

◆ getActiveIcon()

std::shared_ptr< luciad::IIcon > luciad::PointEditHandle::getActiveIcon ( ) const

Returns the icon to paint when the handle is in an active state.

Returns
the icon to paint when the handle is in an active state.
See also
setActiveIcon

◆ getActiveVisualAidComplexStrokeLineStyle()

const std::optional< ComplexStrokeLineStyle > & luciad::PointEditHandle::getActiveVisualAidComplexStrokeLineStyle ( ) const

Returns the visual aid line style to use when this handle is in an active state.

This method is linked to the getActiveVisualAidLineStyle method:

  • if both of them return std::nullopt, no visual aid line is painted
  • if one of them is not std::nullopt, that line style is used
  • it's not possible for both methods to return a non std::nullopt value: they are mutually exclusive
Returns
the visual aid complex stroke line style to use when this handle is in an active state.
See also
setActiveVisualAidComplexStrokeLineStyle
Since
2023.1

◆ getActiveVisualAidLineStyle()

const std::optional< LineStyle > & luciad::PointEditHandle::getActiveVisualAidLineStyle ( ) const

Returns the visual aid line style to use when this handle is in an active state.

This method is linked to the getActiveVisualAidComplexStrokeLineStyle method:

  • if both of them return std::nullopt, no visual aid line is painted
  • if one of them is not std::nullopt, that line style is used
  • it's not possible for both methods to return a non std::nullopt value: they are mutually exclusive
Returns
the visual aid line style to use when this handle is in an active state.
See also
setActiveVisualAidLineStyle

◆ getEditState()

EditHandleState luciad::PointEditHandle::getEditState ( ) const
overridevirtual

Returns the current state of this handle.

Returns
the current state of this handle.

Implements luciad::IEditHandle.

◆ getHighlightedIcon()

std::shared_ptr< luciad::IIcon > luciad::PointEditHandle::getHighlightedIcon ( ) const

Returns the icon to paint when the handle is in a highlighted state.

Returns
the icon to paint when the handle is in a highlighted state.
See also
setHighlightedIcon

◆ getHighlightedVisualAidComplexStrokeLineStyle()

const std::optional< ComplexStrokeLineStyle > & luciad::PointEditHandle::getHighlightedVisualAidComplexStrokeLineStyle ( ) const

Returns the visual aid complex stroke line style to use when this handle is in a highlighted state.

This method is linked to the getHighlightedVisualAidLineStyle method:

  • if both of them return std::nullopt, no visual aid line is painted
  • if one of them is not std::nullopt, that line style is used
  • it's not possible for both methods to return a non std::nullopt value: they are mutually exclusive
Returns
the visual aid complex stroke line style to use when this handle is in a highlighted state.
See also
setHighlightedVisualAidComplexStrokeLineStyle
Since
2023.1

◆ getHighlightedVisualAidLineStyle()

const std::optional< LineStyle > & luciad::PointEditHandle::getHighlightedVisualAidLineStyle ( ) const

Returns the visual aid line style to use when this handle is in a highlighted state.

This method is linked to the getHighlightedVisualAidComplexStrokeLineStyle method:

  • if both of them return std::nullopt, no visual aid line is painted
  • if one of them is not std::nullopt, that line style is used
  • it's not possible for both methods to return a non std::nullopt value: they are mutually exclusive
Returns
the visual aid line style to use when this handle is in a highlighted state.
See also
setHighlightedVisualAidLineStyle

◆ getLocation()

std::shared_ptr< Point > luciad::PointEditHandle::getLocation ( ) const

Returns the current location of this handle.

Note that this location is not necessarily equal to the location provider at all times. For example, they may differ when the handle is dragged around and no location changes are triggered in the location provider.

Returns
the current location of this handle

◆ getLocationProvider()

std::shared_ptr< Observable< std::shared_ptr< Point > > > luciad::PointEditHandle::getLocationProvider ( ) const

Returns the location provider of this handle.

Note that the handle's current location is not necessarily equal to this location provider at all times. For example, they may differ when the handle is dragged around and no location changes are triggered in this location provider. Additionally, the handle may have a different location provider when it is active. See getLocationProviderWhenActive.

Returns
the location provider of this handle. Never nullptr.

◆ getLocationProviderWhenActive()

std::shared_ptr< Observable< std::shared_ptr< Point > > > luciad::PointEditHandle::getLocationProviderWhenActive ( ) const

Returns the location provider to use when the handle is active.

Can be nullptr if no distinct location provider is set for when the handle is active.

Returns
the location provider to use when the handle is active, or nullptr.

◆ getMouseCursor()

std::optional< MouseCursor > luciad::PointEditHandle::getMouseCursor ( ) const
overridevirtual

Returns the current mouse cursor that should be displayed for this handle.

This method typically returns a value when this handle is highlighted or active. If not, std::nullopt can be returned.

Returns
the current mouse cursor that should be displayed for this handle.

Implements luciad::IEditHandle.

◆ getMoveConstraint()

EditMoveConstraint luciad::PointEditHandle::getMoveConstraint ( ) const

Returns the move constraint of this point handle.

Returns
the move constraint of this point handle.

◆ getRegularIcon()

std::shared_ptr< luciad::IIcon > luciad::PointEditHandle::getRegularIcon ( ) const

Returns the icon to paint when the handle is in a regular state.

Returns
the icon to paint when the handle is in a regular state.
See also
setRegularIcon

◆ getRegularVisualAidComplexStrokeLineStyle()

const std::optional< ComplexStrokeLineStyle > & luciad::PointEditHandle::getRegularVisualAidComplexStrokeLineStyle ( ) const

Returns the visual aid complex stroke line style to use when this handle is in an inactive state.

This method is linked to the getRegularVisualAidLineStyle method:

  • if both of them return std::nullopt, no visual aid line is painted
  • if one of them is not std::nullopt, that line style is used
  • it's not possible for both methods to return a non std::nullopt value: they are mutually exclusive
Returns
the visual aid complex stroke line style to use when this handle is in an inactive state.
See also
setRegularVisualAidComplexStrokeLineStyle
Since
2023.1

◆ getRegularVisualAidLineStyle()

const std::optional< LineStyle > & luciad::PointEditHandle::getRegularVisualAidLineStyle ( ) const

Returns the visual aid line style to use when this handle is in an inactive state.

This method is linked to the getRegularVisualAidComplexStrokeLineStyle method:

  • if both of them return std::nullopt, no visual aid line is painted
  • if one of them is not std::nullopt, that line style is used
  • it's not possible for both methods to return a non std::nullopt value: they are mutually exclusive
Returns
the visual aid line style to use when this handle is in an inactive state.
See also
setRegularVisualAidLineStyle

◆ getVisualAidLineProvider()

std::shared_ptr< IVisualAidProvider > luciad::PointEditHandle::getVisualAidLineProvider ( ) const

Returns the visual aid line provider that allows to paint a visual aid line together with this handle.

Returns
the visual aid line provider
See also
setVisualAidLineProvider

◆ getZOrder()

ZOrder luciad::PointEditHandle::getZOrder ( ) const

Returns the Z-order that is used for this handle's paint calls to the FeatureCanvas.

Returns
the Z-order that is used for this handle's paint calls to the FeatureCanvas.
See also
setZOrder.
FeatureCanvas draw commands. For example FeatureCanvas::IconDrawCommand::zOrder.

◆ isUseFeatureAsHandle()

bool luciad::PointEditHandle::isUseFeatureAsHandle ( ) const

Returns whether this handle should paint any icons itself.

When set to true, this handle does not paint any icons itself.

Returns
when this is set to true, this handle does not paint any icons for itself.
See also
setUseFeatureAsHandle

◆ onEvent()

EventResult luciad::PointEditHandle::onEvent ( const std::shared_ptr< IInputEvent > &  inputEvent,
const std::shared_ptr< FeatureEditContext > &  context 
)
overridevirtual

Handles the given event, and returns if the event was consumed or not.

While handling events, IEditHandles can mark themselves as highlighted or as Active. Related to event handling, the main effect of this is that highlighted or active handles get a higher priority compared to other handles: they get the chance to consume events first. See EditHandleState

Parameters
inputEventthe event to handle, cannot be nullptr
contextthe context, cannot be nullptr
Returns
if the event was consumed or not
Exceptions
NullArgumentExceptionwhen nullptr is passed.

Implements luciad::IEditHandle.

◆ operator=()

PointEditHandle & luciad::PointEditHandle::operator= ( const PointEditHandle other)
delete

◆ paint()

void luciad::PointEditHandle::paint ( FeatureCanvas canvas,
const std::shared_ptr< FeatureEditContext > &  context 
) const
overridevirtual

Paints this handle on the given canvas.

This method is called when

This method only gets called on the UI thread, so there is no need for additional synchronization.

Parameters
canvasthe canvas on which this handle gets painted.
contextthe context, cannot be nullptr

Implements luciad::IEditHandle.

◆ removeEditStateObserver()

void luciad::PointEditHandle::removeEditStateObserver ( const std::shared_ptr< IInvalidationCallback > &  observer)
overridevirtual

Removes the given observer.

If the given observer was never added, an exception is thrown.

Parameters
observeran observer
Exceptions
InvalidArgumentExceptionwhen the observer is not known.
Since
2023.1

Implements luciad::IEditHandle.

◆ setActiveIcon()

void luciad::PointEditHandle::setActiveIcon ( std::shared_ptr< IIcon icon)

Sets the icon to paint when the handle is in an active state.

This icon is only used when setUseFeatureAsHandle is set to false.

Parameters
iconthe icon to paint when the handle is in an active state

◆ setActiveVisualAidComplexStrokeLineStyle()

void luciad::PointEditHandle::setActiveVisualAidComplexStrokeLineStyle ( std::optional< ComplexStrokeLineStyle lineStyle)

Sets the visual aid line style to use when this handle is in an active state.

This style is only used when a visual aid line is set.

Only one active line style can be set, if this function is called with a non std::nullopt value when a LineStyle has already been set, it will be overwritten.

The default is std::nullopt, as a linestyle is used as default active visual aid style.

Parameters
lineStylethe visual aid complex stroke line style to use when this handle is in a EditHandleState::Active state.
Since
2023.1

◆ setActiveVisualAidLineStyle()

void luciad::PointEditHandle::setActiveVisualAidLineStyle ( std::optional< LineStyle lineStyle)

Sets the visual aid line style to use when this handle is in an active state.

This style is only used when a visual aid line is set.

Only one active line style can be set, if this function is called with a non std::nullopt value when a ComplexStrokeLineStyle has already been set, it will be overwritten.

The default is a small, grey line.

Parameters
lineStylethe visual aid line style to use when this handle is in an active state.

◆ setHighlightedIcon()

void luciad::PointEditHandle::setHighlightedIcon ( std::shared_ptr< IIcon icon)

Sets the icon to paint when the handle is in a highlighted state.

This icon is only used when setUseFeatureAsHandle is set to false.

Parameters
iconthe icon to paint when the handle is in a highlighted state.

◆ setHighlightedVisualAidComplexStrokeLineStyle()

void luciad::PointEditHandle::setHighlightedVisualAidComplexStrokeLineStyle ( std::optional< ComplexStrokeLineStyle lineStyle)

Sets the visual aid complex stroke line style to use when this handle is in a highlighted state.

This style is only used when a visual aid line is set.

Only one highlighted line style can be set, if this function is called with a non std::nullopt value when a LineStyle has already been set, it will be overwritten.

The default is std::nullopt, as a linestyle is used as default highlighted visual aid style.

Parameters
lineStylethe visual aid complex stroke line style to use when this handle is in a highlighted state.
Since
2023.1

◆ setHighlightedVisualAidLineStyle()

void luciad::PointEditHandle::setHighlightedVisualAidLineStyle ( std::optional< LineStyle lineStyle)

Sets the visual aid line style to use when this handle is in a highlighted state.

This style is only used when a visual aid line is set.

Only one regular line style can be set, if this function is called with a non std::nullopt value when a ComplexStrokeLineStyle has already been set, it will be overwritten.

The default is a small, grey line.

Parameters
lineStylethe visual aid line style to use when this handle is in a highlighted state.

◆ setInvalidationCallback()

void luciad::PointEditHandle::setInvalidationCallback ( std::shared_ptr< IInvalidationCallback invalidationCallback)
overridevirtual

Sets the callback for the handle to call when its visual representation or cursor has changed.

Calling this callback triggers a new call to this handle's paint method.

Parameters
invalidationCallbackthe callback for the handle to call when its visual representation has changed

Implements luciad::IEditHandle.

◆ setLocationProviderWhenActive()

void luciad::PointEditHandle::setLocationProviderWhenActive ( std::shared_ptr< Observable< std::shared_ptr< Point > > >  locationProviderWhenActive)

Sets the location provider to use when the handle is active.

If set, this overrides the regular location provider when the handle is active.

Can be nullptr.

Parameters
locationProviderWhenActivethe location provider to use when the handle is active.

◆ setMoveConstraint()

void luciad::PointEditHandle::setMoveConstraint ( EditMoveConstraint  moveConstraint)

Sets the move constraint of this point handle.

By default, this is EditMoveConstraint::XY.

Parameters
moveConstraintthe move constraint of this point handle.

◆ setRegularIcon()

void luciad::PointEditHandle::setRegularIcon ( std::shared_ptr< IIcon icon)

Sets the icon to paint when the handle is in a regular state.

This icon is only used when setUseFeatureAsHandle is set to false.

Parameters
iconthe icon to paint when the handle is in a regular (i.e. non-highlighted, non-active) state.

◆ setRegularVisualAidComplexStrokeLineStyle()

void luciad::PointEditHandle::setRegularVisualAidComplexStrokeLineStyle ( std::optional< ComplexStrokeLineStyle lineStyle)

Sets the visual aid complex stroke line style to use when this handle is in an inactive state.

This style is only used when a visual aid line is set.

Only one regular line style can be set, if this function is called with a non std::nullopt value when a LineStyle has already been set, it will be overwritten.

The default is std::nullopt, as a linestyle is used as default regular visual aid style.

Parameters
lineStylethe visual aid complex stroke line style to use when this handle is in an inactive state.
Since
2023.1

◆ setRegularVisualAidLineStyle()

void luciad::PointEditHandle::setRegularVisualAidLineStyle ( std::optional< LineStyle lineStyle)

Sets the visual aid line style to use when this handle is in an inactive state.

This style is only used when a visual aid line is set.

Only one regular line style can be set, if this function is called with a non std::nullopt value when a ComplexStrokeLineStyle has already been set, it will be overwritten.

The default is a small, grey line.

Parameters
lineStylethe visual aid line style to use when this handle is in an inactive state.

◆ setUseFeatureAsHandle()

void luciad::PointEditHandle::setUseFeatureAsHandle ( bool  useFeatureAsHandle)

Sets whether this handle should paint any icons itself.

When set to true, this handle does not paint any icons for itself. In this case, the handle considers the feature that is being edited for determining whether it is touched or not. Otherwise, when this is set to false, the handle paints itself as an icon and only considers that icon for deciding whether it is touched.

By default, this is false.

Parameters
useFeatureAsHandlewhen true, this handle does not paint any icons for itself.

◆ setVisualAidLineProvider()

void luciad::PointEditHandle::setVisualAidLineProvider ( std::shared_ptr< IVisualAidProvider provider)

Sets the visual aid line provider that allows to paint a visual aid line together with this handle.

It is not possible to interact with this line. The line style can be configured using setRegularVisualAidLineStyle.

If nullptr, no visual aid line is painted. The default is nullptr.

Parameters
providerthe visual aid line provider.

◆ setZOrder()

void luciad::PointEditHandle::setZOrder ( ZOrder  zOrder)

Sets the Z-order that is used for this handle's paint calls to the FeatureCanvas.

This Z-order determines which handles are painted on top, when multiple handles overlap. Edit handles with a higher Z-order are painted on top of handles with a lower Z-order. Note: highlighted edit handles are always painted above regular handles, and active handles are always painted above highlighted handles.

Must be between [-1000,1000]. The default value is 0.

Parameters
zOrderthe Z-order that is used for this handle's paint calls to the FeatureCanvas.
See also
FeatureCanvas draw commands. For example FeatureCanvas::IconDrawCommand::zOrder.