QGIS API Documentation
3.8.0-Zanzibar (11aff65)
|
Decorator class for Triangulations (s. More...
#include <TriDecorator.h>
Public Member Functions | |
TriDecorator ()=default | |
Constructor for TriDecorator. More... | |
TriDecorator (Triangulation *t) | |
void | addLine (const QVector< QgsPoint > &points, QgsInterpolator::SourceType lineType) override |
Adds a line (e.g. More... | |
int | addPoint (const QgsPoint &p) override |
Adds a point to the triangulation. More... | |
virtual void | addTriangulation (Triangulation *t) |
Adds an association to a triangulation. More... | |
bool | calcNormal (double x, double y, Vector3D *result) override |
Calculates the normal at a point on the surface and assigns it to 'result'. More... | |
bool | calcPoint (double x, double y, QgsPoint &result) override |
Calculates x-, y and z-value of the point on the surface and assigns it to 'result'. More... | |
void | eliminateHorizontalTriangles () override |
Eliminates the horizontal triangles by swapping. More... | |
int | getNumberOfPoints () const override |
Returns the number of points. More... | |
int | getOppositePoint (int p1, int p2) override |
Returns the number of the point opposite to the triangle points p1, p2 (which have to be on a halfedge). More... | |
QgsPoint * | getPoint (int i) const override |
Returns a pointer to the point with number i. Any virtual points must have the number -1. More... | |
QList< int > * | getPointsAroundEdge (double x, double y) override |
Returns a value list with the numbers of the four points, which would be affected by an edge swap. More... | |
QList< int > | getSurroundingTriangles (int pointno) override |
Returns a pointer to a value list with the information of the triangles surrounding (counterclockwise) a point. More... | |
bool | getTriangle (double x, double y, QgsPoint &p1, int &n1, QgsPoint &p2, int &n2, QgsPoint &p3, int &n3) override |
Finds out in which triangle the point with coordinates x and y is and assigns the numbers of the vertices to 'n1', 'n2' and 'n3' and the vertices to 'p1', 'p2' and 'p3'. More... | |
bool | getTriangle (double x, double y, QgsPoint &p1, QgsPoint &p2, QgsPoint &p3) override |
Finds out, in which triangle the point with coordinates x and y is and assigns the points at the vertices to 'p1', 'p2' and 'p3. More... | |
double | getXMax () const override |
Returns the largest x-coordinate value of the bounding box. More... | |
double | getXMin () const override |
Returns the smallest x-coordinate value of the bounding box. More... | |
double | getYMax () const override |
Returns the largest y-coordinate value of the bounding box. More... | |
double | getYMin () const override |
Returns the smallest x-coordinate value of the bounding box. More... | |
void | performConsistencyTest () override |
Performs a consistency check, remove this later. More... | |
bool | pointInside (double x, double y) override |
Returns true , if the point with coordinates x and y is inside the convex hull and false otherwise. More... | |
void | ruppertRefinement () override |
Adds points to make the triangles better shaped (algorithm of ruppert) More... | |
void | setBreakEdgeColor (int r, int g, int b) override |
Sets the color of the breaklines. More... | |
void | setEdgeColor (int r, int g, int b) override |
Sets the color of the normal edges. More... | |
void | setForcedCrossBehavior (Triangulation::ForcedCrossBehavior b) override |
Draws the points, edges and the forced lines. More... | |
void | setForcedEdgeColor (int r, int g, int b) override |
Sets the color of the forced edges. More... | |
void | setTriangleInterpolator (TriangleInterpolator *interpolator) override |
Sets an interpolator object. More... | |
bool | swapEdge (double x, double y) override |
Reads the content of a taff-file. More... | |
Public Member Functions inherited from Triangulation | |
virtual | ~Triangulation ()=default |
virtual bool | saveTriangulation (QgsFeatureSink *sink, QgsFeedback *feedback=nullptr) const =0 |
Saves the triangulation features to a feature sink. More... | |
Protected Attributes | |
Triangulation * | mTIN = nullptr |
Association with a Triangulation object. More... | |
Additional Inherited Members | |
Public Types inherited from Triangulation | |
enum | ForcedCrossBehavior { SnappingTypeVertex, DeleteFirst, InsertVertex } |
Enumeration describing the behavior, if two forced lines cross. More... | |
Static Public Member Functions inherited from Triangulation | |
static QgsFields | triangulationFields () |
Returns the fields output by features when calling saveTriangulation(). More... | |
Decorator class for Triangulations (s.
Decorator pattern in Gamma et al.).
Definition at line 31 of file TriDecorator.h.
|
default |
Constructor for TriDecorator.
|
inlineexplicit |
Definition at line 72 of file TriDecorator.h.
|
overridevirtual |
Adds a line (e.g.
a break-, structure- or an isoline) to the triangulation, by specifying a list of source points.
Implements Triangulation.
Definition at line 20 of file TriDecorator.cpp.
|
overridevirtual |
Adds a point to the triangulation.
The point should have a z-value matching the value to interpolate.
Implements Triangulation.
Definition at line 32 of file TriDecorator.cpp.
|
inlinevirtual |
Adds an association to a triangulation.
Definition at line 78 of file TriDecorator.h.
|
overridevirtual |
Calculates the normal at a point on the surface and assigns it to 'result'.
true
in case of success and false
in case of failure Implements Triangulation.
Definition at line 58 of file TriDecorator.cpp.
|
overridevirtual |
Calculates x-, y and z-value of the point on the surface and assigns it to 'result'.
Returns true
in case of success and false
in case of failure
Implements Triangulation.
Definition at line 72 of file TriDecorator.cpp.
|
overridevirtual |
Eliminates the horizontal triangles by swapping.
Implements Triangulation.
Definition at line 282 of file TriDecorator.cpp.
|
overridevirtual |
Returns the number of points.
Implements Triangulation.
Definition at line 128 of file TriDecorator.cpp.
|
overridevirtual |
Returns the number of the point opposite to the triangle points p1, p2 (which have to be on a halfedge).
Returns -1 if point is a virtual point. Returns -10 if point crosses over edges.
Implements Triangulation.
Definition at line 141 of file TriDecorator.cpp.
|
overridevirtual |
Returns a pointer to the point with number i. Any virtual points must have the number -1.
Implements Triangulation.
Definition at line 86 of file TriDecorator.cpp.
|
overridevirtual |
Returns a value list with the numbers of the four points, which would be affected by an edge swap.
This function is e.g. needed by NormVecDecorator to know the points, for which the normals have to be recalculated. The list has to be deleted by the code which calls this method
Implements Triangulation.
Definition at line 334 of file TriDecorator.cpp.
|
overridevirtual |
Returns a pointer to a value list with the information of the triangles surrounding (counterclockwise) a point.
Four integer values describe a triangle, the first three are the number of the half edges of the triangle and the fourth is -10, if the third (and most counterclockwise) edge is a breakline, and -20 otherwise. Any virtual point needs to have the number -1
Implements Triangulation.
Definition at line 155 of file TriDecorator.cpp.
|
overridevirtual |
Finds out in which triangle the point with coordinates x and y is and assigns the numbers of the vertices to 'n1', 'n2' and 'n3' and the vertices to 'p1', 'p2' and 'p3'.
Implements Triangulation.
Definition at line 100 of file TriDecorator.cpp.
|
overridevirtual |
Finds out, in which triangle the point with coordinates x and y is and assigns the points at the vertices to 'p1', 'p2' and 'p3.
Implements Triangulation.
Definition at line 114 of file TriDecorator.cpp.
|
overridevirtual |
Returns the largest x-coordinate value of the bounding box.
Implements Triangulation.
Definition at line 167 of file TriDecorator.cpp.
|
overridevirtual |
Returns the smallest x-coordinate value of the bounding box.
Implements Triangulation.
Definition at line 181 of file TriDecorator.cpp.
|
overridevirtual |
Returns the largest y-coordinate value of the bounding box.
Implements Triangulation.
Definition at line 194 of file TriDecorator.cpp.
|
overridevirtual |
Returns the smallest x-coordinate value of the bounding box.
Implements Triangulation.
Definition at line 208 of file TriDecorator.cpp.
|
overridevirtual |
Performs a consistency check, remove this later.
Implements Triangulation.
Definition at line 46 of file TriDecorator.cpp.
|
overridevirtual |
Returns true
, if the point with coordinates x and y is inside the convex hull and false
otherwise.
Implements Triangulation.
Definition at line 306 of file TriDecorator.cpp.
|
overridevirtual |
Adds points to make the triangles better shaped (algorithm of ruppert)
Implements Triangulation.
Definition at line 294 of file TriDecorator.cpp.
|
overridevirtual |
Sets the color of the breaklines.
Implements Triangulation.
Definition at line 258 of file TriDecorator.cpp.
|
overridevirtual |
Sets the color of the normal edges.
Implements Triangulation.
Definition at line 234 of file TriDecorator.cpp.
|
overridevirtual |
Draws the points, edges and the forced lines.
Sets the behavior of the triangulation in case of crossing forced lines
Implements Triangulation.
Definition at line 222 of file TriDecorator.cpp.
|
overridevirtual |
Sets the color of the forced edges.
Implements Triangulation.
Definition at line 246 of file TriDecorator.cpp.
|
overridevirtual |
Sets an interpolator object.
Implements Triangulation.
Definition at line 270 of file TriDecorator.cpp.
|
overridevirtual |
Reads the content of a taff-file.
Saves the content to a taff file Swaps the edge which is closest to the point with x and y coordinates (if this is possible)
Implements Triangulation.
Definition at line 320 of file TriDecorator.cpp.
|
protected |
Association with a Triangulation object.
Definition at line 67 of file TriDecorator.h.