forked from githubdoe/DFTFringe
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCircleoutline.h
More file actions
51 lines (43 loc) · 1.6 KB
/
Circleoutline.h
File metadata and controls
51 lines (43 loc) · 1.6 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
/******************************************************************************
**
** Copyright 2016 Dale Eason
** This file is part of DFTFringe
** is free software: you can redistribute it and/or modify
** it under the terms of the GNU General Public License as published by
** the Free Software Foundation version 3 of the License
** DFTFringe is distributed in the hope that it will be useful,
** but WITHOUT ANY WARRANTY; without even the implied warranty of
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
** GNU General Public License for more details.
**
** You should have received a copy of the GNU General Public License
** along with DFTFringe. If not, see <http://www.gnu.org/licenses/>.
****************************************************************************/
#ifndef CIRCLEOUTLINE_H
#define CIRCLEOUTLINE_H
#include <QJsonObject>
#include <QPainter>
#include <QPointF>
#include <QVector>
#include <opencv2/opencv.hpp>
void fillCircle(cv::Mat &m, double cx, double cy, double rad, void *color);
class CircleOutline {
public:
CircleOutline();
CircleOutline(QPointF center, double rad);
CircleOutline(QPointF p1, QPointF p2);
CircleOutline(const QJsonObject &obj);
~CircleOutline() = default;
void translate(QPointF del);
void scale(double factor);
bool isValid();
void draw(QPainter &painter, double scale, double scale2 = -1.);
QVector<QPointF> makeCircleofPoints(int cnt);
void enlarge(int del);
void toJson(QJsonObject &obj);
QPointF m_center;
double m_radius;
QPointF m_p1;
QPointF m_p2;
};
#endif // CIRCLEOUTLINE_H