使用c++實現OpenCV繪制圖形旋轉矩形

功能函數

// 繪制旋轉矩形
void DrawRotatedRect(cv::Mat mask,const cv::RotatedRect &rotatedrect,const cv::Scalar &color,int thickness, int lineType)
{
    // 提取旋轉矩形的四個角點
	cv::Point2f ps[4];
	rotatedrect.points(ps); 
    // 構建輪廓線
	std::vector<std::vector<cv::Point>> tmpContours;    // 創建一個InputArrayOfArrays 類型的點集
	std::vector<cv::Point> contours;
	for (int i = 0; i != 4; ++i) {
		contours.emplace_back(cv::Point2i(ps[i]));
	}
	tmpContours.insert(tmpContours.end(), contours); 
    // 繪制輪廓,即旋轉矩形
	drawContours(mask, tmpContours, 0, color,thickness, lineType);  // 填充mask
}

測試代碼

#include <iostream>
#include <opencv2/opencv.hpp>
using namespace std;
using namespace cv;
void DrawRotatedRect(cv::Mat mask, const cv::RotatedRect &rotatedrect, const cv::Scalar &color,int thickness, int lineType); 
int main()
{
	cv::Mat src = imread("test.jpg");
	cv::Mat result = src.clone();
	cv::RotatedRect rorect(cv::Point(src.cols / 2, src.rows / 2), cv::Size(1000, 800), 50);
	DrawRotatedRect(result, rorect, cv::Scalar(0, 255, 255), 5,16);
	imshow("original", src);
	imshow("result", result);
	waitKey(0);
	return 0;
}
// 繪制旋轉矩形
void DrawRotatedRect(cv::Mat mask,const cv::RotatedRect &rotatedrect,const cv::Scalar &color,int thickness, int lineType)
{
          // 提取旋轉矩形的四個角點
	cv::Point2f ps[4];
	rotatedrect.points(ps);
          // 構建輪廓線
  	std::vector<std::vector<cv::Point>> tmpContours;    
          // 創建一個InputArrayOfArrays 類型的點集
	std::vector<cv::Point> contours;
	for (int i = 0; i != 4; ++i) {
		contours.emplace_back(cv::Point2i(ps[i]));
	}
	tmpContours.insert(tmpContours.end(), contours);

           // 繪制輪廓,即旋轉矩形
	drawContours(mask, tmpContours, 0, color,thickness, lineType);  // 填充mask
}

測試效果 

圖1 原圖

圖2 繪制旋轉矩形

繪制旋轉矩形首先需要得到旋轉矩形的位置坐標,我經常配合cv::minAreaRect函數使用;

得到坐標信息後,結合繪制輪廓線的drawContours函數,即可完成。

以上就是使用c++實現OpenCV繪制圖形旋轉矩形的詳細內容,更多關於c++實現OpenCV繪制的資料請關註WalkonNet其它相關文章!

推薦閱讀: