opencv3学习之绘图基础

#define WINDOW_WIDTH 600

#define WINDOW_NAME1 "绘图1"

#define WINDOW_NAME2 "绘图2"

#include <opencv2/opencv.hpp>

#include <opencv2/core/core.hpp>

#include <opencv2/highgui/highgui.hpp>

#include <opencv2/imgproc/imgproc.hpp>

using namespace cv;

void DrawEllipse(Mat img,double angle){

    int thickness=2;//线宽为2

    int linetype=8;//线型为8--联通线型

    ellipse(img, Point(WINDOW_WIDTH/2,WINDOW_WIDTH/2), Size(WINDOW_WIDTH/4,WINDOW_WIDTH/16),angle, 0, 360, Scalar(255,199,0),thickness,linetype);

    //ellipse是一个绘制图像的opencv函数,将绘制好的图像存放到img中,第一个参数是存放图像的名称,第二个参数表示从整个窗口的中心点开始绘制,第三个参数表示绘制图像的大小,是一个矩形区域,第456参数表示旋转角度,扩展弧度从0360度,第7个参数表示颜色,这里是蓝色,注:Scalar函数的顺序是BGR而不是RGB。第8个参数是线宽,第9个参数是线的类型。

}

void DrawFilledCircle(Mat img,Point center){

    int thickness=-1;

    int linetype=8;

    circle(img, center, WINDOW_WIDTH/32, Scalar(0,0,255),thickness,linetype);//绘制一个红色的实心圆

}

void DrawPolygon(Mat img){

    int linetype=8;

    Point rookPoints[1][20];

    rookPoints[0][0]=Point(WINDOW_WIDTH/4,7*WINDOW_WIDTH/8);

    rookPoints[0][1]=Point(3*WINDOW_WIDTH/4,7*WINDOW_WIDTH/8);

    rookPoints[0][2]=Point(3*WINDOW_WIDTH/4,13*WINDOW_WIDTH/16);

    rookPoints[0][3]=Point(11*WINDOW_WIDTH/16,13*WINDOW_WIDTH/16);

    rookPoints[0][4]=Point(19*WINDOW_WIDTH/32,3*WINDOW_WIDTH/8);

    rookPoints[0][5]=Point(3*WINDOW_WIDTH/4,3*WINDOW_WIDTH/8);

    rookPoints[0][6]=Point(3*WINDOW_WIDTH/4,WINDOW_WIDTH/8);

    rookPoints[0][7]=Point(26*WINDOW_WIDTH/40,WINDOW_WIDTH/8);

    rookPoints[0][8]=Point(26*WINDOW_WIDTH/40,WINDOW_WIDTH/4);

    rookPoints[0][9]=Point(22*WINDOW_WIDTH/40,WINDOW_WIDTH/4);

    rookPoints[0][10]=Point(22*WINDOW_WIDTH/40,WINDOW_WIDTH/8);

    rookPoints[0][11]=Point(18*WINDOW_WIDTH/40,WINDOW_WIDTH/8);

    rookPoints[0][12]=Point(18*WINDOW_WIDTH/40,WINDOW_WIDTH/4);

    rookPoints[0][13]=Point(14*WINDOW_WIDTH/40,WINDOW_WIDTH/4);

    rookPoints[0][14]=Point(14*WINDOW_WIDTH/40,WINDOW_WIDTH/8);

    rookPoints[0][15]=Point(WINDOW_WIDTH/4,WINDOW_WIDTH/8);

    rookPoints[0][16]=Point(WINDOW_WIDTH/4,WINDOW_WIDTH/8);

    rookPoints[0][17]=Point(13*WINDOW_WIDTH/32,WINDOW_WIDTH/8);

    rookPoints[0][18]=Point(5*WINDOW_WIDTH/16,WINDOW_WIDTH/16);

    rookPoints[0][19]=Point(WINDOW_WIDTH/4,WINDOW_WIDTH/16);

    const Point* ppt[1]={rookPoints[0]};

    int npt[]={20};

    fillPoly(img, ppt, npt, 1, Scalar(255,255,255),linetype);

}

void DrawLine(Mat img,Point start,Point end){

    int thickness=2;

    int linetype=8;

    line(img, start, end, Scalar(0,0,0),thickness,linetype);//img上画一条从点start到点end的黑色直线段

}

int main(void){

    //创建空白的Mat图像

    Mat atomImage=Mat::zeros(WINDOW_WIDTH, WINDOW_WIDTH, CV_8UC3);

    Mat rookImage=Mat::zeros(WINDOW_WIDTH, WINDOW_WIDTH, CV_8UC3);

    //画椭圆

    DrawEllipse(atomImage, 90);

    DrawEllipse(atomImage, 0);

    DrawEllipse(atomImage, 45);

    DrawEllipse(atomImage, -45);

    

    //绘制圆心

    DrawFilledCircle(atomImage, Point(WINDOW_WIDTH/2,WINDOW_WIDTH/2));

    

    //绘制椭圆

    DrawPolygon(rookImage);

    

    //矩形

    rectangle(rookImage, Point(0,7*WINDOW_WIDTH/8), Point(WINDOW_WIDTH,WINDOW_WIDTH), Scalar(0,255,255),-1,8);

    //绘制线段

    DrawLine(rookImage,Point(0,15*WINDOW_WIDTH/16), Point(WINDOW_WIDTH,15*WINDOW_WIDTH/16));

    DrawLine(rookImage,Point(WINDOW_WIDTH/4,7*WINDOW_WIDTH/8), Point(WINDOW_WIDTH/4,WINDOW_WIDTH));

    DrawLine(rookImage,Point(WINDOW_WIDTH/2,7*WINDOW_WIDTH/8), Point(WINDOW_WIDTH/2,WINDOW_WIDTH));

    DrawLine(rookImage,Point(3*WINDOW_WIDTH/4,7*WINDOW_WIDTH/8), Point(3*WINDOW_WIDTH/4,WINDOW_WIDTH));

    

    

    

    //显示

    imshow(WINDOW_NAME1, atomImage);

    moveWindow(WINDOW_NAME1, 0, 200);

    imshow(WINDOW_NAME2, rookImage);

    moveWindow(WINDOW_NAME2, WINDOW_WIDTH, 200);

    

    waitKey(0);

    return 0;

}
















  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以参考OpenCV-Python的官方教程来学习如何使用OpenCV-Python。教程中使用了Numpy作为依赖项,并推荐使用Matplotlib和IPython进行绘图和交互式编程。教程还会不断扩展,如果你熟悉某个特定的算法,并且能够编写一个教程,包括算法的基本理论和示例代码,可以参与到项目中来。此外,还提供了一些附加资源,包括Python快速指南、Numpy基础教程、Numpy示例列表、OpenCV文档和OpenCV论坛。在Windows中安装OpenCV-Python也有相应的指南可供参考。总的来说,OpenCV-Python教程适合用于Python原型开发,并介绍了如何在Python中使用OpenCV图形库以及与C调用相应OpenCV函数的不同之处。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [OpenCV-Python (官方)中文教程(部分一)](https://blog.csdn.net/Thomson617/article/details/103956799)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [OpenCV-Python教程(11、轮廓检测)](https://blog.csdn.net/sunny2038/article/details/12889059)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值