Сегментация HSV на основе щелчка мышью
Я пытаюсь сделать базовую сегментацию изображения. Пороговые значения для HSV должны определяться из значения пикселя, при котором щелкается мышь. Я не могу заставить его работать. Вот что я написал до сих пор:
#include <iostream>
#include "opencv2/opencv.hpp"
#include <cv.h>
#include "opencv/highgui.h"
using namespace std;
using namespace cv;
Mat edges,frame,bw,hsv,dst,src_gray,probabilistic_hough, HSV_image;
int H=110,S=40,V=140;
int border=80;
int linethreshold=180,linelengthslider=30,linegapslider=3, HT_threshold=10;
int min_threshold = 50;
void printHSVValues(int event, int x, int y, int, void* );
void changeborder( int, void* );
Scalar hsvlow(0,0,0),hsvhigh(180,255,255);
int c=0;
void printHSVValues(int event, int x, int y, int, void* );
int main ( int argc, char **argv )
{
VideoCapture cap(1);
namedWindow("edges",1);
namedWindow("segmented",1);
setMouseCallback( "edges", printHSVValues, 0 );
while (c != 'q') {
cap >> frame;
imshow("edges",frame);
c= (char)waitKey(100);
}
return 0;
}
void printHSVValues(int event, int x, int y, int, void* ){
int loop;
float change;
if( event == EVENT_LBUTTONDOWN ) {
cvtColor(frame, HSV_image, CV_BGR2HSV);
Vec3b p = HSV_image.at<float>(y,x);
for (loop=0;loop<3;loop++) {
change=p[loop]*0.01;
hsvlow[loop] = p[loop] - change;
hsvhigh[loop] = p[loop] + change;
}
inRange( HSV_image, hsvlow,hsvhigh,bw);
imshow("segmented",bw);
}
}
Где я все испортил? Заранее спасибо.
DY.
1 ответ
Решение
Вы неправильно обращаетесь к значениям Mat. Изображение имеет 3 канала, так как вы правильно присвоили переменной тип Vec3b
Тем не менее, вы получаете float
значение из изображения. Правильный путь будет:
Vec3b p = HSV_image.at<Vec3b>(y,x);