本站使用了 Pjax 等基于 JavaScript 的开发技术,但您的浏览器已禁用 JavaScript,请开启 JavaScript 以保证网站正常显示!

opencv滤镜-连环画滤镜

连环画滤镜

连环画滤镜的公式为:

连环画滤镜公式.png

原图

代码实现

// 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://mangoroom.cn/opencv/comic-filter.html


 继续浏览关于 opencv图像处理图像处理算法滤镜连环画 的文章

 本文最后更新于:2019/07/03 12:00:06,可能因经年累月而与现状有所差异

 引用转载请注明:芒果小屋 > opencv,滤镜 > opencv滤镜-连环画滤镜