OpenCV--阈值分割-threshold()和adaptiveThreshold()

本文主要介绍的是图像分割函数的意义及使用

涉及到的函数为threshold(),在下文代码段进行了详细的介绍。

图1表示了官方对阈值类型的介绍,图2表示的经过阈值处理之后的结果。

   

图1  阈值类型

    

图2  阈值分割结果

线性混合可表示如下:

dst = src1[I]*alpha+ src2[I]*beta + gamma;

/************************************************************************/
/* 
OpenCV阈值分割函数:threshold()

函数原型:
double threshold(InputArray src, OutputArray dst, double thresh, double maxval, int type)

参数含义:
InputArray src      -原图像
OutputArray dst     -输出图像
double thresh       -阈值大小
double maxval       -最大值
int type            -阈值模式

阈值模式有以下几种类型
0: THRESH_BINARY         -当前点值大于阈值时,取Maxval,否则设置为0
1: THRESH_BINARY_INV     -当前点值大于阈值时,设置为0,否则设置为Maxval
2: THRESH_TRUNC          -当前点值大于阈值时,设置为阈值,否则不改变
3: THRESH_TOZERO         -当前点值大于阈值时,不改变,否则设置为0
4: THRESH_TOZERO_INV     -当前点值大于阈值时,设置为0,否则不改变
*/
/************************************************************************/


#include <opencv2\imgproc\imgproc.hpp>
#include <opencv2\highgui\highgui.hpp>
#include <iostream>

using namespace cv;
using namespace std;

#define WINDOW_NAME "窗口"

//定义滑动条初始值
int g_nThresholdValue=100;  //阈值初始值
int g_nThresholdType=0;     //阈值模式初始值

Mat g_srcImage,g_grayImage,g_dstImage;

void on_Threshold(int ,void*);//声名回调函数

int main()
{
	g_srcImage=imread("lena.jpg");//读入图片
	if(!g_srcImage.data)
	{
		cout<<"读入错误"<<endl;
		return -1;
	}

	//转换为灰度图
	cvtColor(g_srcImage,g_grayImage,COLOR_RGB2GRAY);//更多转换方式参见官方文档
	//显示原图
	imshow("原图",g_srcImage);
	
	//创建滑动条
	namedWindow(WINDOW_NAME);
	createTrackbar("模式",WINDOW_NAME,&g_nThresholdType,4,on_Threshold);
	createTrackbar("阈值",WINDOW_NAME,&g_nThresholdValue,255,on_Threshold);

	//使用回调函数显示图像
	on_Threshold(0,0);

	waitKey();
	return 0;
}

void on_Threshold(int,void*)
{
	//进行阈值分割
	threshold(g_grayImage,g_dstImage,g_nThresholdValue,255,g_nThresholdType);
	//显示结果
	imshow(WINDOW_NAME,g_dstImage);
}

大津阈值和自适应阈值

#include <opencv2\imgproc\imgproc.hpp>  
#include <opencv2\highgui\highgui.hpp>  
#include <iostream>  

using namespace cv;  
using namespace std;  

#define WINDOW_NAME "窗口"  

Mat g_srcImage,g_grayImage,g_dstImage;  

int main()  
{  
	g_srcImage=imread("1.bmp");//读入图片  
	if(!g_srcImage.data)  
	{  
		cout<<"读入错误"<<endl;  
		return -1;  
	}  

	//转换为灰度图  
	cvtColor(g_srcImage,g_grayImage,COLOR_RGB2GRAY);//更多转换方式参见官方文档  
	//显示原图  
	imshow("原图",g_srcImage);  

	namedWindow(WINDOW_NAME);  
	//大津阈值
	threshold(g_grayImage,g_dstImage,0,255,CV_THRESH_OTSU); 
	//自适应阈值
	//adaptiveThreshold(g_grayImage,g_dstImage,255,0,0,7,9);
	imshow(WINDOW_NAME,g_dstImage);  

	waitKey();  
	return 0;  
}  




  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要去除图像的光照不均,可以使用一些图像处理技术。首先,你需要加载OpenCV-Python模块。可以使用pip进行安装,命令如下: ``` pip install -i https://pypi.tuna.tsinghua.edu.cn/simple opencv-python ``` 安装完成后,可以使用以下步骤去除图像的光照不均: 1. 加载图像:使用`cv2.imread()`函数加载图像文件。 2. 将图像转换为灰度图像:使用`cv2.cvtColor()`函数将彩色图像转换为灰度图像。 3. 去除光照不均:有多种方法可以去除光照不均,一种常用的方法是使用自适应阈值处理。可以使用`cv2.adaptiveThreshold()`函数进行自适应阈值处理,通过调整参数来适应不同的图像。 4. 显示处理后的图像:使用`cv2.imshow()`函数显示处理后的图像。 下面是示例代码: ```python import cv2 # 加载图像 img = cv2.imread('image.jpg') # 转换为灰度图像 gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # 去除光照不均 # 使用自适应阈值处理 adaptive_threshold = cv2.adaptiveThreshold(gray, 255, cv2.ADAPTIVE_THRESH_MEAN_C, cv2.THRESH_BINARY, 11, 2) # 显示处理后的图像 cv2.imshow('Processed Image', adaptive_threshold) cv2.waitKey(0) cv2.destroyAllWindows() ``` 这样就可以去除图像的光照不均了。你可以根据需要调整自适应阈值处理的参数,以达到更好的效果。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [jetson nano opencv 打开 CSI摄像头_opencv-python图形图像处理入门基础知识](https://blog.csdn.net/weixin_39775354/article/details/110121584)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [opencv-python图形图像处理入门基础知识](https://blog.csdn.net/LaoYuanPython/article/details/108015331)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值