本篇内容介绍了“如何使用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绘制图形旋转矩形”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。