7 #include "CmdAddPointsGraph.h" 8 #include "DigitizeStateContext.h" 9 #include "DigitizeStateSegment.h" 10 #include "EngaugeAssert.h" 12 #include "MainWindow.h" 13 #include "OrdinalGenerator.h" 14 #include <QGraphicsPixmapItem> 15 #include <QGraphicsScene> 18 #include "SegmentFactory.h" 25 DigitizeStateSegment::~DigitizeStateSegment ()
37 LOG4CPP_INFO_S ((*mainCat)) <<
"DigitizeStateSegment::begin";
39 m_cmdMediator = cmdMediator;
50 LOG4CPP_DEBUG_S ((*mainCat)) <<
"DigitizeStateSegment::cursor";
52 return QCursor (Qt::ArrowCursor);
57 LOG4CPP_INFO_S ((*mainCat)) <<
"DigitizeStateSegment::end";
67 const QString &pointIdentifier)
69 LOG4CPP_INFO_S ((*mainCat)) <<
"DigitizeStateSegment::handleContextMenuEventAxis " 70 <<
" point=" << pointIdentifier.toLatin1 ().data ();
74 const QStringList &pointIdentifiers)
76 LOG4CPP_INFO_S ((*mainCat)) <<
"DigitizeStateSegment ::handleContextMenuEventGraph " 77 <<
"points=" << pointIdentifiers.join(
",").toLatin1 ().data ();
82 LOG4CPP_INFO_S ((*mainCat)) <<
"DigitizeStateSegment::handleCurveChange";
98 QList<Segment*>::iterator itr;
99 for (itr = m_segments.begin(); itr != m_segments.end(); itr++) {
102 LOG4CPP_INFO_S ((*mainCat)) <<
"DigitizeStateSegment::handleCurveChange" 105 connect (segment, SIGNAL (signalMouseClickOnSegment (QPointF)),
this, SLOT (
slotMouseClickOnSegment (QPointF)));
113 LOG4CPP_INFO_S ((*mainCat)) <<
"DigitizeStateSegment::handleKeyPress" 114 <<
" key=" << QKeySequence (key).toString ().toLatin1 ().data ();
126 LOG4CPP_INFO_S ((*mainCat)) <<
"DigitizeStateSegment::handleMousePress";
132 LOG4CPP_INFO_S ((*mainCat)) <<
"DigitizeStateSegment::handleMouseRelease";
135 Segment *DigitizeStateSegment::segmentFromSegmentStart (
const QPointF &posSegmentStart)
const 137 LOG4CPP_INFO_S ((*mainCat)) <<
"DigitizeStateSegment::segmentFromSegmentStart" 138 <<
" segments=" << m_segments.count();
140 QList<Segment*>::const_iterator itr;
141 for (itr = m_segments.begin(); itr != m_segments.end(); itr++) {
144 if (segment->
firstPoint() == posSegmentStart) {
150 LOG4CPP_ERROR_S ((*mainCat)) <<
"DigitizeStateSegment::segmentFromSegmentStart";
151 ENGAUGE_ASSERT (
false);
157 LOG4CPP_INFO_S ((*mainCat)) <<
"DigitizeStateSegment::slotMouseClickOnSegment";
159 Segment *segment = segmentFromSegmentStart (posSegmentStart);
162 QList<Segment*> segments;
163 segments.push_back (segment);
177 QList<double> ordinals;
178 QList<QPoint>::iterator itr;
179 for (itr = points.begin(); itr != points.end(); itr++) {
191 context ().mainWindow().selectedGraphCurve(),
200 return "DigitizeStateSegment";
205 LOG4CPP_INFO_S ((*mainCat)) <<
"DigitizeStateSegment::updateAfterPointAddition";
211 LOG4CPP_INFO_S ((*mainCat)) <<
"DigitizeStateSegment::updateModelDigitizeCurve";
216 LOG4CPP_INFO_S ((*mainCat)) <<
"DigitizeStateSegment::updateModelSegments";
218 QList<Segment*>::const_iterator itr;
219 for (itr = m_segments.begin(); itr != m_segments.end(); itr++) {
QImage imageFiltered() const
Background image that has been filtered for the current curve. This asserts if a curve-specific image...
virtual void updateAfterPointAddition()
Update graphics attributes after possible new points. This is useful for highlight opacity...
void setDragMode(QGraphicsView::DragMode dragMode)
Set QGraphicsView drag mode (in m_view). Called from DigitizeStateAbstractBase subclasses.
virtual void handleMousePress(CmdMediator *cmdMediator, QPointF posScreen)
Handle a mouse press that was intercepted earlier.
virtual void updateModelSegments(const DocumentModelSegments &modelSegments)
Update the segments given the new settings.
virtual void handleContextMenuEventAxis(CmdMediator *cmdMediator, const QString &pointIdentifier)
Handle a right click, on an axis point, that was intercepted earlier.
void updateViewsOfSettings(const QString &activeCurve)
Update curve-specific view of settings. Private version gets active curve name from DigitizeStateCont...
virtual QCursor cursor(CmdMediator *cmdMediator) const
Returns the state-specific cursor shape.
virtual void handleMouseMove(CmdMediator *cmdMediator, QPointF posScreen)
Handle a mouse move. This is part of an experiment to see if augmenting the cursor in Point Match mod...
virtual void updateModelDigitizeCurve(CmdMediator *cmdMediator, const DocumentModelDigitizeCurve &modelDigitizeCurve)
Update the digitize curve settings.
QList< QPoint > fillPoints(const DocumentModelSegments &modelSegments, QList< Segment *> segments)
Return segment fill points for all segments, for previewing.
virtual QString activeCurve() const
Name of the active Curve. This can include AXIS_CURVE_NAME.
DigitizeStateContext & context()
Reference to the DigitizeStateContext that contains all the DigitizeStateAbstractBase subclasses...
void makeSegments(const QImage &imageFiltered, const DocumentModelSegments &modelSegments, QList< Segment *> &segments, bool useDlg=true)
Main entry point for creating all Segments for the filtered image.
MainWindow & mainWindow()
Reference to the MainWindow, without const.
Transformation transformation() const
Return read-only copy of transformation.
Factory class for Segment objects.
virtual void handleCurveChange(CmdMediator *cmdMediator)
Handle the selection of a new curve. At a minimum, DigitizeStateSegment will generate a new set of Se...
Model for DlgSettingsDigitizeCurve and CmdSettingsDigitizeCurve.
GraphicsScene & scene()
Scene container for the QImage and QGraphicsItems.
void clearSegments(QList< Segment *> &segments)
Remove the segments created by makeSegments.
void setCursor(CmdMediator *cmdMediator)
Update the cursor according to the current state.
Container for all DigitizeStateAbstractBase subclasses. This functions as the context class in a stan...
void appendNewCmd(CmdMediator *cmdMediator, QUndoCommand *cmd)
Append just-created QUndoCommand to command stack. This is called from DigitizeStateAbstractBase subc...
virtual void end()
Method that is called at the exact moment a state is exited. Typically called just before begin for t...
DocumentModelSegments modelSegments() const
Get method for DocumentModelSegments.
Command for adding one or more graph points. This is for Segment Fill mode.
Storage of one imported image and the data attached to that image.
Selectable piecewise-defined line that follows a filtered line in the image.
void slotMouseClickOnSegment(QPointF)
Receive signal from Segment that has been clicked on. The CmdMediator from the begin method will be u...
virtual void begin(CmdMediator *cmdMediator, DigitizeState previousState)
Method that is called at the exact moment a state is entered.
virtual void handleContextMenuEventGraph(CmdMediator *cmdMediator, const QStringList &pointIdentifiers)
Handle a right click, on a graph point, that was intercepted earlier.
virtual QString state() const
State name for debugging.
Utility class for generating ordinal numbers.
void updateModelSegment(const DocumentModelSegments &modelSegments)
Update this segment given the new settings.
int lineCount() const
Get method for number of lines.
Model for DlgSettingsSegments and CmdSettingsSegments.
QPointF firstPoint() const
Coordinates of first point in Segment.
Base class for all digitizing states. This serves as an interface to DigitizeStateContext.
Add point and line handling to generic QGraphicsScene.
QString selectedGraphCurve() const
Curve name that is currently selected in m_cmbCurve.
DigitizeStateSegment(DigitizeStateContext &context)
Single constructor.
double generateCurvePointOrdinal(const Document &document, const Transformation &transformation, const QPointF &posScreen, const QString &curveName)
Select ordinal so new point curve passes smoothly through existing points.
virtual void handleMouseRelease(CmdMediator *cmdMediator, QPointF posScreen)
Handle a mouse release that was intercepted earlier.
virtual void handleKeyPress(CmdMediator *cmdMediator, Qt::Key key, bool atLeastOneSelectedItem)
Handle a key press that was intercepted earlier.