29 : mCurve( other.mCurve ? other.mCurve->clone() : nullptr )
31 , mTransformContext( other.mTransformContext )
32 , mTolerance( other.mTolerance )
33 , mStepDistance( other.mStepDistance )
34 , mTerrainProvider( other.mTerrainProvider ? other.mTerrainProvider->clone() : nullptr )
35 , mExpressionContext( other.mExpressionContext )
43 mCurve.reset( other.mCurve ? other.mCurve->clone() :
nullptr );
45 mTransformContext = other.mTransformContext;
46 mTolerance = other.mTolerance;
47 mStepDistance = other.mStepDistance;
48 mTerrainProvider.reset( other.mTerrainProvider ? other.mTerrainProvider->clone() :
nullptr );
49 mExpressionContext = other.mExpressionContext;
55 if ( !
qgsDoubleNear( mTolerance, other.mTolerance ) || !
qgsDoubleNear( mStepDistance, other.mStepDistance ) || mCrs != other.mCrs || !( mTransformContext == other.mTransformContext ) )
58 if ( ( !mCurve && other.mCurve ) || ( mCurve && !other.mCurve ) )
62 else if ( mCurve && other.mCurve )
64 if ( !mCurve->equals( *other.mCurve ) )
68 if ( ( mTerrainProvider && !other.mTerrainProvider ) || ( !mTerrainProvider && other.mTerrainProvider ) )
72 else if ( mTerrainProvider && other.mTerrainProvider )
74 if ( !mTerrainProvider->equals( other.mTerrainProvider.get() ) )
83 return !( *
this == other );
88 mCurve.reset( curve );
110 return mTransformContext;
115 mTransformContext = context;
127 mTerrainProvider.reset( provider );
133 return mTerrainProvider.get();
138 mStepDistance = distance;
144 mExpressionContext = context;
Abstract base class for terrain providers.
Represents a coordinate reference system (CRS).
Contains information about the context in which a coordinate transform is executed.
Abstract base class for curved geometry type.
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
QgsProfileRequest & setStepDistance(double distance)
Sets the profile step distance (in crs() units).
QgsAbstractTerrainProvider * terrainProvider() const
Returns the terrain provider.
QgsProfileRequest(QgsCurve *curve)
Constructor for QgsProfileRequest.
QgsProfileRequest & setExpressionContext(const QgsExpressionContext &context)
Sets the expression context used to evaluate expressions.
bool operator==(const QgsProfileRequest &other) const
QgsCoordinateReferenceSystem crs() const
Returns the desired Coordinate Reference System for the profile.
bool operator!=(const QgsProfileRequest &other) const
double tolerance() const
Returns the tolerance of the request (in crs() units).
QgsProfileRequest & setTransformContext(const QgsCoordinateTransformContext &context)
Sets the transform context, for use when transforming coordinates from a source to the request's crs(...
QgsCurve * profileCurve() const
Returns the cross section profile curve, which represents the line along which the profile should be ...
QgsProfileRequest & setTerrainProvider(QgsAbstractTerrainProvider *provider)
Sets the terrain provider.
QgsProfileRequest & setProfileCurve(QgsCurve *curve)
Sets the cross section profile curve, which represents the line along which the profile should be gen...
QgsProfileRequest & setTolerance(double tolerance)
Sets the tolerance of the request (in crs() units).
QgsProfileRequest & setCrs(const QgsCoordinateReferenceSystem &crs)
Sets the desired Coordinate Reference System (crs) for the profile.
QgsProfileRequest & operator=(const QgsProfileRequest &other)
QgsCoordinateTransformContext transformContext() const
Returns the transform context, for use when transforming coordinates from a source to the request's c...
bool qgsDoubleNear(double a, double b, double epsilon=4 *std::numeric_limits< double >::epsilon())
Compare two doubles (but allow some difference).