00001
00002
00003
00004
00005
00006
00007 #ifndef DIGITIZE_STATE_POINT_MATCH_H
00008 #define DIGITIZE_STATE_POINT_MATCH_H
00009
00010 #include "DigitizeStateAbstractBase.h"
00011 #include "PointMatchPixel.h"
00012 #include <QList>
00013 #include <QPoint>
00014
00015 class DocumentModelPointMatch;
00016 class QGraphicsEllipseItem;
00017 class QGraphicsPixmapItem;
00018 class QImage;
00019
00021 class DigitizeStatePointMatch : public DigitizeStateAbstractBase
00022 {
00023 public:
00025 DigitizeStatePointMatch(DigitizeStateContext &context);
00026 virtual ~DigitizeStatePointMatch();
00027
00028 virtual QString activeCurve () const;
00029 virtual void begin(CmdMediator *cmdMediator,
00030 DigitizeState previousState);
00031 virtual QCursor cursor (CmdMediator *cmdMediator) const;
00032 virtual void end();
00033 virtual void handleContextMenuEventAxis (CmdMediator *cmdMediator,
00034 const QString &pointIdentifier);
00035 virtual void handleContextMenuEventGraph (CmdMediator *cmdMediator,
00036 const QStringList &pointIdentifiers);
00037 virtual void handleCurveChange(CmdMediator *cmdMediator);
00038 virtual void handleKeyPress (CmdMediator *cmdMediator,
00039 Qt::Key key,
00040 bool atLeastOneSelectedItem);
00041 virtual void handleMouseMove (CmdMediator *cmdMediator,
00042 QPointF posScreen);
00043 virtual void handleMousePress (CmdMediator *cmdMediator,
00044 QPointF posScreen);
00045 virtual void handleMouseRelease (CmdMediator *cmdMediator,
00046 QPointF posScreen);
00047 virtual QString state() const;
00048 virtual void updateAfterPointAddition ();
00049 virtual void updateModelDigitizeCurve (CmdMediator *cmdMediator,
00050 const DocumentModelDigitizeCurve &modelDigitizeCurve);
00051 virtual void updateModelSegments(const DocumentModelSegments &modelSegments);
00052
00053 private:
00054 DigitizeStatePointMatch();
00055
00056 void createPermanentPoint (CmdMediator *cmdMediator,
00057 const QPointF &posScreen);
00058 void createTemporaryPoint (CmdMediator *cmdMediator,
00059 const QPoint &posScreen);
00060 QList<PointMatchPixel> extractSamplePointPixels (const QImage &img,
00061 const DocumentModelPointMatch &modelPointMatch,
00062 const QPointF &posScreen) const;
00063 void findPointsAndShowFirstCandidate (CmdMediator *cmdMediator,
00064 const QPointF &posScreen);
00065 bool pixelIsOnInImage (const QImage &img,
00066 int x,
00067 int y,
00068 int radiusLimit) const;
00069 void popCandidatePoint (CmdMediator *cmdMediator);
00070 void promoteCandidatePointToPermanentPoint(CmdMediator *cmdMediator);
00071
00072 QGraphicsEllipseItem *m_outline;
00073 QGraphicsPixmapItem *m_candidatePoint;
00074
00075
00076
00077 QList<QPoint> m_candidatePoints;
00078
00079 QPoint m_posCandidatePoint;
00080 };
00081
00082 #endif // DIGITIZE_STATE_POINT_MATCH_H