opencv滤镜-连环画滤镜

连环画滤镜

连环画滤镜的公式为:

连环画滤镜公式.png

filter-img

代码实现

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
// comic-filter.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
// @mango

#include<iostream>
#include<cmath>
#include<opencv2/opencv.hpp>



int main()
{

	cv::Mat img = cv::imread("fruit.jpg");

	for (size_t i = 0; i < img.rows; i++)
	{
		for (size_t j = 0; j < img.cols; j++)
		{
			int r = img.at<cv::Vec3b>(i, j)[2];
			int g = img.at<cv::Vec3b>(i, j)[1];
			int b = img.at<cv::Vec3b>(i, j)[0];

			double R = std::abs(g - b + g + r) * r / 256;
			double G = std::abs(b - g + b + r) * r / 256;
			double B = std::abs(b - g + b + r) * g / 256;

			img.at<cv::Vec3b>(i, j)[0] = cv::saturate_cast<uchar>(B);
			img.at<cv::Vec3b>(i, j)[1] = cv::saturate_cast<uchar>(G);
			img.at<cv::Vec3b>(i, j)[2] = cv::saturate_cast<uchar>(R);
		}
	}
	cv::imshow("连环画滤镜", img);

	cv::waitKey(0);
	return 0;
}

滤镜效果

连环画滤镜效果.png


本文由芒果浩明发布,转载请注明来源。 本文链接:https://blog.mangoeffect.net/opencv/comic-filter.html


微信公众号