在图像上绘制几何图形
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
|
#include<iostream> #include<opencv2/opencv.hpp> using namespace cv; Mat src1, dst; void drawRectangle(); void drawLine(); void drawEllipse(); void drawCircle(); void tsxt(); int main() { src1 = imread( "E:/image/image/daibola.jpg" ); dst = src1.clone(); if (src1.empty()) { printf ( "can not load image \n" ); return -1; } drawRectangle(); drawLine(); drawEllipse(); drawCircle(); tsxt(); cvNamedWindow( "output" , CV_WINDOW_AUTOSIZE); imshow( "output" , dst); waitKey(); return 0; } void drawRectangle() { Rect rect = Rect(150,30,250,250); Scalar color = Scalar(0,255,255); rectangle(dst,rect,Scalar(0,255,255),2); } void drawLine() { line(dst, Point(450,0),Point(450,150),Scalar(255,0,50),2); } void drawEllipse() { ellipse(dst,Point(100,100),Size(50,90),0.0,0.0,360,Scalar(255,255,0),2); } void drawCircle() { circle(dst,Point(100,100),60,Scalar(255,0,255),2); } void tsxt() { putText(dst, "Image" ,Point(300,330),5,3.0,Scalar(255,0,90),2); } |
随机绘制大小不等的圆:
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
|
#include<opencv2/opencv.hpp> using namespace cv; Mat dst, src1; void randomCircle(); int main() { src1 = imread( "E:/image/image/daibola.jpg" ); dst = Mat::zeros(src1.size(),src1.type()); randomCircle(); return 0; } void randomCircle() { RNG rng(0); Point p1; int r; for ( int i =0; i < 10000; i++) { p1.x = rng.uniform(0, dst.cols); p1.y = rng.uniform(0, dst.rows); r = rng.uniform(0, dst.rows/3); Scalar color = Scalar(rng.uniform(0,255), rng.uniform(0, 255), rng.uniform(0, 255)); if (waitKey(100) > 0) { break ; } circle(dst,p1,r,color,2); imshow( "circle" , dst); } } |
以上这篇opencv3/C++绘制几何图形实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/akadiao/article/details/78837419