opencv双滑动条

在自适应二值化的时候,两个参数调试很麻烦。用双滑动条来简化调试过程。

#include<iostream>
#include "opencv2/opencv.hpp"
using namespace std;
using namespace cv;

#define WINDOW_NAME "自适应效果"

Mat g_imgGray,g_imgBin;
int g_nBlockSize=15;  //BlockSize初始值
int g_nMaxBlockSize=30;  //BlockSize最大值
int g_nC=10;
int g_nMaxC=30;

static void on_Track_Adaptive(int, void *)  //自适应二值化回调函数
{
	if(g_nBlockSize%2==0)   //BlockSize只能为奇数
		return;
	adaptiveThreshold(g_imgGray,g_imgBin,255,0,0,g_nBlockSize,g_nC);
    imshow(WINDOW_NAME, g_imgBin);
}

int main()
{
	Mat imgSrc=imread("E:/TestImg/fy/qsz5/104.jpg");
	if(imgSrc.empty())
	{
		cout<<"Load image error!"<<endl;
		return -1;
	}
	cvtColor(imgSrc,g_imgGray,COLOR_BGR2GRAY);  //灰度化
   
	//不能少这一句!!!!**********创建窗口,创建滑动条时停靠在此窗口。
	namedWindow(WINDOW_NAME,WINDOW_AUTOSIZE); 

	//创建滑动条 1.滑动条名称 2.窗口名称 3.滑动条初始位置 4.滑动条最大值 5.回调函数
	createTrackbar( "BlockSize:", WINDOW_NAME, &g_nBlockSize, g_nMaxBlockSize, on_Track_Adaptive);  
	createTrackbar( "C_Value:", WINDOW_NAME, &g_nC, g_nMaxC, on_Track_Adaptive);
	//结果在回调函数中显示
    on_Track_Adaptive(g_nBlockSize, 0);  
	on_Track_Adaptive(g_nC, 0);

	waitKey();
	return 0;
}

 

### 回答1: OpenCV Python中可以使用滑动来调节HSV值。具体步骤如下: 1. 创建一个空白窗口,用于显示图像和滑动。 2. 创建三个滑动,分别对应H、S、V三个通道的值。每个滑动的取值范围为到255。 3. 创建一个回调函数,用于响应滑动的变化。在回调函数中,获取滑动的当前值,并将其赋值给相应的HSV通道。 4. 将HSV值转换为BGR值,并显示在窗口中。 下面是一个示例代码: ```python import cv2 import numpy as np # 创建一个空白窗口 cv2.namedWindow('image') # 创建三个滑动 cv2.createTrackbar('H', 'image', , 255, lambda x: None) cv2.createTrackbar('S', 'image', , 255, lambda x: None) cv2.createTrackbar('V', 'image', , 255, lambda x: None) # 加载图像 img = cv2.imread('test.jpg') while True: # 获取滑动的当前值 h = cv2.getTrackbarPos('H', 'image') s = cv2.getTrackbarPos('S', 'image') v = cv2.getTrackbarPos('V', 'image') # 将HSV值转换为BGR值 hsv = np.array([[[h, s, v]]], dtype=np.uint8) bgr = cv2.cvtColor(hsv, cv2.COLOR_HSV2BGR) bgr = bgr[][] # 在窗口中显示图像和滑动 cv2.imshow('image', img) cv2.imshow('result', np.tile(bgr, (100, 100, 1))) # 等待按键事件 key = cv2.waitKey(1) if key == 27: # 按下ESC键退出 break cv2.destroyAllWindows() ``` 在上面的代码中,我们加载了一张名为test.jpg的图像,并创建了三个滑动。在每次滑动的值发生变化时,我们都会重新计算HSV值,并将其转换为BGR值。最后,我们在窗口中显示原始图像和转换后的颜色块。 ### 回答2: OpenCV 是一个流行的开源计算机视觉库,能够为图像和视频处理提供支持。OpenCV 中提供了一个用于图像颜色空间转换的函数 cv2.cvtColor(),它可以将常见的颜色空间转换成 OpenCV 中的颜色空间。 HSV 是一种表示颜色的常见颜色空间,由色调(Hue)、饱和度(Saturation)和亮度(Value)三种属性组成。在 OpenCV 中,要实现 HSV 颜色空间的滑动调节,需要按照以下步骤进行操作: 1. 首先读取要处理的图像,并将其转换为 HSV 颜色空间。 2. 定义用于滑动的名称和初始值,并将其添加到 OpenCV 窗口中。 3. 创建一些函数来响应滑动的变化。这些函数应该对图像进行修改,并将修改后的图像显示在 OpenCV 窗口中。在修改图像之前,需要将滑动的当前值传递给这些函数。 4. 在主循环中,添加一些代码来捕获滑动值的变化。当滑动的值发生变化时,调用相应的函数来修改图像,并将修改后的图像显示在 OpenCV 窗口中。 5. 将滑动的初始值传递给响应函数,以确保图像在程序启动时显示正确。 以下是示例代码,用于创建一个显示 HSV 图像,并使用滑动调整颜色的 OpenCV 窗口: ```python import cv2 import numpy as np # 这里使用的图像是由 BGR 模式转换而来的 img = cv2.imread('test.jpg') img_hsv = cv2.cvtColor(img, cv2.COLOR_BGR2HSV) # 定义滑动的名称和初始值 cv2.namedWindow('image') # 在窗口中创建滑动 cv2.createTrackbar('H', 'image', 0, 179, nothing) cv2.createTrackbar('S', 'image', 0, 255, nothing) cv2.createTrackbar('V', 'image', 0, 255, nothing) # 定义滑动响应函数 def nothing(x): pass def on_change(x): # 获取当前滑动的值 h = cv2.getTrackbarPos('H', 'image') s = cv2.getTrackbarPos('S', 'image') v = cv2.getTrackbarPos('V', 'image') # 修改图像 img_hsv = cv2.cvtColor(img, cv2.COLOR_BGR2HSV) lower = np.array([h, s, v]) upper = np.array([179, 255, 255]) mask = cv2.inRange(img_hsv, lower, upper) res = cv2.bitwise_and(img, img, mask=mask) # 在窗口中显示图像 cv2.imshow('image', res) # 绑定滑动响应函数 cv2.createTrackbar('H', 'image', 0, 179, on_change) cv2.createTrackbar('S', 'image', 0, 255, on_change) cv2.createTrackbar('V', 'image', 0, 255, on_change) # 将初始值传递给响应函数 on_change(0) # 循环等待按键 while True: k = cv2.waitKey(1) & 0xFF if k == 27: break # 关闭窗口 cv2.destroyAllWindows() ``` 在这个示例中,我们使用 cv2.inRange() 函数来创建一个区域掩模,用于将颜色在给定区间内的像素点标记为白色,其余像素点标记为黑色。最后,我们使用 cv2.bitwise_and() 函数将图像与掩模相乘,从而生成新的图像。这个新的图像只包含符合给定颜色范围的像素点。 通过使用上述方法,我们可以实现在 OpenCV滑动调节 HSV 颜色空间的效果。 ### 回答3: OpenCV是一个开源计算机视觉库,通过它提供的方法和工具,我们可以非常方便地对图像或视频进行处理和分析。Python是一种脚本语言,相当于程序员的瑞士军刀,可以用于快速开发各种软件系统,含丰富的模块库和工具,方便使用者快速开发。 在使用OpenCV库时,有时我们需要对图像进行颜色调节。为了便于实现调节过程,OpenCV提供了一个图形用户界面(GUI)模块,可以使用这个模块来创建一个混合窗口并添加滑动滑动可以控制图像的HSV(色相、饱和度、亮度)参数,以实现实时的颜色调整。要实现这个过程,需要按照以下步骤进行操作。 1. 导入库 ``` import cv2 import numpy as np ``` 2. 创建一个空的回调函数,该函数将作为滑动的回调函数 ``` def nothing(x): pass ``` 3. 创建窗口 ``` cv2.namedWindow('image') ``` 4. 读取图像 ``` img = cv2.imread('图片路径') ``` 5. 将图像转换为HSV ``` hsv = cv2.cvtColor(img, cv2.COLOR_BGR2HSV) ``` 6. 创建滑动 ``` cv2.createTrackbar('Hue_Min', 'image', 0, 179, nothing) cv2.createTrackbar('Hue_Max', 'image', 0, 179, nothing) cv2.createTrackbar('Saturation_Min', 'image', 0, 255, nothing) cv2.createTrackbar('Saturation_Max', 'image', 0, 255, nothing) cv2.createTrackbar('Value_Min', 'image', 0, 255, nothing) cv2.createTrackbar('Value_Max', 'image', 0, 255, nothing) ``` 7. 创建滑动绑定的变量 ``` Hue_Min = cv2.getTrackbarPos('Hue_Min', 'image') Hue_Max = cv2.getTrackbarPos('Hue_Max', 'image') Saturation_Min = cv2.getTrackbarPos('Saturation_Min', 'image') Saturation_Max = cv2.getTrackbarPos('Saturation_Max', 'image') Value_Min = cv2.getTrackbarPos('Value_Min', 'image') Value_Max = cv2.getTrackbarPos('Value_Max', 'image') ``` 8. 创建调整后的图像 ``` lower_hsv = np.array([Hue_Min, Saturation_Min, Value_Min]) upper_hsv = np.array([Hue_Max, Saturation_Max, Value_Max]) mask = cv2.inRange(hsv, lower_hsv, upper_hsv) res = cv2.bitwise_and(img, img, mask=mask) ``` 9. 显示图像 ``` cv2.imshow('image', res) ``` 10. 等待键盘输入 ``` cv2.waitKey(0) cv2.destroyAllWindows() ``` 当以上操作完成时,可以打开GUI界面开始调节HSV参数进行颜色滤镜处理。 以上就是使用OpenCV和Python实现图像颜色调节的过程。通过使用slider,可以控制HSV的参数,实现动态调整。这是一个很好的工具,能够方便地处理图像和视频的颜色。这个过程对初学者较为适合,可以让你快速掌握基本知识并进行拓展,想象力是无限的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值