QGIS API Documentation 3.28.0-Firenze (ed3ad0430f)
|
LabelPosition is a candidate feature label position. More...
#include <labelposition.h>
Public Types | |
enum | Quadrant { QuadrantAboveLeft , QuadrantAbove , QuadrantAboveRight , QuadrantLeft , QuadrantOver , QuadrantRight , QuadrantBelowLeft , QuadrantBelow , QuadrantBelowRight } |
Position of label candidate relative to feature. More... | |
Public Member Functions | |
LabelPosition (const LabelPosition &other) | |
Copy constructor. More... | |
LabelPosition (int id, double x1, double y1, double w, double h, double alpha, double cost, FeaturePart *feature, bool isReversed=false, Quadrant quadrant=QuadrantOver) | |
create a new LabelPosition More... | |
double | angleDifferential () |
Returns the angle differential of all LabelPosition parts. More... | |
bool | conflictsWithObstacle () const |
Returns whether the position is marked as conflicting with an obstacle feature. More... | |
double | cost () const |
Returns the candidate label position's geographical cost. More... | |
bool | crossesBoundary (PointSet *polygon) const |
Returns true if this label crosses the boundary of the specified polygon. More... | |
bool | crossesLine (PointSet *line) const |
Returns true if this label crosses the specified line. More... | |
void | decrementNumOverlaps () |
Decreases the number of overlaps recorded against this position by 1. More... | |
double | getAlpha () const |
Returns the angle to rotate text (in rad). More... | |
void | getBoundingBox (double amin[2], double amax[2]) const |
Returns bounding box - amin: xmin,ymin - amax: xmax,ymax. More... | |
double | getDistanceToPoint (double xp, double yp) const |
Gets distance from this label to a point. If point lies inside, returns negative number. More... | |
FeaturePart * | getFeaturePart () const |
Returns the feature corresponding to this labelposition. More... | |
double | getHeight () const |
int | getId () const |
Returns the id. More... | |
int | getNumOverlaps () const |
int | getPartId () const |
int | getProblemFeatureId () const |
Quadrant | getQuadrant () const |
bool | getReversed () const |
bool | getUpsideDown () const |
double | getWidth () const |
double | getX (int i=0) const |
Returns the down-left x coordinate. More... | |
double | getY (int i=0) const |
Returns the down-left y coordinate. More... | |
unsigned int | globalId () const |
Returns the global ID for the candidate, which is unique for a single run of the pal labelling engine. More... | |
bool | hasHardObstacleConflict () const |
Returns whether the position is marked as having a hard conflict with an obstacle feature. More... | |
void | incrementNumOverlaps () |
Increases the number of overlaps recorded against this position by 1. More... | |
void | insertIntoIndex (PalRtree< LabelPosition > &index) |
Inserts the label position into the specified index. More... | |
bool | intersects (const GEOSPreparedGeometry *geometry) |
Returns true if the label position intersects a geometry. More... | |
bool | intersectsWithPolygon (PointSet *polygon) const |
Returns true if any intersection between polygon and position exists. More... | |
bool | isIn (double *bbox) |
Is the labelposition in the bounding-box ? (intersect or inside????) More... | |
bool | isInConflict (const LabelPosition *ls) const |
Check whether or not this overlap with another labelPosition. More... | |
bool | isInside (double *bbox) |
Is the labelposition inside the bounding-box ? More... | |
bool | isIntersect (double *bbox) |
Is the labelposition intersect the bounding-box ? More... | |
LabelPosition * | nextPart () const |
Returns the next part of this label position (i.e. More... | |
void | offsetPosition (double xOffset, double yOffset) |
Shift the label by specified offset. More... | |
int | polygonIntersectionCost (PointSet *polygon) const |
Returns cost of position intersection with polygon (testing area of intersection and center). More... | |
const GEOSPreparedGeometry * | preparedMultiPartGeom () const |
Returns a prepared GEOS representation of all label parts as a multipolygon. More... | |
void | removeFromIndex (PalRtree< LabelPosition > &index) |
Removes the label position from the specified index. More... | |
void | resetNumOverlaps () |
void | setConflictsWithObstacle (bool conflicts) |
Sets whether the position is marked as conflicting with an obstacle feature. More... | |
void | setCost (double newCost) |
Sets the candidate label position's geographical cost. More... | |
void | setGlobalId (unsigned int id) |
Sets the global id for the candidate, which is unique for a single run of the pal labelling engine. More... | |
void | setHasHardObstacleConflict (bool conflicts) |
Sets whether the position is marked as having a hard conflict with an obstacle feature. More... | |
void | setNextPart (std::unique_ptr< LabelPosition > next) |
Sets the next part of this label position (i.e. More... | |
void | setPartId (int id) |
void | setProblemIds (int probFid, int lpId) |
Set problem feature ID and assigned label candidate ID. More... | |
void | setUpsideDownCharCount (int count) |
Sets the count of upside down characters for this label position. More... | |
int | upsideDownCharCount () const |
Returns the number of upside down characters for this label position. More... | |
void | validateCost () |
Make sure the cost is less than 1. More... | |
bool | within (const GEOSPreparedGeometry *geometry) |
Returns true if the label position is within a geometry. More... | |
Public Member Functions inherited from pal::PointSet | |
PointSet () | |
PointSet (int nbPoints, double *x, double *y) | |
virtual | ~PointSet () |
double | area () const |
Returns area of polygon geometry. More... | |
QgsRectangle | boundingBox () const |
Returns the point set bounding box. More... | |
bool | boundingBoxIntersects (const PointSet *other) const |
Returns true if the bounding box of this pointset intersects the bounding box of another pointset. More... | |
std::unique_ptr< PointSet > | clone () const |
Returns a copy of the point set. More... | |
OrientedConvexHullBoundingBox | computeConvexHullOrientedBoundingBox (bool &ok) |
Computes an oriented bounding box for the shape's convex hull. More... | |
bool | containsLabelCandidate (double x, double y, double width, double height, double alpha=0) const |
Tests whether a possible label candidate will fit completely within the shape. More... | |
bool | containsPoint (double x, double y) const |
Tests whether point set contains a specified point. More... | |
std::tuple< std::vector< double >, double > | edgeDistances () const |
Returns a vector of edge distances as well as its total length. More... | |
void | extendLineByDistance (double startDistance, double endDistance, double smoothDistance) |
Extends linestrings by the specified amount at the start and end of the line, by extending the existing lines following the same direction as the original line start or end. More... | |
std::unique_ptr< PointSet > | extractShape (int nbPtSh, int imin, int imax, int fps, int fpe, double fptx, double fpty) |
Does... something completely inscrutable. More... | |
const GEOSGeometry * | geos () const |
Returns the point set's GEOS geometry. More... | |
void | getCentroid (double &px, double &py, bool forceInside=false) const |
int | getGeosType () const |
PointSet * | getHoleOf () const |
Returns nullptr if this isn't a hole. Otherwise returns pointer to parent pointset. More... | |
int | getNumPoints () const |
void | getPointByDistance (double *d, double *ad, double dl, double *px, double *py) const |
Gets a point a set distance along a line geometry. More... | |
geos::unique_ptr | interpolatePoint (double distance) const |
Returns a GEOS geometry representing the point interpolated on the shape by distance. More... | |
bool | isClosed () const |
Returns true if pointset is closed. More... | |
double | length () const |
Returns length of line geometry. More... | |
double | lineLocatePoint (const GEOSGeometry *point) const |
Returns the distance along the geometry closest to the specified GEOS point. More... | |
double | minDistanceToPoint (double px, double py, double *rx=nullptr, double *ry=nullptr) const |
Returns the squared minimum distance between the point set geometry and the point (px,py) Optionally, the nearest point is stored in (rx,ry). More... | |
void | offsetCurveByDistance (double distance) |
Offsets linestrings by the specified distance. More... | |
QString | toWkt () const |
Returns a WKT representation of the point set. More... | |
Protected Attributes | |
double | alpha |
FeaturePart * | feature = nullptr |
double | h |
int | id |
int | nbOverlap |
int | partId |
int | probFeat |
LabelPosition::Quadrant | quadrant |
bool | reversed |
bool | upsideDown |
double | w |
Protected Attributes inherited from pal::PointSet | |
std::vector< int > | convexHull |
PointSet * | holeOf = nullptr |
double | mArea = -1 |
GEOSGeometry * | mGeos = nullptr |
double | mLength = -1 |
bool | mOwnsGeom = false |
PointSet * | parent = nullptr |
int | type |
double | xmax = std::numeric_limits<double>::lowest() |
double | xmin = std::numeric_limits<double>::max() |
double | ymax = std::numeric_limits<double>::lowest() |
double | ymin = std::numeric_limits<double>::max() |
Friends | |
class | CostCalculator |
class | PolygonCostCalculator |
Additional Inherited Members | |
Static Public Member Functions inherited from pal::PointSet | |
static QLinkedList< PointSet * > | splitPolygons (PointSet *inputShape, double labelWidth, double labelHeight) |
Split a polygon using some random logic into some other polygons. More... | |
Public Attributes inherited from pal::PointSet | |
int | nbPoints |
std::vector< double > | x |
std::vector< double > | y |
Protected Member Functions inherited from pal::PointSet | |
PointSet (const PointSet &ps) | |
PointSet (double x, double y) | |
void | createGeosGeom () const |
void | deleteCoords () |
void | invalidateGeos () const |
const GEOSPreparedGeometry * | preparedGeom () const |
LabelPosition is a candidate feature label position.
Definition at line 55 of file labelposition.h.
Position of label candidate relative to feature.
Enumerator | |
---|---|
QuadrantAboveLeft | |
QuadrantAbove | |
QuadrantAboveRight | |
QuadrantLeft | |
QuadrantOver | |
QuadrantRight | |
QuadrantBelowLeft | |
QuadrantBelow | |
QuadrantBelowRight |
Definition at line 65 of file labelposition.h.
LabelPosition::LabelPosition | ( | int | id, |
double | x1, | ||
double | y1, | ||
double | w, | ||
double | h, | ||
double | alpha, | ||
double | cost, | ||
FeaturePart * | feature, | ||
bool | isReversed = false , |
||
Quadrant | quadrant = QuadrantOver |
||
) |
create a new LabelPosition
id | id of this labelposition |
x1 | down-left x coordinate |
y1 | down-left y coordinate |
w | label width |
h | label height |
alpha | rotation in rad |
cost | geographic cost |
feature | labelpos owners |
isReversed | label is reversed |
quadrant | relative position of label to feature |
Definition at line 43 of file labelposition.cpp.
LabelPosition::LabelPosition | ( | const LabelPosition & | other | ) |
Copy constructor.
Definition at line 140 of file labelposition.cpp.
double LabelPosition::angleDifferential | ( | ) |
Returns the angle differential of all LabelPosition parts.
Definition at line 655 of file labelposition.cpp.
|
inline |
Returns whether the position is marked as conflicting with an obstacle feature.
Definition at line 227 of file labelposition.h.
|
inline |
Returns the candidate label position's geographical cost.
Definition at line 206 of file labelposition.h.
bool LabelPosition::crossesBoundary | ( | PointSet * | polygon | ) | const |
Returns true
if this label crosses the boundary of the specified polygon.
Definition at line 525 of file labelposition.cpp.
bool LabelPosition::crossesLine | ( | PointSet * | line | ) | const |
Returns true
if this label crosses the specified line.
Definition at line 495 of file labelposition.cpp.
|
inline |
Decreases the number of overlaps recorded against this position by 1.
Definition at line 187 of file labelposition.h.
double LabelPosition::getAlpha | ( | ) | const |
Returns the angle to rotate text (in rad).
Definition at line 348 of file labelposition.cpp.
void LabelPosition::getBoundingBox | ( | double | amin[2], |
double | amax[2] | ||
) | const |
Returns bounding box - amin: xmin,ymin - amax: xmax,ymax.
Definition at line 366 of file labelposition.cpp.
double LabelPosition::getDistanceToPoint | ( | double | xp, |
double | yp | ||
) | const |
Gets distance from this label to a point. If point lies inside, returns negative number.
Definition at line 460 of file labelposition.cpp.
FeaturePart * LabelPosition::getFeaturePart | ( | ) | const |
Returns the feature corresponding to this labelposition.
Definition at line 361 of file labelposition.cpp.
|
inline |
Definition at line 261 of file labelposition.h.
int LabelPosition::getId | ( | ) | const |
Returns the id.
Definition at line 333 of file labelposition.cpp.
|
inline |
Definition at line 176 of file labelposition.h.
|
inline |
Definition at line 287 of file labelposition.h.
|
inline |
Definition at line 189 of file labelposition.h.
|
inline |
Definition at line 270 of file labelposition.h.
|
inline |
Definition at line 267 of file labelposition.h.
|
inline |
Definition at line 268 of file labelposition.h.
|
inline |
Definition at line 260 of file labelposition.h.
double LabelPosition::getX | ( | int | i = 0 | ) | const |
Returns the down-left x coordinate.
Definition at line 338 of file labelposition.cpp.
double LabelPosition::getY | ( | int | i = 0 | ) | const |
Returns the down-left y coordinate.
Definition at line 343 of file labelposition.cpp.
|
inline |
Returns the global ID for the candidate, which is unique for a single run of the pal labelling engine.
A return value of 0 means that the ID has not been assigned.
Definition at line 329 of file labelposition.h.
|
inline |
Returns whether the position is marked as having a hard conflict with an obstacle feature.
A hard conflict means that the placement should (usually) not be considered, because the candidate conflicts with a obstacle of sufficient weight.
Definition at line 243 of file labelposition.h.
|
inline |
Increases the number of overlaps recorded against this position by 1.
Definition at line 182 of file labelposition.h.
void LabelPosition::insertIntoIndex | ( | PalRtree< LabelPosition > & | index | ) |
Inserts the label position into the specified index.
Definition at line 414 of file labelposition.cpp.
bool LabelPosition::intersects | ( | const GEOSPreparedGeometry * | geometry | ) |
Returns true
if the label position intersects a geometry.
Definition at line 198 of file labelposition.cpp.
bool LabelPosition::intersectsWithPolygon | ( | PointSet * | polygon | ) | const |
Returns true
if any intersection between polygon and position exists.
Definition at line 564 of file labelposition.cpp.
bool LabelPosition::isIn | ( | double * | bbox | ) |
Is the labelposition in the bounding-box ? (intersect or inside????)
bbox | the bounding-box double[4] = {xmin, ymin, xmax, ymax} |
Definition at line 164 of file labelposition.cpp.
bool LabelPosition::isInConflict | ( | const LabelPosition * | ls | ) | const |
Check whether or not this overlap with another labelPosition.
ls | other labelposition |
true
or false
Definition at line 265 of file labelposition.cpp.
bool LabelPosition::isInside | ( | double * | bbox | ) |
Is the labelposition inside the bounding-box ?
bbox | the bounding-box double[4] = {xmin, ymin, xmax, ymax} |
Definition at line 250 of file labelposition.cpp.
bool LabelPosition::isIntersect | ( | double * | bbox | ) |
Is the labelposition intersect the bounding-box ?
bbox | the bounding-box double[4] = {xmin, ymin, xmax, ymax} |
Definition at line 181 of file labelposition.cpp.
|
inline |
Returns the next part of this label position (i.e.
the next character for a curved label).
Definition at line 277 of file labelposition.h.
void LabelPosition::offsetPosition | ( | double | xOffset, |
double | yOffset | ||
) |
Shift the label by specified offset.
Definition at line 319 of file labelposition.cpp.
int LabelPosition::polygonIntersectionCost | ( | PointSet * | polygon | ) | const |
Returns cost of position intersection with polygon (testing area of intersection and center).
Cost ranges between 0 and 12, with extra cost if center of label position is covered.
Definition at line 556 of file labelposition.cpp.
const GEOSPreparedGeometry * LabelPosition::preparedMultiPartGeom | ( | ) | const |
Returns a prepared GEOS representation of all label parts as a multipolygon.
Definition at line 448 of file labelposition.cpp.
void LabelPosition::removeFromIndex | ( | PalRtree< LabelPosition > & | index | ) |
Removes the label position from the specified index.
Definition at line 406 of file labelposition.cpp.
|
inline |
Definition at line 177 of file labelposition.h.
void LabelPosition::setConflictsWithObstacle | ( | bool | conflicts | ) |
Sets whether the position is marked as conflicting with an obstacle feature.
conflicts | set to true to mark candidate as being in conflict |
Definition at line 392 of file labelposition.cpp.
|
inline |
Sets the candidate label position's geographical cost.
newCost | new cost for position |
Definition at line 213 of file labelposition.h.
|
inline |
Sets the global id for the candidate, which is unique for a single run of the pal labelling engine.
Definition at line 337 of file labelposition.h.
void LabelPosition::setHasHardObstacleConflict | ( | bool | conflicts | ) |
Sets whether the position is marked as having a hard conflict with an obstacle feature.
A hard conflict means that the placement should (usually) not be considered, because the candidate conflicts with a obstacle of sufficient weight.
Definition at line 399 of file labelposition.cpp.
|
inline |
Sets the next part of this label position (i.e.
the next character for a curved label).
Definition at line 284 of file labelposition.h.
|
inline |
Definition at line 288 of file labelposition.h.
|
inline |
Set problem feature ID and assigned label candidate ID.
called from pal.cpp during extraction.
Definition at line 195 of file labelposition.h.
|
inline |
Sets the count of upside down characters for this label position.
Definition at line 295 of file labelposition.h.
|
inline |
Returns the number of upside down characters for this label position.
Definition at line 302 of file labelposition.h.
void LabelPosition::validateCost | ( | ) |
Make sure the cost is less than 1.
Definition at line 353 of file labelposition.cpp.
bool LabelPosition::within | ( | const GEOSPreparedGeometry * | geometry | ) |
Returns true
if the label position is within a geometry.
Definition at line 224 of file labelposition.cpp.
|
friend |
Definition at line 57 of file labelposition.h.
|
friend |
Definition at line 58 of file labelposition.h.
|
protected |
Definition at line 355 of file labelposition.h.
|
protected |
Definition at line 348 of file labelposition.h.
|
protected |
Definition at line 357 of file labelposition.h.
|
protected |
Definition at line 346 of file labelposition.h.
|
protected |
Definition at line 353 of file labelposition.h.
|
protected |
Definition at line 359 of file labelposition.h.
|
protected |
Definition at line 351 of file labelposition.h.
|
protected |
Definition at line 368 of file labelposition.h.
|
protected |
Definition at line 364 of file labelposition.h.
|
protected |
Definition at line 366 of file labelposition.h.
|
protected |
Definition at line 356 of file labelposition.h.