-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmeasuring.h
More file actions
74 lines (56 loc) · 1.81 KB
/
measuring.h
File metadata and controls
74 lines (56 loc) · 1.81 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
#ifndef MEASURING_H
#define MEASURING_H
#include "qcustomplot.h"
#include <QGuiApplication>
#include <QDialog>
#include <QtGui>
#include <QtCore>
#include <QPixmap>
#include <QImage>
#include <QLine>
#include <QLabel>
#include <QPainter>
#include <QWidget>
#include <opencv2/opencv.hpp>
#include <opencv2/imgproc/imgproc.hpp>
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
namespace Ui {
class measuring;
}
class measuring : public QDialog
{
Q_OBJECT
public:
explicit measuring(QWidget *parent = 0);
bool mousePressed;
bool drawStarted;
QString operation; // "linear" and "circle"
~measuring();
private:
Ui::measuring *ui;
cv::Mat image,blur_img; //blur_img : use in Guassian Smooth
QLine mLine;
QPixmap mPix,linePix,offsetPix,pointPix,tmp_pix;
protected:
void mousePressEvent(QMouseEvent *event);
void mouseMoveEvent(QMouseEvent *event);
void mouseReleaseEvent(QMouseEvent *event);
std::vector<double> linspace(double a, double b, int n) ;
std::vector<cv::Point3i> ffSlope(std::vector<double> smoothX,std::vector<double> smoothY,int lengthAmpi);
void findPeak(std::vector<double> &smoothY,std::vector<double> &outputX,std::vector<double> &outputY,int distanceAmpi);
private slots:
void on_showImg_clicked();
void on_showGraph_clicked();
void on_smoothSlider_valueChanged(int value);
void on_amplitudeSlider_valueChanged(int value);
void on_offsetVal_valueChanged(int value);
void on_offsetNum_valueChanged(int value);
void on_resultLine_clicked();
void on_line_operation_toggled(bool checked);
void on_circle_operation_toggled(bool checked);
void on_circle_offsetDeg_valueChanged(int value);
void on_circle_offsetNum_valueChanged(int value);
void on_resultCircle_clicked();
};
#endif // MEASURING_H