MATLAB 获取图像轮廓线

 转载自:https://blog.csdn.net/q1302182594/article/details/50394576

本文主要总结一下在matlab中可用于进行轮廓提取的函数。

1 bwperim

    根据参考资料[2]的提示,可以使用bwperim()函数进行轮廓提取,具体代码如下:

[cpp]  view plain  copy
  1. %读取原图  
  2. im = imread( filepath );                
  3. imshow(im);  
  4. title('原图');                         
  5.   
  6. % 转二值图像  
  7. bw = im2bw( im );                         
  8.   
  9.  %轮廓提取     
  10. contour = bwperim(bw);                    
  11. figure  
  12. imshow(contour);  
  13. title('轮廓')  

    原图和所提取的轮廓分别如图1和图2所示。

                   图1 原图


                    图2 轮廓

2 edge

    可以借助edge()函数进行边界检测,算子可以选择canny,soble等等。具体代码如下:

[cpp]  view plain  copy
  1. %读取原图  
  2. im = imread( filepath );                
  3. imshow(im);  
  4. title('原图');                         
  5.   
  6. % 转二值图像  
  7. bw = im2bw( im );                         
  8. % 边界检测  
  9. contour = edge(bw ,'canny');  
  10. figure  
  11. imshow(contour);  
  12. title('边界')  
    对图1的检测效果如图3所示:


                       图3 edge检测结果


参考资料

[1]轮廓提取

[2]matlab 二值图像 外轮廓提取

[3]matlab 二进制图像轮廓提取

  • 4
    点赞
  • 58
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MATLAB中,可以使用图像处理工具箱中的函数来进行图像轮廓线拟合。一种常用的方法是使用多项式拟合或样条插值来逼近图像轮廓的曲线。 以下是一种基本的图像轮廓线拟合的步骤: 1. 读取图像并进行预处理:使用imread函数读取图像,并对图像进行预处理,例如灰度化、二值化等操作,以便得到二值图像。 2. 提取图像轮廓:使用边缘检测算法(如Canny边缘检测)或者轮廓提取算法(如findContours函数)来提取图像的轮廓。 3. 进行曲线拟合:对提取到的轮廓点集进行曲线拟合。可以使用polyfit函数进行多项式拟合,或者使用interp1函数进行样条插值。 4. 绘制拟合曲线:使用plot函数将拟合曲线绘制在原始图像上,以便观察拟合效果。 下面是一个简单的示例代码,演示了如何在MATLAB中进行图像轮廓线拟合: ```matlab % 读取图像并进行预处理 image = imread('image.jpg'); grayImage = rgb2gray(image); binaryImage = imbinarize(grayImage); % 提取图像轮廓 contour = bwboundaries(binaryImage); contour = contour{1}; % 假设只有一个轮廓 % 进行曲线拟合 p = polyfit(contour(:, 2), contour(:, 1), 3); % 三次多项式拟合 % 生成拟合曲线 x = min(contour(:, 2)):max(contour(:, 2)); y = polyval(p, x); % 绘制拟合曲线 imshow(image); hold on; plot(x, y, 'r', 'LineWidth', 2); hold off; % 相关问题: % 1. 什么是图像轮廓? % 2. MATLAB中如何读取图像? % 3. MATLAB中如何进行图像预处理? ``` 希望对你有帮助!如果有任何问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值