LuciadCPillar 2024.0.04
luciad::PolygonHandlesProvider Class Referencefinal

This handles provider can create handles to edit Polygon geometries. More...

#include <luciad/edit/geometries/PolygonHandlesProvider.h>

Inheritance diagram for luciad::PolygonHandlesProvider:
luciad::IGeometryHandlesProvider

Public Member Functions

 PolygonHandlesProvider ()
 Creates a new handles provider that can create handles for a Polygon geometry. More...
 
 ~PolygonHandlesProvider () override
 
bool canProvide (const std::shared_ptr< Observable< std::shared_ptr< Geometry > > > &geometry, const std::shared_ptr< FeatureEditContext > &context) const override
 Indicates if this handles provider can create handles for the given geometry. More...
 
std::shared_ptr< IGeometryHandlesProvidergetPolylineRingHandlesProvider () const
 Returns the IGeometryHandlesProvider that is used to provide handles for exterior and interior PolylineRing instances. More...
 
std::shared_ptr< IEditHandlesprovide (std::shared_ptr< Observable< std::shared_ptr< Geometry > > > geometry, const std::shared_ptr< FeatureEditContext > &context, std::shared_ptr< IGeometryEditCallback > geometryEditCallback) const override
 Returns the handles for the given feature. More...
 
std::shared_ptr< ITranslateEditActionprovideTranslateAction (std::shared_ptr< Observable< std::shared_ptr< Geometry > > > geometry, const std::shared_ptr< FeatureEditContext > &context, std::shared_ptr< IGeometryEditCallback > geometryEditCallback) const override
 Provides a translate action that can be used by the caller to add translation behavior. More...
 
void setPolylineRingHandlesProvider (std::shared_ptr< IGeometryHandlesProvider > provider)
 Sets the IGeometryHandlesProvider that is used to provide handles for the exterior and interior PolylineRing instances. More...
 
- Public Member Functions inherited from luciad::IGeometryHandlesProvider
virtual ~IGeometryHandlesProvider ()=default
 
virtual bool canProvide (const std::shared_ptr< Observable< std::shared_ptr< Geometry > > > &geometry, const std::shared_ptr< FeatureEditContext > &context) const =0
 Indicates if this handles provider can create handles for the given geometry. More...
 
virtual std::shared_ptr< IEditHandlesprovide (std::shared_ptr< Observable< std::shared_ptr< Geometry > > > geometry, const std::shared_ptr< FeatureEditContext > &context, std::shared_ptr< IGeometryEditCallback > geometryEditCallback) const =0
 Returns the handles for the given feature. More...
 
virtual std::shared_ptr< ITranslateEditActionprovideTranslateAction (std::shared_ptr< Observable< std::shared_ptr< Geometry > > > geometry, const std::shared_ptr< FeatureEditContext > &context, std::shared_ptr< IGeometryEditCallback > geometryEditCallback) const =0
 Provides a translate action that can be used by the caller to add translation behavior. More...
 

Detailed Description

This handles provider can create handles to edit Polygon geometries.

It delegates its handle creation to a delegate IGeometryHandlesProvider for its exterior and interior PolylineRing instances.

Note: the handle to translate the entire feature is typically created by the IFeatureHandlesProvider. FeatureHandlesProvider does this by default.

Limitations of this handle provider:

  • it does not create a handle to remove interior PolylineRing instances
  • it does not create a handle to add new interior PolylineRing instances
  • it does not prevent you from modifying the PolylineRing instances that overlap with other PolylineRing instances, or that self-overlap.
Since
2024.0.04

Constructor & Destructor Documentation

◆ PolygonHandlesProvider()

luciad::PolygonHandlesProvider::PolygonHandlesProvider ( )

Creates a new handles provider that can create handles for a Polygon geometry.

◆ ~PolygonHandlesProvider()

luciad::PolygonHandlesProvider::~PolygonHandlesProvider ( )
override

Member Function Documentation

◆ canProvide()

bool luciad::PolygonHandlesProvider::canProvide ( const std::shared_ptr< Observable< std::shared_ptr< Geometry > > > &  geometry,
const std::shared_ptr< FeatureEditContext > &  context 
) const
overridevirtual

Indicates if this handles provider can create handles for the given geometry.

Parameters
geometryan observable geometry, cannot be nullptr
contextthe context. Contains additional information about the edited feature, cannot be nullptr.
Returns
if this handles provider can provide handles and a translate action for the given Feature

Implements luciad::IGeometryHandlesProvider.

◆ getPolylineRingHandlesProvider()

std::shared_ptr< IGeometryHandlesProvider > luciad::PolygonHandlesProvider::getPolylineRingHandlesProvider ( ) const

Returns the IGeometryHandlesProvider that is used to provide handles for exterior and interior PolylineRing instances.

Returns
the IGeometryHandlesProvider that is used to provide handles for exterior and interior PolylineRing instances.
See also
PolygonHandlesProvider::setPolylineRingHandlesProvider

◆ provide()

std::shared_ptr< IEditHandles > luciad::PolygonHandlesProvider::provide ( std::shared_ptr< Observable< std::shared_ptr< Geometry > > >  geometry,
const std::shared_ptr< FeatureEditContext > &  context,
std::shared_ptr< IGeometryEditCallback geometryEditCallback 
) const
overridevirtual

Returns the handles for the given feature.

Note: translation of features is handled by IFeatureHandlesProvider. So geometry handles providers should not provide handles to translate a geometry.

Parameters
geometrythe observable geometry for which to provide handles, cannot be nullptr.
contextthe context. Contains additional information about the edited feature, cannot be nullptr.
geometryEditCallbacka callback that notifies the caller when the Feature has changed, cannot be nullptr.
Returns
handles for the given feature. Never nullptr.

Implements luciad::IGeometryHandlesProvider.

◆ provideTranslateAction()

std::shared_ptr< ITranslateEditAction > luciad::PolygonHandlesProvider::provideTranslateAction ( std::shared_ptr< Observable< std::shared_ptr< Geometry > > >  geometry,
const std::shared_ptr< FeatureEditContext > &  context,
std::shared_ptr< IGeometryEditCallback geometryEditCallback 
) const
overridevirtual

Provides a translate action that can be used by the caller to add translation behavior.

A translation handle is typically added by an IFeatureHandlesProvider, like for example the FeatureHandlesProvider implementation. It calls this method to retrieve a translate action, and uses it to create a TranslateEditHandle.

When ITranslateEditAction::translate is called, the returned implementation must:

Parameters
geometrythe observable geometry for which to provide a translate action, cannot be nullptr
contextthe context, cannot be nullptr
geometryEditCallbacka callback that notifies the caller of this method when a translation has occurred, cannot be nullptr
Returns
a translate action. Never nullptr.

Implements luciad::IGeometryHandlesProvider.

◆ setPolylineRingHandlesProvider()

void luciad::PolygonHandlesProvider::setPolylineRingHandlesProvider ( std::shared_ptr< IGeometryHandlesProvider provider)

Sets the IGeometryHandlesProvider that is used to provide handles for the exterior and interior PolylineRing instances.

If this method is not called, a default implementation is used.

Parameters
providerthe IGeometryHandlesProvider to use, cannot be nullptr.
Exceptions
NullArgumentExceptionwhen nullptr is passed.