forked from bsdnoobz/opencv-code
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathstraighten-img.cpp
More file actions
83 lines (72 loc) · 1.77 KB
/
straighten-img.cpp
File metadata and controls
83 lines (72 loc) · 1.77 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
/*
straighten-img.cpp
Draw a line on an image and the image rotates so that the line is horizontal
Author: Nash
Website: http://opencv-code.com/tutorials/straighten-up-an-image/
Usage:
1. Click to set the start point.
2. Drag your mouse.
3. Click to set the end point.
4. The corrected image will be displayed.
5. Click the original image again to restart.
6. Press 'q' to quit.
*/
#include <opencv2/imgproc/imgproc.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <cmath>
#include <iostream>
cv::Mat im0, im1;
std::vector<cv::Point> pt;
void straighten_image(std::vector<cv::Point> pt)
{
double angle = std::atan((double)(pt[0].y - pt[1].y) /
(pt[0].x - pt[1].x)) *
(180 / CV_PI);
cv::Point2f center(im0.cols/2., im0.rows/2.);
cv::Mat dst, r = cv::getRotationMatrix2D(center, angle, 1.0);
cv::warpAffine(im0, dst, r, im0.size());
cv::imshow("dst", dst);
cv::imwrite("src.jpg", im1);
cv::imwrite("dst.jpg", dst);
}
void on_mouse(int event, int x, int y, int flags, void* param)
{
if (event == CV_EVENT_LBUTTONDOWN)
{
switch (pt.size())
{
case 0:
pt.push_back(cv::Point(x,y));
break;
case 1:
pt.push_back(cv::Point(x,y));
straighten_image(pt);
break;
case 2:
im1 = im0.clone();
pt.clear();
break;
}
}
else if (event == CV_EVENT_MOUSEMOVE && pt.size() == 1)
{
im1 = im0.clone();
cv::line(im1, pt[0], cv::Point(x,y), CV_RGB(255,0,0), 2);
}
if (im1.data)
cv::imshow("src", im1);
}
int main()
{
im0 = cv::imread("lena.png");
if (!im0.data)
{
std::cout << "Cannot load source image!" << std::endl;
return -1;
}
cv::namedWindow("src", CV_WINDOW_AUTOSIZE);
cv::setMouseCallback("src", on_mouse, 0);
cv::imshow("src", im0);
cv::waitKey();
return 0;
}