7#ifndef GEOMETRY_STRATEGY_ABSTRACT_BASE_H
8#define GEOMETRY_STRATEGY_ABSTRACT_BASE_H
41 QVector<bool> &isPotentialExportAmbiguity,
42 QVector<QString> &distanceGraphForward,
43 QVector<QString> &distancePercentForward,
44 QVector<QString> &distanceGraphBackward,
45 QVector<QString> &distancePercentBackward)
const = 0;
52 QVector<QPointF> &positionsGraph)
const;
55 double functionArea (
const QVector<QPointF> &positionsGraph)
const;
61 const QVector<QPointF> &positionsGraph,
62 QVector<QPointF> &positionsGraphWithSubintervals,
63 QVector<QString> &distanceGraphForward,
64 QVector<QString> &distancePercentForward,
65 QVector<QString> &distanceGraphBackward,
66 QVector<QString> &distancePercentBackward)
const;
72 QVector<bool> &isPotentialExportAmbiguity)
const;
75 void loadXY (
const QVector<QPointF> &positionsGraph,
81 QVector<QString> &y)
const;
Model for DlgSettingsCoords and CmdSettingsCoords.
Model for DlgSettingsGeneral and CmdSettingsGeneral.
double polygonAreaForSimplyConnected(const QVector< QPointF > &points) const
Area in polygon using Shoelace formula, which only works if polygon is simply connected.
virtual void calculateGeometry(const Points &points, const DocumentModelCoords &modelCoords, const DocumentModelGeneral &modelGeneral, const MainWindowModel &modelMainWindow, const Transformation &transformation, QString &funcArea, QString &polyArea, QVector< QString > &x, QVector< QString > &y, QVector< bool > &isPotentialExportAmbiguity, QVector< QString > &distanceGraphForward, QVector< QString > &distancePercentForward, QVector< QString > &distanceGraphBackward, QVector< QString > &distancePercentBackward) const =0
Calculate geometry parameters.
virtual void loadPotentialExportVector(QVector< QString > &x, QVector< QString > &y, const Transformation &transformation, QVector< bool > &isPotentialExportAmbiguity) const
Load isPotentialExportAmbiguity vector. Default in base class is to load false values since there are...
void loadXY(const QVector< QPointF > &positionsGraph, const DocumentModelCoords &modelCoords, const DocumentModelGeneral &modelGeneral, const MainWindowModel &modelMainWindow, const Transformation &transformation, QVector< QString > &x, QVector< QString > &y) const
Load x and y coordinate vectors.
void insertSubintervalsAndLoadDistances(int subintervalsPerInterval, const QVector< QPointF > &positionsGraph, QVector< QPointF > &positionsGraphWithSubintervals, QVector< QString > &distanceGraphForward, QVector< QString > &distancePercentForward, QVector< QString > &distanceGraphBackward, QVector< QString > &distancePercentBackward) const
Insert the specified number of subintervals into each interval.
void calculatePositionsGraph(const Points &points, const Transformation &transformation, QVector< QPointF > &positionsGraph) const
Convert screen positions to graph positions.
double functionArea(const QVector< QPointF > &positionsGraph) const
Use trapezoidal approximation to compute area under the function. Does not apply to relation.
GeometryStrategyAbstractBase()
Single constructor.
virtual ~GeometryStrategyAbstractBase()
Model for DlgSettingsMainWindow.