OpenCV中的Alpha渐变(统一包装器)

时间:2018-12-01 10:45:05

标签: opencv unity3d gradient alpha

我正在C#中使用Unity的opencv,但我认为与Java的opencv非常相似

我认为我的问题很简单,但是我是opencv的新手,很多事情我都不知道...

这是我的情况:从图片中我需要剪裁脸部并应用一些素描效果。

图片: enter image description here

具有某些效果的裁剪图像:

enter image description here

我需要的是最终图像中椭圆的渐变alpha边框。类似于下一张图片,但椭圆的边缘带有渐变

enter image description here

这是我的代码:

Mat mask = new Mat(rgbaMat.rows(), rgbaMat.cols(), CvType.CV_8UC4, new Scalar(0, 0, 0, 0));
Mat face = new Mat(rgbaMat.rows(), rgbaMat.cols(), CvType.CV_8UC4, new Scalar(0, 0, 0, 0));
OpenCVForUnity.Rect rectCrop = new OpenCVForUnity.Rect((int)x, (int)y, (int)width, (int)height);
RotatedRect rRect = new RotatedRect(new Point(centerX, centerY), new Size(width, height), 0);
Imgproc.ellipse(mask, rRect, new Scalar(255, 255, 255, 255), -1);
Imgcodecs.imwrite(Application.dataPath + "/mask.png", mask);


Mat abs_grad_x = new Mat(rgbaMat.rows(), rgbaMat.cols(), CvType.CV_16SC4, new Scalar(0, 0, 0, 0));
Mat abs_grad_y = new Mat(rgbaMat.rows(), rgbaMat.cols(), CvType.CV_16SC4, new Scalar(0, 0, 0, 0));
Mat grad_x = new Mat(rgbaMat.rows(), rgbaMat.cols(), CvType.CV_16SC4, new Scalar(0, 0, 0, 0));
Mat grad_y = new Mat(rgbaMat.rows(), rgbaMat.cols(), CvType.CV_16SC4, new Scalar(0, 0, 0, 0));
int delta = 0;
int scale = 1;
int ddepth = CvType.CV_16S;

Mat final = new Mat(rgbaMat.rows(), rgbaMat.cols(), CvType.CV_16SC4, new 
Scalar(0, 0, 0, 0));
Imgproc.GaussianBlur(mask, mask, new Size(42, 42), 0);
rgbaMat.copyTo(face, mask);
face = face.submat(rectCrop);
Imgproc.GaussianBlur(face, face, new Size(21, 21), 0);
Imgproc.cvtColor(face, face, Imgproc.COLOR_RGBA2GRAY);
Imgproc.Scharr(face, grad_x, ddepth, 1,0,scale, delta, 0);
Core.convertScaleAbs(grad_x, abs_grad_x);

Imgproc.Scharr(face, grad_y, ddepth,0, 1, scale, delta, 0);
Core.convertScaleAbs(grad_y, abs_grad_y);
Core.addWeighted(abs_grad_x, 0.5, abs_grad_y, 0.5, 0, final);
Core.bitwise_not(final, final);
Imgproc.threshold(final, final, 230,255, Imgproc.THRESH_BINARY);

0 个答案:

没有答案