使用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 }
測試效果
繪制旋轉矩形首先需要得到旋轉矩形的位置坐標,我經常配合cv::minAreaRect
函數使用;
得到坐標信息後,結合繪制輪廓線的drawContours
函數,即可完成。
以上就是使用c++實現OpenCV繪制圖形旋轉矩形的詳細內容,更多關於c++實現OpenCV繪制的資料請關註WalkonNet其它相關文章!