opencv人像(人脸)美颜、磨皮

#include<opencv2/opencv.hpp>
#include<opencv2/imgproc/imgproc.hpp>
#include<opencv2/highgui/highgui.hpp>
#include<opencv2/objdetect/objdetect.hpp>
using namespace std;
using namespace cv;

void whiteFace(Mat& matSelfPhoto, int alpha, int beta)
{
	for (int y = 0; y < matSelfPhoto.rows; y++)
	{
		for (int x = 0; x < matSelfPhoto.cols; x++)
		{
			for (int c = 0; c < 3; c++)
			{
				matSelfPhoto.at<Vec3b>(y, x)[c] = saturate_cast<uchar>(alpha*(matSelfPhoto.at<Vec3b>(y, x)[c]) + beta);
			}
		}
	}
}

int main()
{
	Mat matResult;
	Mat src = imread("E:/rengong_check/face/2_face.jpg");
	int bilateralFilterVal = 30;  // 双边模糊系数
	imshow("src", src);
	whiteFace(src, 1.2, 20);  // 调整对比度与亮度,参数2为对比度,参数3为亮度
	imshow("white_src", src);
	GaussianBlur(src, src, Size(3, 3), 0, 0); // 高斯模糊,消除椒盐噪声
	imshow("gaussian_src", src);
	bilateralFilter(src, matResult, bilateralFilterVal, // 整体磨皮
		bilateralFilterVal * 2, bilateralFilterVal / 2);
	imshow("bilateralFilter_src", matResult);

	Mat matFinal;

	// 图像增强,使用非锐化掩蔽(Unsharpening Mask)方案。
	cv::GaussianBlur(matResult, matFinal, cv::Size(0, 0), 3);
	cv::addWeighted(matResult, 1.5, matFinal, -0.5, 0, matFinal);
	imshow("inforcement_src", matFinal);
	//imwrite("E:\\test\\result.png", matFinal);
	waitKey(0);
	return 0;
}

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值