91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

天门市| 体育| 称多县| 宁化县| 乐亭县| 澄江县| 阿鲁科尔沁旗| 平原县| 武胜县| 龙州县| 榆中县| 徐水县| 阿瓦提县| 翁源县| 安泽县| 呼图壁县| 大冶市| 乌恰县| 固始县| 怀柔区| 浦城县| 宜兰市| 广宗县| 蓬莱市| 新宁县| 广水市| 南丹县| 琼海市| 耒阳市| 遂溪县| 德清县| 宜黄县| 垦利县| 五大连池市| 东明县| 靖江市| 鹿泉市| 陕西省| 淅川县| 崇礼县| 从江县|