7 #include "CoordSystemContext.h"
8 #include "EngaugeAssert.h"
11 const CoordSystemIndex DEFAULT_COORD_SYSTEM_INDEX = 0;
14 m_coordSystemIndex (DEFAULT_COORD_SYSTEM_INDEX)
16 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::CoordSystemContext";
19 CoordSystemContext::~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::loadVersion7AndUp";
284 int indexLast = m_coordSystems.count() - 1;
285 m_coordSystems [indexLast]->loadVersions7AndUp (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::modelGridDisplay";
342 return m_coordSystems [m_coordSystemIndex]->modelGridDisplay();
347 LOG4CPP_DEBUG_S ((*mainCat)) <<
"CoordSystemContext::modelGridRemoval";
349 return m_coordSystems [m_coordSystemIndex]->modelGridRemoval();
354 LOG4CPP_DEBUG_S ((*mainCat)) <<
"CoordSystemContext::modelPointMatch";
356 return m_coordSystems [m_coordSystemIndex]->modelPointMatch();
361 LOG4CPP_DEBUG_S ((*mainCat)) <<
"CoordSystemContext::modelSegments";
363 return m_coordSystems [m_coordSystemIndex]->modelSegments();
367 const QPointF &deltaScreen)
369 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::movePoint";
371 return m_coordSystems [m_coordSystemIndex]->movePoint(pointIdentifier,
377 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::nextOrdinalForCurve";
379 return m_coordSystems [m_coordSystemIndex]->nextOrdinalForCurve(curveName);
384 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::positionGraph";
386 return m_coordSystems [m_coordSystemIndex]->positionGraph(pointIdentifier);
391 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::addGraphCurveAtEnd";
393 return m_coordSystems [m_coordSystemIndex]->positionScreen(pointIdentifier);
398 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::print";
400 return m_coordSystems [m_coordSystemIndex]->print();
404 QTextStream &str)
const
406 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::printStream";
408 m_coordSystems [m_coordSystemIndex]->printStream(indentation,
414 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::reasonForUnsuccessfulRead";
416 return m_coordSystems [m_coordSystemIndex]->reasonForUnsuccessfulRead();
421 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::removePointAxis";
423 m_coordSystems [m_coordSystemIndex]->removePointAxis(identifier);
428 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::removePointGraph";
430 m_coordSystems [m_coordSystemIndex]->removePointGraph(identifier);
435 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::removePointsInCurvesGraphs";
437 m_coordSystems [m_coordSystemIndex]->removePointsInCurvesGraphs(curvesGraphs);
442 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::saveXml";
444 for (
int index = 0; index < m_coordSystems.count(); index++) {
445 m_coordSystems [index]->saveXml (writer);
451 return m_coordSystems [m_coordSystemIndex]->selectedCurveName();
456 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setCoordSystemIndex"
459 ENGAUGE_ASSERT(coordSystemIndex < (
unsigned int) m_coordSystems.count());
466 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setCurveAxes";
468 m_coordSystems [m_coordSystemIndex]->setCurveAxes(curveAxes);
473 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setCurvesGraphs";
475 m_coordSystems [m_coordSystemIndex]->setCurvesGraphs(curvesGraphs);
480 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelAxesChecker";
482 m_coordSystems [m_coordSystemIndex]->setModelAxesChecker(modelAxesChecker);
487 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelColorFilter";
489 m_coordSystems [m_coordSystemIndex]->setModelColorFilter(modelColorFilter);
494 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelCoords";
496 m_coordSystems [m_coordSystemIndex]->setModelCoords(modelCoords);
501 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelCurveStyles";
503 m_coordSystems [m_coordSystemIndex]->setModelCurveStyles(modelCurveStyles);
508 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelDigitizeCurve";
510 m_coordSystems [m_coordSystemIndex]->setModelDigitizeCurve(modelDigitizeCurve);
515 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelExport";
517 m_coordSystems [m_coordSystemIndex]->setModelExport (modelExport);
522 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelGeneral";
524 m_coordSystems [m_coordSystemIndex]->setModelGeneral(modelGeneral);
529 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelGridDisplay";
531 m_coordSystems [m_coordSystemIndex]->setModelGridDisplay(modelGridDisplay);
536 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelGridRemoval";
538 m_coordSystems [m_coordSystemIndex]->setModelGridRemoval(modelGridRemoval);
543 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelPointMatch";
545 m_coordSystems [m_coordSystemIndex]->setModelPointMatch(modelPointMatch);
550 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::setModelSegments";
552 m_coordSystems [m_coordSystemIndex]->setModelSegments(modelSegments);
557 m_coordSystems [m_coordSystemIndex]->setSelectedCurveName(selectedCurveName);
562 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::successfulRead";
564 return m_coordSystems [m_coordSystemIndex]->successfulRead();
569 LOG4CPP_INFO_S ((*mainCat)) <<
"CoordSystemContext::updatePointOrdinals";
571 m_coordSystems [m_coordSystemIndex]->updatePointOrdinals(transformation);
virtual QString selectedCurveName() const
Currently selected curve name. This is used to set the selected curve combobox in MainWindow...
void addCoordSystems(DocumentAxesPointsRequired documentAxesPointsRequired, unsigned int numberCoordSystemToAdd)
Add specified number of coordinate systems to the original one created by the constructor.
virtual DocumentModelGeneral modelGeneral() const
Get method for DocumentModelGeneral.
Model for DlgSettingsGeneral and CmdSettingsGeneral.
virtual void saveXml(QXmlStreamWriter &writer) const
Save graph to xml.
Model for DlgSettingsPointMatch and CmdSettingsPointMatch.
Model for DlgSettingsGridDisplay and CmdSettingsGridDisplay.
virtual bool successfulRead() const
Return true if startup loading succeeded. If the loading failed then reasonForUnsuccessfulRed will ex...
virtual void addPointGraphWithGeneratedIdentifier(const QString &curveName, const QPointF &posScreen, QString &generatedIentifier, double ordinal)
Add a single graph point with a generated point identifier.
Model for DlgSettingsCurveProperties and CmdSettingsCurveProperties.
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...
virtual DocumentModelGridRemoval modelGridRemoval() const
Get method for DocumentModelGridRemoval.
virtual void checkEditPointAxis(const QString &pointIdentifier, const QPointF &posScreen, const QPointF &posGraph, bool &isError, QString &errorMessage)
Check before calling editPointAxis.
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...
Storage of data belonging to one coordinate system.
const CoordSystem & coordSystem() const
Current CoordSystem.
virtual DocumentModelExportFormat modelExport() const
Get method for DocumentModelExportFormat.
virtual Curve * curveForCurveName(const QString &curveName)
See CurvesGraphs::curveForCurveName, although this also works for AXIS_CURVE_NAME.
unsigned int coordSystemCount() const
Number of CoordSystem.
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...
CoordSystemIndex coordSystemIndex() const
Index of current CoordSystem.
virtual void removePointsInCurvesGraphs(CurvesGraphs &curvesGraphs)
Remove all points identified in the specified CurvesGraphs. See also addPointsInCurvesGraphs.
virtual void setModelCoords(const DocumentModelCoords &modelCoords)
Set method for DocumentModelCoords.
virtual const Curve & curveAxes() const
Get method for axis curve.
virtual void setModelColorFilter(const DocumentModelColorFilter &modelColorFilter)
Set method for DocumentModelColorFilter.
virtual void setSelectedCurveName(const QString &selectedCurveName)
Save curve name that is selected for the current coordinate system, for the next time the coordinate ...
virtual void setModelGridDisplay(const DocumentModelGridDisplay &modelGridDisplay)
Set method for DocumentModelGridDisplay.
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 void setCurvesGraphs(const CurvesGraphs &curvesGraphs)
Let CmdAbstract classes overwrite CurvesGraphs. Applies to current coordinate system.
virtual CurveStyles modelCurveStyles() const
Get method for CurveStyles.
virtual void setModelCurveStyles(const CurveStyles &modelCurveStyles)
Set method for CurveStyles.
void loadVersions7AndUp(QXmlStreamReader &reader, DocumentAxesPointsRequired documentAxesPointsRequired)
Load one CoordSystem from file in version 7 format or newer, into the most recent CoordSystem which w...
void loadVersion6(QXmlStreamReader &reader)
Load from file in version 6 format, into the single CoordSystem.
virtual DocumentModelColorFilter modelColorFilter() const
Get method for DocumentModelColorFilter.
virtual void setCurveAxes(const Curve &curveAxes)
Let CmdAbstract classes overwrite axes Curve. Applies to current coordinate system.
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 setModelGridRemoval(const DocumentModelGridRemoval &modelGridRemoval)
Set method for DocumentModelGridRemoval.
Model for DlgSettingsDigitizeCurve and CmdSettingsDigitizeCurve.
virtual void setModelAxesChecker(const DocumentModelAxesChecker &modelAxesChecker)
Set method for DocumentModelAxesChecker.
void loadPreVersion6(QDataStream &str, double version)
Load from file in pre-version 6 format.
bool isXOnly(const QString &pointIdentifier) const
True/false if y/x value is empty.
Container for all graph curves. The axes point curve is external to this class.
Model for DlgSettingsColorFilter and CmdSettingsColorFilter.
virtual void setModelExport(const DocumentModelExportFormat &modelExport)
Set method for DocumentModelExportFormat.
void setModelPointMatch(const DocumentModelPointMatch &modelPointMatch)
Set method for DocumentModelPointMatch.
virtual void addPointsInCurvesGraphs(CurvesGraphs &curvesGraphs)
Add all points identified in the specified CurvesGraphs. See also removePointsInCurvesGraphs.
virtual QString reasonForUnsuccessfulRead() const
Return an informative text message explaining why startup loading failed. Applies if successfulRead r...
virtual QStringList curvesGraphsNames() const
See CurvesGraphs::curvesGraphsNames.
virtual void addGraphCurveAtEnd(const QString &curveName)
Add new graph curve to the list of existing graph curves.
virtual void setModelDigitizeCurve(const DocumentModelDigitizeCurve &modelDigitizeCurve)
Set method for DocumentModelDigitizeCurve.
virtual void removePointGraph(const QString &identifier)
Perform the opposite of addPointGraph.
virtual void setModelSegments(const DocumentModelSegments &modelSegments)
Set method for DocumentModelSegments.
Model for DlgSettingsCoords and CmdSettingsCoords.
virtual void removePointAxis(const QString &identifier)
Perform the opposite of addPointAxis.
virtual void print() const
Debugging method for printing directly from symbolic debugger.
virtual DocumentModelAxesChecker modelAxesChecker() const
Get method for DocumentModelAxesChecker.
Container for one set of digitized Points.
virtual int nextOrdinalForCurve(const QString &curveName) const
Default next ordinal value for specified curve.
virtual QPointF positionGraph(const QString &pointIdentifier) const
See Curve::positionGraph.
Model for DlgSettingsAxesChecker and CmdSettingsAxesChecker.
virtual void setModelGeneral(const DocumentModelGeneral &modelGeneral)
Set method for DocumentModelGeneral.
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 QPointF positionScreen(const QString &pointIdentifier) const
See Curve::positionScreen.
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 iterateThroughCurvePointsAxes(const Functor2wRet< const QString &, const Point &, CallbackSearchReturn > &ftorWithCallback)
See Curve::iterateThroughCurvePoints, for the axes curve.
virtual int curvesGraphsNumPoints(const QString &curveName) const
See CurvesGraphs::curvesGraphsNumPoints.
Model for DlgSettingsSegments and CmdSettingsSegments.
virtual const CurvesGraphs & curvesGraphs() const
Make all Curves available, read only, for CmdAbstract classes only.
virtual void updatePointOrdinals(const Transformation &transformation)
Update point ordinals after point addition/removal or dragging.
virtual DocumentModelPointMatch modelPointMatch() const
Get method for DocumentModelPointMatch.
virtual DocumentModelSegments modelSegments() const
Get method for DocumentModelSegments.
CoordSystemContext()
Default constructor for constructing from opened file.
virtual void movePoint(const QString &pointIdentifier, const QPointF &deltaScreen)
See Curve::movePoint.
virtual DocumentModelGridDisplay modelGridDisplay() const
Get method for DocumentModelGridDisplay.
virtual DocumentModelCoords modelCoords() const
Get method for DocumentModelCoords.
Model for DlgSettingsGridRemoval and CmdSettingsGridRemoval. The settings are unstable until the user...
void setCoordSystemIndex(CoordSystemIndex coordSystemIndex)
Index of current CoordSystem.
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 iterateThroughCurvesPointsGraphs(const Functor2wRet< const QString &, const Point &, CallbackSearchReturn > &ftorWithCallback)
See Curve::iterateThroughCurvePoints, for all the graphs curves.
virtual DocumentModelDigitizeCurve modelDigitizeCurve() const
Get method for DocumentModelDigitizeCurve.