OpenCV计算摄影学(15)无缝克隆(Seamless Cloning)调整图像颜色的函数colorChange()

  • 操作系统:ubuntu22.04
  • OpenCV版本:OpenCV4.9
  • IDE:Visual Studio Code
  • 编程语言:C++11

算法描述

cv::colorChange 是 OpenCV 中用于调整图像颜色的函数。它允许你通过乘以不同的系数来独立地改变输入图像中红色、绿色和蓝色通道的强度,从而实现对图像色彩的调整。这个功能对于需要精细控制图像色调的应用非常有用。

函数原型

cpp 复制代码
void cv::colorChange 	
(
        InputArray  	src,
		InputArray  	mask,
		OutputArray  	dst,
		float  	red_mul = 1.0f,
		float  	green_mul = 1.0f,
		float  	blue_mul = 1.0f 
	) 		

参数

  • 参数src 输入 8 位 3 通道图像‌34。
  • 参数mask 输入 8 位 1 或 3 通道图像‌35。
  • 参数dst 输出与 src 尺寸和类型相同的图像‌34。
  • 参数red_mul 红色通道乘法因子‌4。
  • 参数green_mul 绿色通道乘法因子‌4。
  • 参数blue_mul 蓝色通道乘法因子‌4。

乘法因子范围在 0.5 至 2.5 之间‌

示例代码

cpp 复制代码
#include <iostream>
#include <opencv2/opencv.hpp>

int main()
{
    // 加载图像
    cv::Mat src = cv::imread("/media/dingxin/data/study/OpenCV/sources/images/jiangnan.jpg");
    if (src.empty())
    {
        std::cerr << "无法加载图像!" << std::endl;
        return -1;
    }

    // 创建全1掩模(处理整个图像)
    cv::Mat mask = cv::Mat::ones(src.size(), CV_8UC1);

    // 应用颜色变换(调整参数以增强效果)
    cv::Mat dst;
    cv::colorChange(src, mask, dst, 2.5f, 0.1f, 1.0f); // 红通道增强,绿通道减弱

    // 转换为浮点型计算差异
    cv::Mat src_f, dst_f;
    src.convertTo(src_f, CV_32F);
    dst.convertTo(dst_f, CV_32F);

    // 计算绝对差异并归一化‌:ml-citation{ref="1,2" data="citationList"}
    cv::Mat diff_f;
    cv::absdiff(src_f, dst_f, diff_f);
    cv::normalize(diff_f, diff_f, 0, 255, cv::NORM_MINMAX); // 关键修改:归一化数据范围‌:ml-citation{ref="1" data="citationList"}

    // 转换为8位图像
    cv::Mat diff;
    diff_f.convertTo(diff, CV_8U);

    // 增强对比度显示(调整缩放因子)‌:ml-citation{ref="2" data="citationList"}
    cv::Mat enhanced_diff;
    cv::convertScaleAbs(diff, enhanced_diff, 5, 0); // alpha=5 增强差异可见性‌:ml-citation{ref="2" data="citationList"}

    // 显示结果
    cv::imshow("Original Image", src);
    cv::imshow("Processed Image", dst);
    cv::imshow("Difference Image", diff);
    cv::imshow("Enhanced Difference", enhanced_diff);

    // 保存结果(建议使用无损格式)‌:ml-citation{ref="5" data="citationList"}
    cv::imwrite("original.png", src);
    cv::imwrite("processed.png", dst);
    cv::imwrite("difference.png", diff);
    cv::imwrite("enhanced_difference.png", enhanced_diff);

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

运行结果

相关推荐
阿龙AI日记19 分钟前
详解Transformer04:Decoder的结构
人工智能·深度学习·自然语言处理
爱写代码的小朋友19 分钟前
“数字镜像”与认知负能者:生成式AI个性化学习支持者的协同构建与伦理规制研究
人工智能
找方案24 分钟前
新型智慧城市城市大数据应用解决方案
人工智能·智慧城市
K***72841 小时前
开源模型应用落地-工具使用篇-Spring AI-Function Call(八)
人工智能·spring·开源
Chat_zhanggong3451 小时前
K4A8G165WC-BITD产品推荐
人工智能·嵌入式硬件·算法
霍格沃兹软件测试开发1 小时前
Playwright MCP浏览器自动化指南:让AI精准理解你的命令
运维·人工智能·自动化
强化学习与机器人控制仿真2 小时前
RSL-RL:开源人形机器人强化学习控制研究库
开发语言·人工智能·stm32·神经网络·机器人·强化学习·模仿学习
网易智企2 小时前
智能玩具新纪元:一个AI能力底座开启创新“加速度”
人工智能·microsoft
咚咚王者2 小时前
人工智能之数据分析 numpy:第十二章 数据持久化
人工智能·数据分析·numpy
沛沛老爹2 小时前
AI应用入门之LangChain中SerpAPI、LLM-Math等Tools的集成方法实践
人工智能·langchain·llm·ai入门·serpapi