-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmainwindow.h
More file actions
104 lines (91 loc) · 2.97 KB
/
mainwindow.h
File metadata and controls
104 lines (91 loc) · 2.97 KB
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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
#ifndef MAINWINDOW_H
#define MAINWINDOW_H
#include "chart.h"
#include "imageitem.h"
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
#include <opencv2/videoio/videoio.hpp>
#include <opencv2/video/tracking.hpp>
#include <QDebug>
#include <QChartView>
#include <QMainWindow>
#include <QWidget>
#include <QFile>
#include <QFileDialog>
#include <QGraphicsScene>
#include <QImage>
#include <QPen>
#include <QPixmap>
#include <QString>
#include <QTableWidgetItem>
#include <string>
typedef std::vector<cv::Point> Contour;
typedef std::vector<Contour> ContourList;
typedef std::vector<ContourList> ContourListSet;
typedef std::vector<cv::Vec<int, 4>> Hierarchy;
typedef std::vector<Hierarchy> HierarchyListSet;
typedef std::vector<cv::Scalar> ColorList;
//typedef std::vector<std::vector<cv::Vec<int, 4>>> HierarchyListSet;
namespace Ui {
class MainWindow;
}
class MainWindow : public QMainWindow
{
Q_OBJECT
public:
cv::Mat current_frame;
cv::Mat blurred_frame;
cv::Rect2d roi;
explicit MainWindow(QWidget *parent = 0);
~MainWindow();
public slots:
void showMousePosition(QPointF& pos);
//void showClosestContour(QPointF& pos);
void updateInset(QPointF& pos);
void showSelectedContours(QRect& selection);
void deselectAll();
private slots:
void resizeEvent(QResizeEvent *event);
void on_frameSpinBox_valueChanged(int arg1);
void on_action_Open_triggered();
void on_contourTable_itemSelectionChanged();
void on_contourTable_currentCellChanged(int row, int column, int previous_row, int previous_column);
void on_deleteContourButton_clicked();
void on_findContoursButton_clicked();
void on_contoursCheckBox_stateChanged(int arg1);
void on_centroidsCheckBox_stateChanged(int arg1);
void on_actionSave_to_CSV_triggered();
void on_mainTabs_currentChanged(int index);
void on_trackingApplyButton_clicked();
void on_blurSpinBox_valueChanged(int arg1);
void on_thresholdSpinBox_valueChanged(int arg1);
void on_trackBlurSpinBox_valueChanged(int arg1);
private:
Ui::MainWindow *ui;
std::string video_filepath;
cv::VideoCapture cap;
std::vector<std::tuple<int, double>> ctr_matches;
std::vector<std::vector<cv::Point>> frame_centroids;
ContourListSet frame_contours;
HierarchyListSet frame_hierarchies;
ColorList contour_colors;
std::vector<int> active_contours;
QImage img;
QGraphicsScene *scene;
ImageItem *image_item;
Chart *chart;
QChartView *chart_view;
int blur;
int threshold;
void removeAllSceneEllipses();
void removeAllSceneLines();
void drawCrosshair(int x, int y, QColor color=QColor(50,205,50,100));
void savePointsToCSV(QString filename);
void updateAllContours();
void drawAllContours(int frame_index);
void showCannyFrame(int frame_index);
cv::Point getMeanPoint(const Contour contour);
cv::Point getCenterOfMass(const Contour contour);
};
#endif // MAINWINDOW_H