-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlabelimage.h
89 lines (70 loc) · 2.45 KB
/
labelimage.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
#ifndef LABELIMAGE_H
#define LABELIMAGE_H
#include <QGraphicsObject>
#include <QImage>
#include "labelwidget.h"
#include <set>
#include <opencv2/flann/miniflann.hpp>
class EndPoint;
class Action;
class LabelImage : public QGraphicsObject
{
Q_OBJECT
public:
LabelImage(LabelWidget *labelWidget, const cv::Mat& image);
~LabelImage();
void addEdges(const cv::Mat& image);
void buildKD();
void searchNN(const QPointF& pos, EdgeItem*& pEdge, int& localIndex);
void searchNN(const QPointF& pos, EdgeItem*& pEdge);
void updateNNMask(EdgeItem* pEdge);
QPointF item2image(const QPointF& pos);
QPointF image2item(const QPointF& pos);
EdgeItem* currEdge();
void splitEdge();
void performSplitEdge(EdgeItem* oldEdge, EdgeItem* newEdge1, EdgeItem* newEdge2);
void reverseSplitEdge(EdgeItem* oldEdge, EdgeItem* newEdge1, EdgeItem* newEdge2);
void addAction(Action* act);
void reverseAction();
void redoAction();
void toggleCreateMode();
bool inCreateMode();
void enterCreateMode();
void exitCreateMode();
void addStrayPoint(EndPoint* point);
void removeStrayPoint(EndPoint* point);
void addConnection(EndPoint* point1, EndPoint* point2);
void removeConnection(EndPoint* point1, EndPoint* point2);
EndPoint* getConnectPoint();
void updateConnectPoint(EndPoint* point);
QRectF boundingRect() const override;
void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget) override;
void hoverMoveEvent(QGraphicsSceneHoverEvent *event) override;
void hoverEnterEvent(QGraphicsSceneHoverEvent *event) override;
void hoverLeaveEvent(QGraphicsSceneHoverEvent *event) override;
void mousePressEvent(QGraphicsSceneMouseEvent *event) override;
private:
QImage qimage;
LabelWidget* parent;
std::set<EdgeItem*> pEdges;
EdgeItem* pCurrEdge;
// for hovering
QPointF mousePos;
cv::flann::Index* kdtree;
std::vector<cv::Point2f> edgePoints;
std::map<int, EdgeItem*> ind2edge;
std::map<EdgeItem*, int> edge2ind;
std::map<int, int> global2local;
std::map<int, bool> pointMask;
double radiusNN;
// action queue
unsigned int maxActionListSize;
std::list<Action*> actionList;
std::list<Action*> redoList;
// create mode
bool createMode;
EndPoint* pConnectPoint;
std::set<EndPoint*> pStrayPoints;
std::vector<std::pair<EndPoint*,EndPoint*>> connections;
};
#endif // LABELIMAGE_H