大佬教程收集整理的这篇文章主要介绍了OpenCV实现马赛克和毛玻璃滤镜效果,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
本文为大家分享了OpenCV实现马赛克和毛玻璃滤镜的具体代码,供大家参考,具体内容如下
一、马赛克效果
马赛克的实现原理是把图像上某个像素点一定范围邻域内的所有点用邻域内随机选取的一个像素点的颜色代替,这样可以模糊细节,但是可以保留大体的轮廓。
以下OpenCV程序实现马赛克效果,通过鼠标左键在图像上划定马赛克的矩形框。
#include <core\core.hpp> #include <highgui\highgui.hpp> using namespace cv; Mat imagesourcecopy; //原始图像 Mat imagesource; //原始图像拷贝 int neightbourHood = 9; //马赛克上每个方框的像素大小 RNG rng; int randomNum; //邻域内随机值 Point ptL; //左键按下时坐标 Point ptR; //右键按下时坐标 //鼠标回掉函数 voID onMouse(int event,int x,int y,int flag,void *ustg); int main() { imagesourcecopy = imread("Test.jpg"); imagesource = imagesourcecopy.clone(); //imshow("马赛克",imagesourcecopy); nameDWindow("马赛克"); setMouseCallBACk("马赛克",onMousE); waitKey(); } voID onMouse(int event,void *ustg) { if (event == CV_EVENT_LbuttonDOWN) { ptL = Point(x,y); } if (event == CV_EVENT_LbuttonUp) { //对鼠标画出的矩形框超出图像范围做处理,否则会越界崩溃 x > imagesource.cols - 2 * neightbourHood ? x = imagesource.cols - 2 * neightbourHood : x = x; y > imagesource.rows - 2 * neightbourHood ? y = imagesource.rows - 2 * neightbourHood : y = y; //对鼠标从右下往右上画矩形框的情况做处理 ptR = Point(x,y); Point pt = ptR; ptR.x < ptl.x ? ptR = ptL,ptL = pt : ptR = ptR; for (int i = 0; i < ptR.y - ptl.y; i += neightbourHood) { for (int j = 0; j < ptR.x - ptl.x; j += neightbourHood) { randomNum = rng.uniform(-neightbourHood / 2,neightbourHood / 2); Rect rect = Rect(j + neightbourHood + ptl.x,i + neightbourHood + ptl.y,neightbourHood,neightbourHood); Mat roi = imagesourcecopy(rect); Scalar sca = Scalar( imagesource.at<Vec3b>(i + randomNum + ptl.y,j + randomNum + ptl.X)[0],imagesource.at<Vec3b>(i + randomNum + ptl.y,j + randomNum + ptl.X)[1],j + randomNum + ptl.X)[2]); Mat roicopy = Mat(rect.size(),CV_8UC3,sca); roicopy.copyTo(roi); } } } imshow("马赛克",imagesourcecopy); waitKey(); }
可以通过改变程序中neightbourHood参数的大小调整小矩形快的大小,实现效果:
二、毛玻璃效果
毛玻璃效果的实现通过用像素点邻域内随机一个像素点的颜色替代当前像素点的颜色实现。
#include <core\core.hpp> #include <highgui\highgui.hpp> using namespace cv; int main() { Mat imagesource = imread("Test.jpg"); Mat imageResult = imagesource.clone(); RNG rng; int randomNum; int number = 5; for (int i = 0; i < imagesource.rows - number; i++) for (int j = 0; j < imagesource.cols - number; j++) { randomNum = rng.uniform(0,number); imageResult.at<Vec3b>(i,j)[0] = imagesource.at<Vec3b>(i + randomNum,j + randomNum)[0]; imageResult.at<Vec3b>(i,j)[1] = imagesource.at<Vec3b>(i + randomNum,j + randomNum)[1]; imageResult.at<Vec3b>(i,j)[2] = imagesource.at<Vec3b>(i + randomNum,j + randomNum)[2]; } imshow("毛玻璃效果",imageResult); waitKey(); }
实现效果:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。
以上是大佬教程为你收集整理的OpenCV实现马赛克和毛玻璃滤镜效果全部内容,希望文章能够帮你解决OpenCV实现马赛克和毛玻璃滤镜效果所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。