7#include "CoordSystemContext.h"
8#include "EngaugeAssert.h"
11const CoordSystemIndex DEFAULT_COORD_SYSTEM_INDEX = 0;
14 m_coordSystemIndex (DEFAULT_COORD_SYSTEM_INDEX)
16 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::CoordSystemContext";
19CoordSystemContext::~CoordSystemContext()
21 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::~CoordSystemContext";
23 for (
int i = 0; i < m_coordSystems.count(); i++) {
28 m_coordSystems.clear ();
29 m_coordSystemIndex = 0;
33 unsigned int numberCoordSystemToAdd)
35 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::addCoordSystems"
36 <<
" numberToAdd=" << numberCoordSystemToAdd;
39 for (
unsigned int i = 0; i < numberCoordSystemToAdd; i++) {
40 m_coordSystems.push_back (
new CoordSystem (documentAxesPointsRequired));
46 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::addGraphCurveAtEnd";
48 m_coordSystems [m_coordSystemIndex]->addGraphCurveAtEnd(curveName);
52 const QPointF &posGraph,
57 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::addPointAxisWithGeneratedIdentifier";
59 m_coordSystems [m_coordSystemIndex]->addPointAxisWithGeneratedIdentifier(posScreen,
67 const QPointF &posGraph,
68 const QString &identifier,
72 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::addPointAxisWithSpecifiedIdentifier";
74 m_coordSystems [m_coordSystemIndex]->addPointAxisWithSpecifiedIdentifier(posScreen,
82 const QPointF &posScreen,
83 QString &generatedIdentifier,
86 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::addPointGraphWithGeneratedIdentifier";
88 m_coordSystems [m_coordSystemIndex]->addPointGraphWithGeneratedIdentifier(curveName,
95 const QPointF &posScreen,
96 const QString &identifier,
99 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::addPointGraphWithSpecifiedIdentifier";
101 m_coordSystems [m_coordSystemIndex]->addPointGraphWithSpecifiedIdentifier(curveName,
109 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::addPointsInCurvesGraphs";
111 m_coordSystems [m_coordSystemIndex]->addPointsInCurvesGraphs(
curvesGraphs);
115 const QPointF &posGraph,
117 QString &errorMessage,
120 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::checkAddPointAxis";
122 m_coordSystems [m_coordSystemIndex]->checkAddPointAxis(posScreen,
130 const QPointF &posScreen,
131 const QPointF &posGraph,
133 QString &errorMessage)
135 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::checkEditPointAxis";
137 m_coordSystems [m_coordSystemIndex]->checkEditPointAxis(pointIdentifier,
146 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::coordSystem";
148 return *(m_coordSystems [m_coordSystemIndex]);
153 return m_coordSystems.count();
158 return m_coordSystemIndex;
163 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::curveAxes";
165 return m_coordSystems [m_coordSystemIndex]->curveAxes();
170 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::curveForCurveName";
172 return m_coordSystems [m_coordSystemIndex]->curveForCurveName(curveName);
177 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::curveForCurveName";
179 return m_coordSystems [m_coordSystemIndex]->curveForCurveName(curveName);
184 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::curvesGraphs";
186 return m_coordSystems [m_coordSystemIndex]->curvesGraphs();
191 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::curvesGraphsNames";
193 return m_coordSystems [m_coordSystemIndex]->curvesGraphsNames();
198 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::curvesGraphsNumPoints";
200 return m_coordSystems [m_coordSystemIndex]->curvesGraphsNumPoints(curveName);
204 const QString &identifier)
206 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::editPointAxis";
208 m_coordSystems [m_coordSystemIndex]->editPointAxis(posGraph,
214 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::isXOnly";
216 return m_coordSystems [m_coordSystemIndex]->isXOnly (pointIdentifier);
221 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::iterateThroughCurvePointsAxes";
223 m_coordSystems [m_coordSystemIndex]->iterateThroughCurvePointsAxes(ftorWithCallback);
228 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::iterateThroughCurvePointsAxes";
230 m_coordSystems [m_coordSystemIndex]->iterateThroughCurvePointsAxes(ftorWithCallback);
234 const Functor2wRet<const Point &, const Point &, CallbackSearchReturn> &ftorWithCallback)
const
236 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::iterateThroughCurveSegments";
238 m_coordSystems [m_coordSystemIndex]->iterateThroughCurveSegments(curveName,
244 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::iterateThroughCurvesPointsGraphs";
246 m_coordSystems [m_coordSystemIndex]->iterateThroughCurvesPointsGraphs(ftorWithCallback);
251 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::iterateThroughCurvesPointsGraphs";
253 m_coordSystems [m_coordSystemIndex]->iterateThroughCurvesPointsGraphs(ftorWithCallback);
258 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::loadCurvesFile";
260 return m_coordSystems [m_coordSystemIndex]->loadCurvesFile (curvesFile);
266 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::loadPreVersion6";
268 m_coordSystems [m_coordSystemIndex]->loadPreVersion6 (str,
274 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::loadVersion6";
276 m_coordSystems [m_coordSystemIndex]->loadVersion6 (reader);
280 DocumentAxesPointsRequired documentAxesPointsRequired)
282 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::loadVersion7";
284 int indexLast = m_coordSystems.count() - 1;
285 m_coordSystems [indexLast]->loadVersion7 (reader,
286 documentAxesPointsRequired);
291 LOG4CPP_DEBUG_S ((*mainCat)) <<
"CoordSystemContext::modelAxesChecker";
293 return m_coordSystems [m_coordSystemIndex]->modelAxesChecker();
298 LOG4CPP_DEBUG_S ((*mainCat)) <<
"CoordSystemContext::modelColorFilter";
300 return m_coordSystems [m_coordSystemIndex]->modelColorFilter();
305 LOG4CPP_DEBUG_S ((*mainCat)) <<
"CoordSystemContext::modelCoords";
307 return m_coordSystems [m_coordSystemIndex]->modelCoords();
312 LOG4CPP_DEBUG_S ((*mainCat)) <<
"CoordSystemContext::modelCurveStyles";
314 return m_coordSystems [m_coordSystemIndex]->modelCurveStyles();
319 LOG4CPP_DEBUG_S ((*mainCat)) <<
"CoordSystemContext::modelDigitizeCurve";
321 return m_coordSystems [m_coordSystemIndex]->modelDigitizeCurve();
326 LOG4CPP_DEBUG_S ((*mainCat)) <<
"CoordSystemContext::modelExport";
328 return m_coordSystems [m_coordSystemIndex]->modelExport();
333 LOG4CPP_DEBUG_S ((*mainCat)) <<
"CoordSystemContext::modelGeneral";
335 return m_coordSystems [m_coordSystemIndex]->modelGeneral();
340 LOG4CPP_DEBUG_S ((*mainCat)) <<
"CoordSystemContext::modelGridRemoval";
342 return m_coordSystems [m_coordSystemIndex]->modelGridRemoval();
347 LOG4CPP_DEBUG_S ((*mainCat)) <<
"CoordSystemContext::modelPointMatch";
349 return m_coordSystems [m_coordSystemIndex]->modelPointMatch();
354 LOG4CPP_DEBUG_S ((*mainCat)) <<
"CoordSystemContext::modelSegments";
356 return m_coordSystems [m_coordSystemIndex]->modelSegments();
360 const QPointF &deltaScreen)
362 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::movePoint";
364 return m_coordSystems [m_coordSystemIndex]->movePoint(pointIdentifier,
370 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::nextOrdinalForCurve";
372 return m_coordSystems [m_coordSystemIndex]->nextOrdinalForCurve(curveName);
377 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::positionGraph";
379 return m_coordSystems [m_coordSystemIndex]->positionGraph(pointIdentifier);
384 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::addGraphCurveAtEnd";
386 return m_coordSystems [m_coordSystemIndex]->positionScreen(pointIdentifier);
391 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::print";
393 return m_coordSystems [m_coordSystemIndex]->print();
397 QTextStream &str)
const
399 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::printStream";
401 m_coordSystems [m_coordSystemIndex]->printStream(indentation,
407 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::reasonForUnsuccessfulRead";
409 return m_coordSystems [m_coordSystemIndex]->reasonForUnsuccessfulRead();
414 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::removePointAxis";
416 m_coordSystems [m_coordSystemIndex]->removePointAxis(identifier);
421 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::removePointGraph";
423 m_coordSystems [m_coordSystemIndex]->removePointGraph(identifier);
428 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::removePointsInCurvesGraphs";
430 m_coordSystems [m_coordSystemIndex]->removePointsInCurvesGraphs(
curvesGraphs);
435 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::saveXml";
437 for (
int index = 0; index < m_coordSystems.count(); index++) {
438 m_coordSystems [index]->saveXml (writer);
444 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setCoordSystemIndex"
454 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setCurvesGraphs";
456 m_coordSystems [m_coordSystemIndex]->setCurvesGraphs(
curvesGraphs);
462 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setCurvesGraphs";
469 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelAxesChecker";
476 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelColorFilter";
483 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelCoords";
485 m_coordSystems [m_coordSystemIndex]->setModelCoords(
modelCoords);
490 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelCurveStyles";
497 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelDigitizeCurve";
504 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelExport";
506 m_coordSystems [m_coordSystemIndex]->setModelExport (
modelExport);
511 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelGeneral";
513 m_coordSystems [m_coordSystemIndex]->setModelGeneral(
modelGeneral);
518 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelGridRemoval";
525 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelPointMatch";
527 m_coordSystems [m_coordSystemIndex]->setModelPointMatch(
modelPointMatch);
532 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelSegments";
534 m_coordSystems [m_coordSystemIndex]->setModelSegments(
modelSegments);
539 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::successfulRead";
541 return m_coordSystems [m_coordSystemIndex]->successfulRead();
546 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::updatePointOrdinals";
548 m_coordSystems [m_coordSystemIndex]->updatePointOrdinals(transformation);
unsigned int coordSystemCount() const
Number of CoordSystem.
virtual void addPointGraphWithSpecifiedIdentifier(const QString &curveName, const QPointF &posScreen, const QString &identifier, double ordinal)
Add a single graph point with the specified point identifer. Note that PointStyle is not applied to t...
virtual DocumentModelColorFilter modelColorFilter() const
Get method for DocumentModelColorFilter.
CoordSystemIndex coordSystemIndex() const
Index of current CoordSystem.
virtual void setModelCurveStyles(const CurveStyles &modelCurveStyles)
Set method for CurveStyles.
virtual CurveStyles modelCurveStyles() const
Get method for CurveStyles.
virtual void setModelAxesChecker(const DocumentModelAxesChecker &modelAxesChecker)
Set method for DocumentModelAxesChecker.
virtual void iterateThroughCurvePointsAxes(const Functor2wRet< const QString &, const Point &, CallbackSearchReturn > &ftorWithCallback)
See Curve::iterateThroughCurvePoints, for the axes curve.
virtual const CurvesGraphs & curvesGraphs() const
Make all Curves available, read only, for CmdAbstract classes only.
void setCurvesGraphs(CoordSystemIndex coordSystemIndex, const CurvesGraphs &curvesGraphs)
Applies to current coordinate system.
const CoordSystem & coordSystem() const
Current CoordSystem.
virtual void printStream(QString indentation, QTextStream &str) const
Debugging method that supports print method of this class and printStream method of some other class(...
virtual void editPointAxis(const QPointF &posGraph, const QString &identifier)
Edit the graph coordinates of a single axis point. Call this after checkAddPointAxis to guarantee suc...
void setModelPointMatch(const DocumentModelPointMatch &modelPointMatch)
Set method for DocumentModelPointMatch.
virtual void setModelGeneral(const DocumentModelGeneral &modelGeneral)
Set method for DocumentModelGeneral.
virtual void setModelColorFilter(const DocumentModelColorFilter &modelColorFilter)
Set method for DocumentModelColorFilter.
virtual const Curve & curveAxes() const
Get method for axis curve.
virtual void addPointsInCurvesGraphs(CurvesGraphs &curvesGraphs)
Add all points identified in the specified CurvesGraphs. See also removePointsInCurvesGraphs.
virtual void setModelCoords(const DocumentModelCoords &modelCoords)
Set method for DocumentModelCoords.
virtual void updatePointOrdinals(const Transformation &transformation)
Update point ordinals after point addition/removal or dragging.
virtual void addPointGraphWithGeneratedIdentifier(const QString &curveName, const QPointF &posScreen, QString &generatedIentifier, double ordinal)
Add a single graph point with a generated point identifier.
CoordSystemContext()
Default constructor for constructing from opened file.
virtual DocumentModelAxesChecker modelAxesChecker() const
Get method for DocumentModelAxesChecker.
virtual void print() const
Debugging method for printing directly from symbolic debugger.
virtual int curvesGraphsNumPoints(const QString &curveName) const
See CurvesGraphs::curvesGraphsNumPoints.
void loadVersion6(QXmlStreamReader &reader)
Load from file in version 6 format, into the single CoordSystem.
virtual QPointF positionScreen(const QString &pointIdentifier) const
See Curve::positionScreen.
bool isXOnly(const QString &pointIdentifier) const
True/false if y/x value is empty.
virtual void setModelSegments(const DocumentModelSegments &modelSegments)
Set method for DocumentModelSegments.
virtual DocumentModelDigitizeCurve modelDigitizeCurve() const
Get method for DocumentModelDigitizeCurve.
virtual DocumentModelCoords modelCoords() const
Get method for DocumentModelCoords.
virtual Curve * curveForCurveName(const QString &curveName)
See CurvesGraphs::curveForCurveName, although this also works for AXIS_CURVE_NAME.
virtual int nextOrdinalForCurve(const QString &curveName) const
Default next ordinal value for specified curve.
virtual DocumentModelSegments modelSegments() const
Get method for DocumentModelSegments.
virtual DocumentModelExportFormat modelExport() const
Get method for DocumentModelExportFormat.
virtual void addGraphCurveAtEnd(const QString &curveName)
Add new graph curve to the list of existing graph curves.
virtual void movePoint(const QString &pointIdentifier, const QPointF &deltaScreen)
See Curve::movePoint.
virtual QString reasonForUnsuccessfulRead() const
Return an informative text message explaining why startup loading failed. Applies if successfulRead r...
virtual void checkAddPointAxis(const QPointF &posScreen, const QPointF &posGraph, bool &isError, QString &errorMessage, bool isXOnly)
Check before calling addPointAxis. Also returns the next available ordinal number (to prevent clashes...
void loadVersion7(QXmlStreamReader &reader, DocumentAxesPointsRequired documentAxesPointsRequired)
Load one CoordSystem from file in version 7 format, into the most recent CoordSystem which was just c...
void addCoordSystems(DocumentAxesPointsRequired documentAxesPointsRequired, unsigned int numberCoordSystemToAdd)
Add specified number of coordinate systems to the original one created by the constructor.
virtual void saveXml(QXmlStreamWriter &writer) const
Save graph to xml.
virtual void setModelExport(const DocumentModelExportFormat &modelExport)
Set method for DocumentModelExportFormat.
virtual void removePointGraph(const QString &identifier)
Perform the opposite of addPointGraph.
virtual bool loadCurvesFile(const QString &curvesFile)
Load the curve names in the specified Engauge file into the current graph. This is called near the en...
virtual void checkEditPointAxis(const QString &pointIdentifier, const QPointF &posScreen, const QPointF &posGraph, bool &isError, QString &errorMessage)
Check before calling editPointAxis.
void setCoordSystemIndex(CoordSystemIndex coordSystemIndex)
Index of current CoordSystem.
virtual bool successfulRead() const
Return true if startup loading succeeded. If the loading failed then reasonForUnsuccessfulRed will ex...
virtual DocumentModelGridRemoval modelGridRemoval() const
Get method for DocumentModelGridRemoval.
virtual void addPointAxisWithGeneratedIdentifier(const QPointF &posScreen, const QPointF &posGraph, QString &identifier, double ordinal, bool isXOnly)
Add a single axis point with a generated point identifier.
virtual DocumentModelPointMatch modelPointMatch() const
Get method for DocumentModelPointMatch.
virtual QStringList curvesGraphsNames() const
See CurvesGraphs::curvesGraphsNames.
virtual void iterateThroughCurveSegments(const QString &curveName, const Functor2wRet< const Point &, const Point &, CallbackSearchReturn > &ftorWithCallback) const
See Curve::iterateThroughCurveSegments, for any axes or graph curve.
virtual void addPointAxisWithSpecifiedIdentifier(const QPointF &posScreen, const QPointF &posGraph, const QString &identifier, double ordinal, bool isXOnly)
Add a single axis point with the specified point identifier.
virtual void removePointsInCurvesGraphs(CurvesGraphs &curvesGraphs)
Remove all points identified in the specified CurvesGraphs. See also addPointsInCurvesGraphs.
virtual void removePointAxis(const QString &identifier)
Perform the opposite of addPointAxis.
virtual void iterateThroughCurvesPointsGraphs(const Functor2wRet< const QString &, const Point &, CallbackSearchReturn > &ftorWithCallback)
See Curve::iterateThroughCurvePoints, for all the graphs curves.
void loadPreVersion6(QDataStream &str, double version)
Load from file in pre-version 6 format.
virtual void setModelGridRemoval(const DocumentModelGridRemoval &modelGridRemoval)
Set method for DocumentModelGridRemoval.
virtual DocumentModelGeneral modelGeneral() const
Get method for DocumentModelGeneral.
virtual QPointF positionGraph(const QString &pointIdentifier) const
See Curve::positionGraph.
virtual void setModelDigitizeCurve(const DocumentModelDigitizeCurve &modelDigitizeCurve)
Set method for DocumentModelDigitizeCurve.
Storage of data belonging to one coordinate system.
Model for DlgSettingsCurveProperties and CmdSettingsCurveProperties.
Container for one set of digitized Points.
Container for all graph curves. The axes point curve is external to this class.
Model for DlgSettingsAxesChecker and CmdSettingsAxesChecker.
Model for DlgSettingsColorFilter and CmdSettingsColorFilter.
Model for DlgSettingsCoords and CmdSettingsCoords.
Model for DlgSettingsDigitizeCurve and CmdSettingsDigitizeCurve.
Model for DlgSettingsGeneral and CmdSettingsGeneral.
Model for DlgSettingsGridRemoval and CmdSettingsGridRemoval. The settings are unstable until the user...
Model for DlgSettingsPointMatch and CmdSettingsPointMatch.
Model for DlgSettingsSegments and CmdSettingsSegments.