QGIS API Documentation 3.99.0-Master (18a1e75d814)
Loading...
Searching...
No Matches
ParametricLine.h
Go to the documentation of this file.
1/***************************************************************************
2 ParametricLine.h - description
3 -------------------
4 copyright : (C) 2004 by Marco Hugentobler
6 ***************************************************************************/
7
8/***************************************************************************
9 * *
10 * This program is free software; you can redistribute it and/or modify *
11 * it under the terms of the GNU General Public License as published by *
12 * the Free Software Foundation; either version 2 of the License, or *
13 * (at your option) any later version. *
14 * *
15 ***************************************************************************/
16
17#ifndef PARAMETRICLINE_H
18#define PARAMETRICLINE_H
19
20#include "qgis_analysis.h"
21#include "qgis_sip.h"
22#include "qgspoint.h"
23
24#include <QVector>
25
26#define SIP_NO_FILE
27
28class Vector3D;
29
30
39class ANALYSIS_EXPORT ParametricLine
40{
41 protected:
43 int mDegree = 0;
47 QVector<QgsPoint *> *mControlPoly = nullptr;
48
49 public:
50 ParametricLine() = default;
51
55 ParametricLine( ParametricLine *par SIP_TRANSFER, QVector<QgsPoint *> *controlpoly );
56 virtual ~ParametricLine() = default;
57 virtual void add( ParametricLine *pl SIP_TRANSFER ) = 0;
58 virtual void calcFirstDer( float t, Vector3D *v SIP_OUT ) = 0;
59 virtual void calcSecDer( float t, Vector3D *v SIP_OUT ) = 0;
60 //virtual QgsPoint calcPoint(float t);
61 virtual void calcPoint( float t, QgsPoint *p SIP_OUT ) = 0;
62 virtual void changeDirection() = 0;
63 //virtual void draw(QPainter* p);
64 virtual const QgsPoint *getControlPoint( int number ) const = 0;
65 virtual const QVector<QgsPoint *> *getControlPoly() const = 0;
66 virtual int getDegree() const = 0;
67 virtual ParametricLine *getParent() const = 0;
68 //virtual bool intersects(ParametricLine* pal);
69 virtual void remove( int i ) = 0;
70 virtual void setControlPoly( QVector<QgsPoint *> *cp ) = 0;
71 virtual void setParent( ParametricLine *paral ) = 0;
72};
73
74#ifndef SIP_RUN
75
76//-----------------------------------------constructors and destructor----------------------
77
78inline ParametricLine::ParametricLine( ParametricLine *par, QVector<QgsPoint *> *controlpoly )
79 : mParent( par )
80 , mControlPoly( controlpoly )
81{
82}
83
84#endif
85
86#endif
virtual ~ParametricLine()=default
virtual const QVector< QgsPoint * > * getControlPoly() const =0
virtual void setParent(ParametricLine *paral)=0
virtual void remove(int i)=0
int mDegree
Degree of the parametric Line.
virtual void changeDirection()=0
virtual int getDegree() const =0
virtual void calcSecDer(float t, Vector3D *v)=0
virtual void add(ParametricLine *pl)=0
virtual const QgsPoint * getControlPoint(int number) const =0
ParametricLine * mParent
Pointer to the parent object. If there isn't one, mParent is 0.
virtual void calcFirstDer(float t, Vector3D *v)=0
virtual void setControlPoly(QVector< QgsPoint * > *cp)=0
QVector< QgsPoint * > * mControlPoly
MControlPoly stores the points of the control polygon.
virtual ParametricLine * getParent() const =0
virtual void calcPoint(float t, QgsPoint *p)=0
ParametricLine()=default
Point geometry type, with support for z-dimension and m-values.
Definition qgspoint.h:53
Represents a 3D-Vector, capable of storing x, y and z-coordinates in double values.
Definition Vector3D.h:37
#define SIP_TRANSFER
Definition qgis_sip.h:35
#define SIP_OUT
Definition qgis_sip.h:57