OpenCV——颜色运算
来源:互联网 发布:淘宝网买车 编辑:程序博客网 时间:2024/04/29 22:49
#ifndef PS_ALGORITHM_H_INCLUDED#define PS_ALGORITHM_H_INCLUDED#include <iostream>#include <string>#include "cv.h"#include "highgui.h"#include "cxmat.hpp"#include "cxcore.hpp"using namespace std;using namespace cv;void Show_Image(Mat&, const string &);void Save_Image(Mat&, const string &);#endif // PS_ALGORITHM_H_INCLUDED
/*This program will do the computationon three channels respectively, and generatethe "cast" effect.*/#include "PS_Algorithm.h"using namespace std;using namespace cv;int main(void){ string Img_name("4.jpg"); Mat Image_in; Image_in=imread(Img_name); Show_Image(Image_in, Img_name); // split the three channels Mat Image_2(Image_in.size(), CV_32FC3); Image_in.convertTo( Image_2, CV_32FC3); Mat r(Image_in.rows, Image_in.cols, CV_32FC1); Mat g(Image_in.rows, Image_in.cols, CV_32FC1); Mat b(Image_in.rows, Image_in.cols, CV_32FC1); Mat out[]={b, g, r}; split(Image_2, out); b=out[0]/255; g=out[1]/255; r=out[2]/255; // generate the new image Mat Image_new(Image_in.size(), CV_32FC3); Image_in.convertTo( Image_new, CV_32FC3); // generate new channels Mat r_new(Image_in.rows, Image_in.cols, CV_32FC1); Mat g_new(Image_in.rows, Image_in.cols, CV_32FC1); Mat b_new(Image_in.rows, Image_in.cols, CV_32FC1); float alpha; alpha=0.15; // cv::divide(r,(b+g+0.001),r_new, alpha); // cv::divide(g,(b+r+0.001),g_new, alpha); // cv::divide(b,(r+g+0.001),b_new, alpha); r_new=r*alpha/(b+g+0.001); g_new=g*alpha/(r+b+0.001); b_new=b*alpha/(r+g+0.001); Mat out_new[]={b_new, g_new, r_new}; cv::merge(out_new, 3, Image_new); Show_Image(Image_new, "Img_out"); waitKey(); cout<<"All is well \n";}
</pre><pre name="code" class="cpp">#include "PS_Algorithm.h"#include <iostream>#include <string>using namespace std;using namespace cv;void Show_Image(Mat& Image, const string& str){ namedWindow(str.c_str(),CV_WINDOW_AUTOSIZE); imshow(str.c_str(), Image); // waitKey(); // cvDestroyWindow(str.c_str());}
原图:
效果图:
0 0
- OpenCV——颜色运算
- OpenCV——颜色运算(二)
- OpenCV颜色空间——HLS颜色空间
- OpenCV颜色空间——HSV颜色空间
- OpenCV颜色空间——Lab颜色空间
- OpenCV颜色空间——Luv颜色空间
- OpenCV——颜色均匀渐变
- OpenCV——颜色空间转换
- OpenCV—多通道颜色分离&混合
- PS 色调——颜色运算
- OpenCV——Mat矩阵运算
- opencv学习——形态学运算
- OpenCV—形态学运算定义与实现
- OpenCV—形态学运算定义与实现
- 学习OpenCV——一次颜色聚类
- 学习OpenCV:滤镜系列(3)——颜色变幻
- OpenCV中文网站例程——图像颜色分布直方图
- 学习OpenCV——一次颜色聚类
- 教你如何彻底解决网页中文乱码
- SVN—如何安装SVN客户端软件
- 第八周项目5定期存款利息计算器
- java IdentityHashMap 与HashMap
- 练习题目17. 定猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个,第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下,的一半零一个。到第10天早
- OpenCV——颜色运算
- [USACO 2014 Jan Silver]ccski
- 第八周项目二加班费
- Javascript获取select下拉框选中的的值
- java异常处理之throw, throws,try和catch
- 练习题目18. 给定一段连续的整数,求出他们中所有偶数的平方和以及所有奇数的立方和。
- 数据库常见面试题总结
- POJ 1833 生成排列
- HDU 4474 Yet Another Multiple Problem