连环画滤镜
连环画滤镜的公式为:
data:image/s3,"s3://crabby-images/6867f/6867f55210be01242f601def7683233f851a5298" alt="连环画滤镜公式.png"
data:image/s3,"s3://crabby-images/6609d/6609d6f0c4de7e1407bc8fb9e74a507053fe29a5" alt="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;
}
|
滤镜效果
data:image/s3,"s3://crabby-images/6c0b1/6c0b15f8b120f9450a263705b248090232b58f55" alt="连环画滤镜效果.png"
本文由芒果浩明发布,转载请注明来源。
本文链接:https://blog.mangoeffect.net/opencv/comic-filter.html
data:image/s3,"s3://crabby-images/e4395/e43958e3b67989e098bf460d0be3090cde0cf6ca" alt="微信公众号"