亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

OpenCV如何繪制同心圓

發布時間:2021-08-31 10:30:29 來源:億速云 閱讀:198 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關OpenCV如何繪制同心圓,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

功能函數

// 繪制同心圓
void DrawConcentricCircle(cv::Mat mask, const cv::Point2i &center, int radius1,int radius2, const cv::Scalar &color, int thickness,int linetype)
{
	// 創建畫布
	cv::Mat canvas = cv::Mat::zeros(mask.size(), CV_8UC1);
 
	// 計算內徑和外徑
	int inradius = min(radius1, radius2);
	int outradius = max(radius1, radius2);
 
	// 分情況討論
	// 當thickness大于0時,繪制的是兩個圓型線條組成的同心圓,不需填充
	if (thickness > 0)
	{
		cv::circle(mask, center, outradius, color, thickness, linetype);
		cv::circle(mask, center, inradius, color, thickness, linetype);
	}
	// 當thickness小于0,一般為-1,繪制的是填充同心圓,內圓不能有填充色
	else {
		cv::circle(canvas, center, outradius, cv::Scalar(255), -1, linetype);
		cv::circle(canvas, center, inradius, cv::Scalar(0), -1, linetype);
		int row = mask.rows;
		int col = mask.cols;
		for (int i = 0; i < row; ++i)
		{
			for (int j = 0; j < col; ++j)
			{
				uchar *m = canvas.ptr<uchar>(i);
				if (m[j] == 255)
				{
					mask.at<Vec3b>(i, j)[0] = static_cast<uchar>(color[0]);
					mask.at<Vec3b>(i, j)[1] = static_cast<uchar>(color[1]);
					mask.at<Vec3b>(i, j)[2] = static_cast<uchar>(color[2]);
				}
 
			}
		}
	}
}

測試代碼

#include <iostream>
#include <opencv2/opencv.hpp>
#include <stdio.h>
using namespace std;
using namespace cv;
 
void DrawConcentricCircle(cv::Mat mask, const cv::Point2i &center, int radius1, int radius2, const cv::Scalar &color, int thickness, int linetype);
 
int main()
{
	cv::Mat src = imread("test.jpg");
	cv::Mat result = src.clone();
	DrawConcentricCircle(result, cv::Point(result.cols / 2, result.rows / 2), 300, 500, cv::Scalar(255, 255, 0),-10, 16);
	imshow("original", src);
	imshow("result", result);
	waitKey(0);
	system("pause");
	return 0;
}
 
// 繪制同心圓
void DrawConcentricCircle(cv::Mat mask, const cv::Point2i &center, int radius1,int radius2, const cv::Scalar &color, int thickness,int linetype)
{
	// 創建畫布
	cv::Mat canvas = cv::Mat::zeros(mask.size(), CV_8UC1);
 
	// 計算內徑和外徑
	int inradius = min(radius1, radius2);
	int outradius = max(radius1, radius2);
 
	// 分情況討論
	// 當thickness大于0時,繪制的是兩個圓型線條組成的同心圓,不需填充
	if (thickness > 0)
	{
		cv::circle(mask, center, outradius, color, thickness, linetype);
		cv::circle(mask, center, inradius, color, thickness, linetype);
	}
	// 當thickness小于0,一般為-1,繪制的是填充同心圓,內圓不能有填充色
	else {
		cv::circle(canvas, center, outradius, cv::Scalar(255), -1, linetype);
		cv::circle(canvas, center, inradius, cv::Scalar(0), -1, linetype);
		int row = mask.rows;
		int col = mask.cols;
		for (int i = 0; i < row; ++i)
		{
			for (int j = 0; j < col; ++j)
			{
				uchar *m = canvas.ptr<uchar>(i);
				if (m[j] == 255)
				{
					mask.at<Vec3b>(i, j)[0] = static_cast<uchar>(color[0]);
					mask.at<Vec3b>(i, j)[1] = static_cast<uchar>(color[1]);
					mask.at<Vec3b>(i, j)[2] = static_cast<uchar>(color[2]);
				}
 
			}
		}
	}
}

測試效果

OpenCV如何繪制同心圓 

圖1 原圖

OpenCV如何繪制同心圓 

圖2 繪制同心圓

繪制同心圓就是兩個圓組合,但又不完全是,因為要考慮填充的情況,同心圓填充后應該是兩個圓之間的區域填充,而不是填充為一整個圓,如圖3所示。

OpenCV如何繪制同心圓 

圖3 填充效果

關于“OpenCV如何繪制同心圓”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

花垣县| 绥芬河市| 华阴市| 临洮县| 济南市| 阳谷县| 油尖旺区| 宣汉县| 扎兰屯市| 新津县| 恩施市| 沙坪坝区| 介休市| 辽阳市| 色达县| 鸡西市| 临沧市| 雷波县| 泾阳县| 盘山县| 丘北县| 乐清市| 岚皋县| 屏边| 萍乡市| 万年县| 漠河县| 延吉市| 昌都县| 盐亭县| 台前县| 密云县| 康定县| 江西省| 福泉市| 盐城市| 临城县| 苍山县| 赣州市| 长顺县| 鸡泽县|