QGIS API Documentation 3.99.0-Master (2fe06baccd8)
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
26class Vector3D;
27
28#define SIP_NO_FILE
29
38class ANALYSIS_EXPORT ParametricLine
39{
40 protected:
42 int mDegree = 0;
46 QVector<QgsPoint *> *mControlPoly = nullptr;
47
48 public:
49 ParametricLine() = default;
50
54 ParametricLine( ParametricLine *par SIP_TRANSFER, QVector<QgsPoint *> *controlpoly );
55 virtual ~ParametricLine() = default;
56 virtual void add( ParametricLine *pl SIP_TRANSFER ) = 0;
57 virtual void calcFirstDer( float t, Vector3D *v SIP_OUT ) = 0;
58 virtual void calcSecDer( float t, Vector3D *v SIP_OUT ) = 0;
59 //virtual QgsPoint calcPoint(float t);
60 virtual void calcPoint( float t, QgsPoint *p SIP_OUT ) = 0;
61 virtual void changeDirection() = 0;
62 //virtual void draw(QPainter* p);
63 virtual const QgsPoint *getControlPoint( int number ) const = 0;
64 virtual const QVector<QgsPoint *> *getControlPoly() const = 0;
65 virtual int getDegree() const = 0;
66 virtual ParametricLine *getParent() const = 0;
67 //virtual bool intersects(ParametricLine* pal);
68 virtual void remove( int i ) = 0;
69 virtual void setControlPoly( QVector<QgsPoint *> *cp ) = 0;
70 virtual void setParent( ParametricLine *paral ) = 0;
71};
72
73#ifndef SIP_RUN
74
75//-----------------------------------------constructors and destructor----------------------
76
77inline ParametricLine::ParametricLine( ParametricLine *par, QVector<QgsPoint *> *controlpoly )
78 : mParent( par )
79 , mControlPoly( controlpoly )
80{
81}
82
83#endif
84
85#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:49
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:36
#define SIP_OUT
Definition qgis_sip.h:58