【发布时间】:2015-12-03 14:22:18
【问题描述】:
我是计算机视觉方面的新手。 我基于http://www.pyimagesearch.com/2014/08/18/skin-detection-step-step-example-using-python-opencv/在Android上做了一个皮肤检测器
但是我在选择色彩空间时遇到了问题。 http://imgur.com/DxNOXd9(Sr,没有 10 个声望我不能发布图片)
我在互联网和这个网站上尝试了很多空间,但都错了。
这是我的代码:
public Mat onCameraFrame(CvCameraViewFrame inputFrame) {
Mat hsv = new Mat();
//H,S,V area
Scalar lower = new Scalar(0, 0.28*255, 0);
Scalar upper = new Scalar(25, 0.68*255, 255);
//Skin detector HSV-based
Imgproc.cvtColor(inputFrame.rgba(), hsv, Imgproc.COLOR_RGBA2RGB);
Imgproc.cvtColor(hsv, hsv, Imgproc.COLOR_RGB2HSV_FULL);
Mat result = new Mat(hsv.rows(), hsv.cols(), CvType.CV_8U);
Core.inRange(hsv, lower, upper, result);
// Perform and decrease noise
Mat kernel = Imgproc.getStructuringElement(Imgproc.MORPH_ELLIPSE, new Size(2, 2));
Imgproc.erode(result, result, kernel);
Imgproc.dilate(result, result, kernel);
Imgproc.GaussianBlur(result, result, new Size(3,3), 0);
// Output
Imgproc.cvtColor(result, result, Imgproc.COLOR_GRAY2RGB);
Imgproc.cvtColor(result, result, Imgproc.COLOR_RGB2RGBA);
return result;
}
更新 1: 我尝试通过人脸检测示例获取皮肤空间:
for (int i = 0; i < facesArray.length; i++) {
Core.rectangle(mRgba, facesArray[i].tl(), facesArray[i].br(),
FACE_RECT_COLOR, 3);
Mat hsv = new Mat(inputFrame.rgba(), facesArray[i]);
Imgproc.cvtColor(hsv, hsv, Imgproc.COLOR_RGB2HSV_FULL);
List<Mat> hsv_channel = new ArrayList<Mat>();
Core.split(hsv, hsv_channel);
Log.w("Color: ", "H: " + hsv_channel.get(0) + "S: " + hsv_channel.get(1) + "V: " + hsv_channel.get(2));
}
然后输出:
H:垫 [261*261*CV_8UC1,isCont=true,isSubmat=false,nativeObj=0xffffffffb8b15658,dataAddr=0xffffffffb983d5f0]
S: Mat [ 261*261*CV_8UC1, isCont=true, isSubmat=false, nativeObj=0xffffffffb8b15698, dataAddr=0xffffffffb984e030 ]
V: Mat [ 261*261*CV_8UC1, isCont=true, isSubmat=false, nativeObj=0xffffffffb8b156d8, dataAddr=0xffffffffb985ea60 ]
如何将这些应用到我的代码中?
【问题讨论】:
-
不确定android,但通常openCV图像不是RGB而是BGR,所以也许在RGB2HSV之前尝试BGRA2RGB转换
-
@Micka:在adnroid中使用rgba
-
那么样本看起来没问题...
COLOR_RGB2HSV和COLOR_RGB2HSV_FULL有什么区别?也许在第一次尝试时不要尝试腐蚀、膨胀和高斯。并且可能在开始时尝试更大的范围,例如Scalar lower = new Scalar(0, 0, 0); Scalar upper = new Scalar(25, 255, 255);
标签: android opencv computer-vision hsv vision