OpenCV之怀旧色、冰冻滤镜、熔铸滤镜

怀旧色

源码:

复制代码
void huaijiu(Mat& src,Mat& dst)
{
    for (int h = 0;h < src.rows;h ++)
    {
        uchar *d1 = src.ptr<uchar>(h);
        uchar *d2 = dst.ptr<uchar>(h);
        for (int w = 0;w < src.cols;w ++)
        {
            int w3 = 3*w;
            int r =  d1[w3 + 2];
            int g = d1[w3 + 1];
            int b = d1[w3 + 0];
            int AR =(int)(0.393*r + 0.769*g + 0.189*b);
            int AG =(int)(0.349*r + 0.686*g + 0.168*b);
            int AB =(int)(0.272*r + 0.534*g + 0.131*b);
            AR = AR > 255 ? 255 : AR;
            AG = AG > 255 ? 255 : AG;
            AB = AB > 255 ? 255  : AB;

            d2[w3 + 2] = AR;
            d2[w3 + 1] = AG;
            d2[w3 + 0] = AB;
        }
    }

}

原图:

冰冻滤镜

复制代码
void bingdong(Mat& src,Mat& dst)
{
    for (int h = 0;h < src.rows;h ++)
    {
        uchar *d1 = src.ptr<uchar>(h);
        uchar *d2 = dst.ptr<uchar>(h);
        for (int w = 0;w < src.cols;w ++)
        {
            int w3 = 3*w;
            int r =  d1[w3 + 2];
            int g = d1[w3 + 1];
            int b = d1[w3 + 0];

            int AR =(r - b - g)*3/2;
            int AG =(g - b - r)*3/2;
            int AB =(b - r - g)*3/2;

            AR = AR > 255 ? 255 : AR;
            AG = AG > 255 ? 255 : AG;
            AB = AB > 255 ? 255  : AB;

            d2[w3 + 2] = AR;
            d2[w3 + 1] = AG;
            d2[w3 + 0] = AB;
        }
    }
}

熔铸滤镜

复制代码
void rongzhu(Mat& src,Mat& dst)
{
    for (int h = 0;h < src.rows;h ++)
    {
        uchar *d1 = src.ptr<uchar>(h);
        uchar *d2 = dst.ptr<uchar>(h);
        for (int w = 0;w < src.cols;w ++)
        {
            int w3 = 3*w;
            int r =  d1[w3 + 2];
            int g = d1[w3 + 1];
            int b = d1[w3 + 0];

            int AR = r * 128 / (b+g+1);
            int AG = g*128 / (b+r+1);
            int AB = b*128 / (r+g+1);

            AR = AR > 255 ? 255 : AR;
            AG = AG > 255 ? 255 : AG;
            AB = AB > 255 ? 255  : AB;

            d2[w3 + 2] = AR;
            d2[w3 + 1] = AG;
            d2[w3 + 0] = AB;
        }
    }
}
相关推荐
Johny_Zhao1 小时前
OpenClaw安装部署教程
linux·人工智能·ai·云计算·系统运维·openclaw
飞哥数智坊2 小时前
我帮你读《一人公司(OPC)发展研究》
人工智能
冬奇Lab5 小时前
OpenClaw 源码精读(3):Agent 执行引擎——AI 如何「思考」并与真实世界交互?
人工智能·aigc
没事勤琢磨7 小时前
如何让 OpenClaw 控制使用浏览器:让 AI 像真人一样操控你的浏览器
人工智能
用户5191495848457 小时前
CrushFTP 认证绕过漏洞利用工具 (CVE-2024-4040)
人工智能·aigc
牛马摆渡人5287 小时前
OpenClaw实战--Day1: 本地化
人工智能
前端小豆7 小时前
玩转 OpenClaw:打造你的私有 AI 助手网关
人工智能
BugShare7 小时前
写一个你自己的Agent Skills
人工智能·程序员
机器之心8 小时前
英伟达护城河被AI攻破,字节清华CUDA Agent,让人人能搓CUDA内核
人工智能·openai
后端小肥肠9 小时前
公众号躺更神器!OpenClaw+Claude Skill 实现自动读对标 + 写文 + 配图 + 存入草稿箱
人工智能·aigc·agent