OpenCV 图像线性滤波综合示例程序(用到了Trackbar轨迹条)
来源:互联网 发布:万游网络武汉 编辑:程序博客网 时间:2024/06/05 09:02
http://blog.csdn.net/poem_qianmo/article/details/22745559
//-----------------------------------【程序说明】----------------------------------------------// 程序名称::【OpenCV入门教程之八】线性滤波专场:方框滤波、均值滤波与高斯滤波 //------------------------------------------------------------------------------------------------//-----------------------------------【头文件包含部分】---------------------------------------// 描述:包含程序所依赖的头文件//----------------------------------------------------------------------------------------------#include <opencv2/core/core.hpp>#include<opencv2/highgui/highgui.hpp>#include <opencv2/imgproc/imgproc.hpp>#include <iostream>//-----------------------------------【命名空间声明部分】---------------------------------------// 描述:包含程序所使用的命名空间//----------------------------------------------------------------------------------------------- using namespace std;using namespace cv;//-----------------------------------【全局变量声明部分】--------------------------------------// 描述:全局变量声明//-----------------------------------------------------------------------------------------------Mat g_srcImage, g_dstImage1, g_dstImage2, g_dstImage3;//存储图片的Mat类型int g_nBoxFilterValue = 3; //方框滤波参数值int g_nMeanBlurValue = 3; //均值滤波参数值int g_nGaussianBlurValue = 3; //高斯滤波参数值//-----------------------------------【全局函数声明部分】--------------------------------------// 描述:全局函数声明//-----------------------------------------------------------------------------------------------//轨迹条的回调函数static void on_BoxFilter(int, void *); //方框滤波static void on_MeanBlur(int, void *); //均值滤波static void on_GaussianBlur(int, void *); //高斯滤波//-----------------------------------【main( )函数】--------------------------------------------// 描述:控制台应用程序的入口函数,我们的程序从这里开始//-----------------------------------------------------------------------------------------------int main(){//改变console字体颜色system("color5E");//载入原图g_srcImage = imread("yun.jpg");if (!g_srcImage.data) { printf("Oh,no,读取srcImage错误~!\n"); return false; }//克隆原图到三个Mat类型中 深拷贝g_dstImage1 = g_srcImage.clone();g_dstImage2 = g_srcImage.clone();g_dstImage3 = g_srcImage.clone();//显示原图namedWindow("【<0>原图窗口】", 1);imshow("【<0>原图窗口】", g_srcImage);//=================【<1>方框滤波】==================//创建窗口namedWindow("【<1>方框滤波】", 1);//创建轨迹条createTrackbar("内核值:", "【<1>方框滤波】", &g_nBoxFilterValue, 40, on_BoxFilter);on_MeanBlur(g_nBoxFilterValue, 0);imshow("【<1>方框滤波】", g_dstImage1);//================================================//=================【<2>均值滤波】==================//创建窗口namedWindow("【<2>均值滤波】", 1);//创建轨迹条createTrackbar("内核值:", "【<2>均值滤波】", &g_nMeanBlurValue, 40, on_MeanBlur);on_MeanBlur(g_nMeanBlurValue, 0);//================================================//=================【<3>高斯滤波】=====================//创建窗口namedWindow("【<3>高斯滤波】", 1);//创建轨迹条createTrackbar("内核值:", "【<3>高斯滤波】", &g_nGaussianBlurValue, 40, on_GaussianBlur);on_GaussianBlur(g_nGaussianBlurValue, 0);//================================================//输出一些帮助信息cout << endl << "\t嗯。好了,请调整滚动条观察图像效果~\n\n";waitKey();return 0;}//-----------------------------【on_BoxFilter( )函数】------------------------------------// 描述:方框滤波操作的回调函数//-----------------------------------------------------------------------------------------------static void on_BoxFilter(int, void *){//方框滤波操作boxFilter(g_srcImage, g_dstImage1, -1, Size(g_nBoxFilterValue + 1, g_nBoxFilterValue + 1));//显示窗口imshow("【<1>方框滤波】", g_dstImage1);}//-----------------------------【on_MeanBlur( )函数】------------------------------------// 描述:均值滤波操作的回调函数//-----------------------------------------------------------------------------------------------static void on_MeanBlur(int, void *){//均值滤波操作blur(g_srcImage, g_dstImage2, Size(g_nMeanBlurValue + 1, g_nMeanBlurValue + 1), Point(-1, -1));//显示窗口imshow("【<2>均值滤波】", g_dstImage2);}//-----------------------------【on_GaussianBlur( )函数】------------------------------------// 描述:高斯滤波操作的回调函数//-----------------------------------------------------------------------------------------------static void on_GaussianBlur(int, void *){//高斯滤波操作GaussianBlur(g_srcImage, g_dstImage3, Size(g_nGaussianBlurValue * 2 + 1, g_nGaussianBlurValue * 2 + 1), 0, 0);//显示窗口imshow("【<3>高斯滤波】", g_dstImage3);}
0 0
- OpenCV 图像线性滤波综合示例程序(用到了Trackbar轨迹条)
- 线性图像滤波综合示例
- Opencv 学习笔记之图像线性滤波综合示例
- OpenCV 创建Trackbar 轨迹条
- Opencv图像线性滤波-滚动条
- OpenCV 腐蚀与膨胀+轨迹条控制 综合示例
- OpenCV 形态学图像处理 开运算、闭运算、形态学梯度、顶帽、黑帽合辑(轨迹条控制)综合示例
- OpenCV Trackbar轨迹条运用与轮廓查找填充
- OpenCV之轨迹条(TrackBar)的创建和使用
- 【拜小白opencv】34-图像平滑处理,6种滤波总结的综合示例【盒式滤波、均值滤波、高斯滤波、中值滤波、双边滤波、导向滤波】
- 五种图像滤波综合示例
- opencv基本图像处理——添加滑动条trackbar
- OpenCv基础(四):Trackbar(轨迹条)的创建和使用
- 3基于opencv的对比度_亮度调整_轨迹条Trackbar
- 【拜小白opencv】11-综合示例-两幅图像融合-摄像头采集图像-滑动条
- Opencv图像非线滤波-滚动条
- opencv——轨迹条控制图像对比度与亮度
- Opencv形态学滤波-综合
- Linux的哲学思想
- hdu4221 Greedy?
- 深入浅出RxJava(二:操作符)
- 欢迎使用CSDN-markdown编辑器
- 任务一 HelloWorld
- OpenCV 图像线性滤波综合示例程序(用到了Trackbar轨迹条)
- _cinit
- Hibernate JAP 字段自动添加下划线问题,
- 基于c++标准库计算文件大小
- 第三章习题3-第6题==判断完数
- 滑动窗口机制
- 第三周 项目4-顺序表的应用
- PHP中echo和print的区别
- Linux的哲学思想