栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

C++ opencv实现的把蓝底照片转化为白底照片功能完整示例

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

C++ opencv实现的把蓝底照片转化为白底照片功能完整示例

本文实例讲述了C++ opencv实现的把蓝底照片转化为白底照片功能。分享给大家供大家参考,具体如下:

#include 
#include 
#include 
#include 
using namespace std;
using namespace cv;//包含cv命名空间
int main()
{
 char *origin="Original";
 char *window="Image";
 char *str="G:\yay.jpg";
 namedWindow(origin,1);
 namedWindow(window,1);
 Mat image=imread(str);
 if(!image.data)
 {
  cout<<"图像载入出现问题"< v;
 split(hsvImg,v);
 Mat roiH=v[0](Rect(20,20,20,20));
 Mat roiS=v[1](Rect(20,20,20,20));
 int SumH=0;
 int SumS=0;
 int avgH, avgS;//蓝底的平均色调和平均饱和度
 //取一块蓝色背景,计算出它的平均色调和平均饱和度
 for(int i=0; i<20; i++)
 {
  for(int j=0; j<20; j++)
  {
   
   SumH=int(roiH.at(j,i))+SumH;
   SumS=int(roiS.at(j,i))+SumS;
  }
 }
 avgH=SumH/400;
 avgS=SumS/400;
 //遍历整个图像
 int nl=hsvImg.rows;
 int nc=hsvImg.cols;
 int step=10;
 for(int j=0; j(j,i))<=(avgH+5) && v[0].at(j,i)>=(avgH-5)
    &&(v[1].at(j,i))<=(avgS+40) && v[1].at(j,i)>=(avgS-40))
   {
    //cout<(j,i))<(j,i)=0;
    //白色底
    v[0].at(j,i)=0;
    v[1].at(j,i)=0; //V[0]和V[1]全调成0就是变成白色
    //绿色底
    //v[0].at(j,i)=60;
    //蓝色底
    //v[0].at(j,i)=120;
    
   }
  }
 }
 Mat finImg;
 merge(v,finImg);
 Mat rgbImg;
 cvtColor(finImg,rgbImg, CV_HSV2BGR); //将图像转换回RGB空间
 imshow(origin,image);
 imshow(window,rgbImg);
 //加个滤波把边缘部分的值滤掉(此处应该用低通滤波器,但感觉不太好,还是不用了。)
 Mat result;
 GaussianBlur(rgbImg,result,Size(3,3),0.5);
 imshow(window,result);
 imwrite("new.jpg",result);
 waitKey(0);
 //system("pause");
 return 0;
}

这个效果比之前要好,图片对比:

参考文章:https://www.jb51.net/article/176326.htm

希望本文所述对大家C++程序设计有所帮助。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/62184.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号