我是靠谱客的博主 坦率毛豆,最近开发中收集的这篇文章主要介绍OpenCV拉普拉斯算子使用,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

拉普拉斯算子的计算在浮点数类型的图像上进行。要对结果做缩放处理才能使其正常显示。缩放基于拉普拉斯算子的最大绝对值,其中数值 0 对应灰度级 128。类中有一个方
法可获得下面的图像表示:

// 获得拉普拉斯结果,存在 8 位图像中
// 0 表示灰度级 128
// 如果不指定缩放比例,那么最大值会放大到 255
// 在调用这个函数之前,必须先调用 computeLaplacian 
cv::Mat getLaplacianImage(double scale=-1.0) { 
 if (scale<0) { 
 double lapmin, lapmax; 
 // 取得最小和最大拉普拉斯值
 cv::minMaxLoc(laplace,&lapmin,&lapmax); 
 // 缩放拉普拉斯算子到 127
 scale= 127/ std::max(-lapmin,lapmax); 
 } 
 // 生成灰度图像
 cv::Mat laplaceImage; 
 laplace.convertTo(laplaceImage,CV_8U,scale,128); 
 return laplaceImage; 
} 

使用这个类,从 7×7 内核计算拉普拉斯图像的方法为:

// 用 LaplacianZC 类计算拉普拉斯算子
LaplacianZC laplacian; 
laplacian.setAperture(7); // 7×7 的拉普拉斯算子
cv::Mat flap= laplacian.computeLaplacian(image); 
laplace= laplacian.getLaplacianImage(); 

最后

以上就是坦率毛豆为你收集整理的OpenCV拉普拉斯算子使用的全部内容,希望文章能够帮你解决OpenCV拉普拉斯算子使用所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(52)

评论列表共有 0 条评论

立即
投稿
返回
顶部