OpenCV基本图形绘制

113 篇文章 1 订阅

#include"OpenCVLib.hpp"
using namespace cv;

#define WINDOW_NAME1 "IMAGE 1"
#define WINDOW_NAME2 "IMAGE 2"
#define WINDOW_WIDTH 600


void DrawEllipse(Mat img,double angle){
    int thickness = 2;
    int lineType = 8;
    ellipse(img,
    Point(WINDOW_WIDTH/2,WINDOW_WIDTH/2),
    Size(WINDOW_WIDTH/4,WINDOW_WIDTH/16),
        angle,
        0,
        360,
        Scalar(255,129,0),
        thickness,
        lineType
        );

}
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,3*WINDOW_WIDTH/8);
    rookPoints[0][17] = Point(13*WINDOW_WIDTH/32,3*WINDOW_WIDTH/8);
    rookPoints[0][18] = Point(5*WINDOW_WIDTH/16,13*WINDOW_WIDTH/16);
    rookPoints[0][19] = Point(WINDOW_WIDTH/4,13*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);
}


int main(){
    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;


}










评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值