求取圆形区域内的平均灰度值

该博客介绍如何利用OpenCV的霍夫变换检测圆形并计算其内部的平均灰度值。通过读取图像、进行双边滤波、霍夫变换检测圆以及遍历像素来求取平均值,最后将结果绘制到新的图像上。
摘要由CSDN通过智能技术生成
#include <cmath>
#include <opencv2/opencv.hpp>
using namespace cv;
using namespace std;

const int kvalue = http://blog.csdn.net/kh1445291129/article/details/15;//双边滤波邻域大小
const double PI = 3.14;//圆周率

int graylevel(Mat image, Mat dst, Point cen, int r)//求取圆形区域内的平均灰度值
{
int graysum = 0, n = 0;

for(int i = (cen.y - r); i <= (cen.y + r); ++i)//访问矩形框内的像素值
{
uchar* data = image.ptr(i);
for(int j = (cen.x - r); j <= (cen.x + r); ++j)
{
double d = (i-cen.y)*(i-cen.y) + (j-cen.x)*(j-cen.x);
if(d < r*r)
{
++n;
graysum += (int)data[j];
}
}
}

for(int i = (cen.y - r); i <= (cen.y + r); ++i)//画出圆,圆内像素值为平均灰度值
{
uchar* temp = dst.ptr(i);
for(in
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以按照以下步骤来获取圆形区域内的亮斑并用圆标记: 1. 使用cv2.HoughCircles函数来检测图像中所有的圆形区域,返回的结果是一个圆心坐标和半径的列表。 2. 对于每一个圆形区域,使用cv2.mean函数来计算该区域平均亮度值。 3. 对于所有平均亮度值超过阈值的圆形区域,使用cv2.circle函数在图像上画一个圆形,并标记该区域。 下面是一个示例代码,你可以参考一下: ``` import cv2 import numpy as np # 读取图像 img = cv2.imread('image.jpg', cv2.IMREAD_GRAYSCALE) # 设置圆形区域半径和阈值 radius = 50 threshold = 200 # 使用cv2.HoughCircles函数检测圆形区域 circles = cv2.HoughCircles(img, cv2.HOUGH_GRADIENT, dp=1, minDist=radius, param1=50, param2=30, minRadius=0, maxRadius=radius) if circles is not None: # 将圆形区域的坐标和半径转换成整数 circles = np.round(circles[0, :]).astype("int") # 遍历所有圆形区域 for (x, y, r) in circles: # 计算圆形区域平均亮度值 mean = cv2.mean(img[y-r:y+r, x-r:x+r])[0] # 如果平均亮度值超过阈值,就在图像上画一个圆形 if mean > threshold: cv2.circle(img, (x, y), r, (0, 255, 0), 2) # 显示图像 cv2.imshow('image', img) cv2.waitKey(0) cv2.destroyAllWindows() ``` 在这个示例代码中,我们读取了一张灰度图像,并使用cv2.HoughCircles函数检测图像中的圆形区域。然后,对于每一个圆形区域,我们计算了该区域平均亮度值,并根据阈值来判断是否在图像上画一个圆形。最后,我们使用cv2.imshow函数显示图像,并等待按下任意键后关闭窗口。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值