OpenCV实现开操作、闭操作、形态学梯度、顶帽、黑帽
一、概述
案例:利用opencv实现开操作、闭操作、形态学梯度、顶帽、黑帽
二、示例图
1.开操作
2.闭操作
3.形态学梯度
4.顶帽
5.黑帽
三、示例代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 | //开操作:先腐蚀后膨胀,可以去掉小的对象 //闭操作:先膨胀、后腐蚀,可以填充小的洞 //形态学梯度:又称为基本梯度,基本原理是:膨胀减去腐蚀 //顶帽:原图像与开操作之间的差值图像 //黑帽:原图像与闭操作图像的差值图像 // #include <opencv2/opencv.hpp> #include <iostream> using namespace cv; using namespace std; void getGray(); void getThreshold(); Mat src,dst,gray,thresholdMat; /**获取原生图像*/ int getSrc(){ src = imread( "girl.jpg" ); if (!src.data){ cout << "can't load image..." <<endl; return -1; } imshow( "src" ,src); // getGray(); // getThreshold(); return 0; } /**对图像进行灰度处理*/ void getGray(){ //转换色彩空间--->将彩色图转换为灰度图 cvtColor(src,gray,COLOR_BGR2GRAY); imshow( "gray" ,gray); } /** * 对图像进行二值分割 * */ void getThreshold(){ threshold(gray,thresholdMat,0,255,THRESH_OTSU); imshow( "thresholdMat" ,thresholdMat); } /** * 开操作 * */ void openOption(){ getSrc(); Mat kernel = getStructuringElement(MORPH_RECT,Size(7,7),Point(-1,-1)); morphologyEx(src,dst,MORPH_OPEN ,kernel); imshow( "dst" ,dst); } /** * 闭操作 * */ void closeOption(){ getSrc(); Mat kernel = getStructuringElement(MORPH_RECT,Size(5,5),Point(-1,-1)); morphologyEx(src,dst,MORPH_CLOSE,kernel); imshow( "dst" ,dst); } /** * * 形态学梯度:突出高亮区域的外围、为轮廓查找提供思路 * */ void gradOption(){ getSrc(); Mat kernel = getStructuringElement(MORPH_RECT,Size(5,5),Point(-1,-1)); morphologyEx(src,dst,MORPH_GRADIENT,kernel); imshow( "dst" ,dst); } /** * 顶帽操作:用于背景提取、顶帽运算往往用来分离比临近点亮一些的斑点,当一副图像具有大幅背景的时候,而微小物品比较有规律的 情况下可以用顶帽运算进行背景提取 * */ void topOption(){ getSrc(); Mat kernel = getStructuringElement(MORPH_RECT,Size(5,5),Point(-1,-1)); morphologyEx(src,dst,MORPH_TOPHAT,kernel); imshow( "dst" ,dst); } /** * 黑帽操作 * */ void blackOption(){ getSrc(); Mat kernel = getStructuringElement(MORPH_RECT,Size(5,5),Point(-1,-1)); morphologyEx(src,dst,MORPH_BLACKHAT,kernel); imshow( "dst" ,dst); } int main( int argc, char const *argv[]) { // openOption(); // closeOption(); // gradOption(); // topOption(); blackOption(); waitKey(0); return 0; } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
· SQL Server 2025 AI相关能力初探