OpenCV笔记(二十九)轮廓周围绘制矩形框和圆形框

一、相关API

1.approxPolyDP

基于RDP算法实现,目的是减少多边形轮廓点数

approxPolyDP(
    InputArray  curve, 
    OutputArray approxCurve,  
    double  epsilon,  
    bool  closed)

2.boundingRect

得到轮廓周围最小矩形左上交点坐标和右下角点坐标,绘制一个矩形

cv::boundingRect(InputArray points)

3.minAreaRect

得到一个旋转的矩形,返回旋转矩形

cv::minAreaRect(InputArray  points)

4.minEnclosingCircle

轮廓周围绘制圆

cv::minEnclosingCircle(InputArray points, //得到最小区域圆形
	Point2f& center, // 圆心位置

5.fitEllipse

轮廓周围绘制椭圆

cv::fitEllipse(InputArray  points)得到最小椭圆

二、处理步骤

  1. 首先将图像变为二值图像
  2. 发现轮廓,找到图像轮廓
  3. 通过相关API在轮廓点上找到最小包含矩形和圆,旋转矩形与椭圆。
  4. 绘制它们。

三、综合例程

#include <opencv2/opencv.hpp>
#include <iostream>
#include <math.h>

using namespace std;
using namespace cv;
Mat src, gray_src, drawImg;
int threshold_v = 170;
int threshold_max = 255;
const char* output_win = "rectangle-demo";
RNG rng(12345);
void Contours_Callback(int, void*);
int main(int argc, char** argv) {
	src = imread("D:/vcprojects/images/hotball.png");
	if (!src.data) {
		printf("could not load image...\n");
		return -1;
	}
	cvtColor(src, gray_src, CV_BGR2GRAY);
	blur(gray_src, gray_src, Size(3, 3), Point(-1, -1));
	
	const char* source_win = "input image";
	namedWindow(source_win, CV_WINDOW_AUTOSIZE);
	namedWindow(output_win, CV_WINDOW_AUTOSIZE);
	imshow(source_win, src);

	createTrackbar("Threshold Value:", output_win, &threshold_v, threshold_max, Contours_Callback);
	Contours_Callback(0, 0);

	waitKey(0);
	return 0;
}

void Contours_Callback(int, void*) {
	Mat binary_output;
	vector<vector<Point>> contours;
	vector<Vec4i> hierachy;
	threshold(gray_src, binary_output, threshold_v, threshold_max, THRESH_BINARY);
	//imshow("binary image", binary_output);
	findContours(binary_output, contours, hierachy, RETR_TREE, CHAIN_APPROX_SIMPLE, Point(-1, -1));

	vector<vector<Point>> contours_ploy(contours.size());
	vector<Rect> ploy_rects(contours.size());
	vector<Point2f> ccs(contours.size());
	vector<float> radius(contours.size());

	vector<RotatedRect> minRects(contours.size());
	vector<RotatedRect> myellipse(contours.size());

	for (size_t i = 0; i < contours.size(); i++) {
		approxPolyDP(Mat(contours[i]), contours_ploy[i], 3, true);
		ploy_rects[i] = boundingRect(contours_ploy[i]);
		minEnclosingCircle(contours_ploy[i], ccs[i], radius[i]);
		if (contours_ploy[i].size() > 5) {
			myellipse[i] = fitEllipse(contours_ploy[i]);
			minRects[i] = minAreaRect(contours_ploy[i]);
		}
	}

	// draw it
	drawImg = Mat::zeros(src.size(), src.type());
	Point2f pts[4];
	for (size_t t = 0; t < contours.size(); t++) {
		Scalar color = Scalar(rng.uniform(0, 255), rng.uniform(0, 255), rng.uniform(0, 255));
		//rectangle(drawImg, ploy_rects[t], color, 2, 8);
		//circle(drawImg, ccs[t], radius[t], color, 2, 8);
		if (contours_ploy[t].size() > 5) {
			ellipse(drawImg, myellipse[t], color, 1, 8);
			minRects[t].points(pts);
			for (int r = 0; r < 4; r++) {
				line(drawImg, pts[r], pts[(r + 1) % 4], color, 1, 8);
			}
		}
	}

	imshow(output_win, drawImg);
	return;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 使用Python OpenCV绘制矩形框的方法如下: 1. 导入OpenCV库 ``` import cv2 ``` 2. 读取图像 ``` img = cv2.imread('image.jpg') ``` 3. 定义矩形框的位置和大小 ``` x, y, w, h = 100, 100, 200, 200 ``` 4. 绘制矩形框 ``` cv2.rectangle(img, (x, y), (x+w, y+h), (0, 255, 0), 2) ``` 其中,第一个参数是要绘制矩形框的图像,第二个参数是矩形框的左上角坐标,第三个参数是矩形框的右下角坐标,第四个参数是矩形框的颜色,第五个参数是矩形框的线宽。 5. 显示图像 ``` cv2.imshow('image', img) cv2.waitKey(0) cv2.destroyAllWindows() ``` 完整代码如下: ``` import cv2 img = cv2.imread('image.jpg') x, y, w, h = 100, 100, 200, 200 cv2.rectangle(img, (x, y), (x+w, y+h), (0, 255, 0), 2) cv2.imshow('image', img) cv2.waitKey(0) cv2.destroyAllWindows() ``` ### 回答2: Python中的OpenCV库是许多计算机视觉和图像处理项目的首选库之一。绘制矩形框OpenCV库中的一项非常常见的操作。以下是使用Python和OpenCV绘制矩形框的步骤。 1. 安装OpenCV库: 在Python环境下安装OpenCV库,最简单的方法是使用pip命令。 可以在终端窗口中使用以下命令安装OpenCV库: `pip install opencv-python` 2. 导入OpenCV库和其他必要的库: 在Python代码中,需要导入以下库: ``` import cv2 import numpy as np ``` 3. 读取图像: 使用OpenCV库的imread()函数读取所需的图像。例如: ``` img = cv2.imread("image.jpg") ``` 4. 绘制矩形框: 使用cv2.rectangle()函数绘制矩形框。此函数需要以下参数: ``` cv2.rectangle(image, start_point, end_point, color, thickness) ``` - image:原始图像。 - start_point: 矩形的左上角坐标。 - end_point: 矩形的右下角坐标。 - color: 矩形框的颜色。 - thickness: 矩形框的线条粗细。(如果为负数,则矩形框将填充为所选颜色。) 例如,为以下图像绘制一个矩形框: ![image](https://user-images.githubusercontent.com/60111143/132330100-8268d4cd-c52e-4a62-a9fd-b991dbd6bdae.png) 代码如下: ``` img = cv2.imread("image.jpg") start_point = (120, 120) end_point = (500, 500) color = (255, 0, 0) # 蓝色 thickness = 5 cv2.rectangle(img, start_point, end_point, color, thickness) cv2.imshow("Image with rectange", img) cv2.waitKey(0) cv2.destroyAllWindows() ``` 输出结果如下图所示: ![image](https://user-images.githubusercontent.com/60111143/132330285-51be0b5d-6771-4238-99f3-5f96d183ca6e.png) 5. 显示图像: 使用cv2.imshow()函数显示结果图像。此函数需要以下参数: ``` cv2.imshow(window_name, image) ``` - window_name: 窗口的名称(一个字符串)。 - image: 想要显示的图像或帧。 6. 键盘绑定: 使用cv2.waitKey()函数等待键盘上的任何键被按下。如果在等待期间未按下任何键,操作将退出并关闭窗口。此函数需要一个整数参数,表示等待时间(以毫秒为单位)。 7. 销毁窗口: 使用cv2.destroyAllWindows()函数,关闭并销毁所有打开的窗口。 上述步骤中的代码示例可以在Python中成功绘制矩形框,并展示在窗口中。可以通过对start_point和end_point的值进行更改,调整矩形框的大小和位置,然后再次运行代码即可。 ### 回答3: Python是一种强大的编程语言,广泛应用于科学技术领域中的数据分析、机器学习、人工智能等方面。而OpenCV是一个专业用于计算机视觉的开源库,为Python提供了一系列强大的图像处理功能,大大简化了图像处理的操作。 绘制矩形框OpenCV中的一个常用操作,可以用于图像分析、目标检测等领域。在Python中使用OpenCV绘制矩形框,有以下几种方法: 1. 使用cv2.rectangle()函数。该函数的参数包括:图像、矩形框的左上角坐标、矩形框的右下角坐标、颜色、线条粗细等。例如,以下代码可以在图像中画出一个左上角坐标为(50, 50),右下角坐标为(150, 150)的红色矩形框。 import cv2 img = cv2.imread('test.jpg') cv2.rectangle(img, (50, 50), (150, 150), (0, 0, 255), 2) cv2.imshow('image', img) cv2.waitKey(0) cv2.destroyAllWindows() 2. 使用matplotlib库的pyplot模块。Matplotlib是Python中一个非常流行的绘图库,它可以实现可视化效果。在使用pyplot绘制矩形框时,需要先将OpenCV读入的图像转为RGB格式。例如,以下代码同样可以在图像中画出一个左上角坐标为(50, 50),右下角坐标为(150, 150)的红色矩形框。 import cv2 from matplotlib import pyplot as plt img = cv2.imread('test.jpg') img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB) plt.imshow(img) plt.gca().add_patch(plt.Rectangle((50, 50), 100, 100, edgecolor='r', fill=None, linewidth=2)) plt.show() 3. 使用Pillow库。Pillow是Python中非常好用的图像处理库,可以实现图像的读取、保存、转换等功能。使用Pillow绘制矩形框时,需要先将OpenCV读入的图像转为Pillow格式。例如,以下代码同样可以在图像中画出一个左上角坐标为(50, 50),右下角坐标为(150, 150)的红色矩形框。 import cv2 from PIL import Image, ImageDraw img = cv2.imread('test.jpg') img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB) img = Image.fromarray(img) draw = ImageDraw.Draw(img) draw.rectangle((50, 50, 150, 150), outline='red', width=2) img.show() 综上所述,Python使用OpenCV绘制矩形框的方法有多种,开发者可以根据实际需求灵活选择。无论使用哪种方法,都需要注意矩形框的大小、颜色、线条粗细等参数设置,以达到最佳的视觉效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值