米粒图片处理
去除背景二值化
data:image/s3,"s3://crabby-images/6138a/6138a409408a499ecc80b7cff7527d999f6a85e4" alt=""
- 去除图像背景
data:image/s3,"s3://crabby-images/bd250/bd25098935fcc550d7525b3568a1b92d7c74450a" alt=""
I = imread('rice.png');
subplot(1,3,1); imshow(I);
BG = imopen(I, strel('disk', 15));
subplot(1,3,2); imshow(BG);
I2 = imsubtract(I, BG);
subplot(1,3,3); imshow(I2);
- 对图像二值化
data:image/s3,"s3://crabby-images/15bce/15bce6aa5fee2890cff09bfa145cba4135f21fc3" alt=""
I2 = imsubtract(I, BG); level=graythresh(I2);
bw2 = im2bw(I2, level);
- 所用函数
graythresh()
使用最大类间方差法找到图片的一个合适的阈值(threshold)。
m2bw()
使用阈值(threshold)变换法把灰度图像(grayscale image)转换成二值图像。
计数
data:image/s3,"s3://crabby-images/3ec27/3ec2784bb45fadea880ccafa6eb1f09b04bdef99" alt=""
bwlable
计算连通区域,该函数使用了连通区域标记算法,将每个连通区域内的像素点赋值为同一个值.
- 原理:
data:image/s3,"s3://crabby-images/024e7/024e769b16d60960ed13f9b27d8ca19ddc040d83" alt=""
data:image/s3,"s3://crabby-images/29b37/29b37e2047ff444cb8291e829d6ea1419c552ac9" alt=""
data:image/s3,"s3://crabby-images/29569/295693adbedc4926bac518b141e7372702baa50c" alt=""
- 代码实现:
I=imread('rice.png');
BG=imopen(I, strel('disk', 15));
I2=imsubtract(I, BG); level=graythresh(I2);
BW=im2bw(I2, level);
[labeled, numObjects]=bwlabel(BW, 8);
彩色显示
data:image/s3,"s3://crabby-images/bb7d3/bb7d3cc9e54df55b74b56529321f35fd465d4483" alt=""
I=imread('rice.png');
BG=imopen(I, strel('disk', 15));
I2=imsubtract(I, BG); level=graythresh(I2);
BW=im2bw(I2, level);
[labeled, numObjects]=bwlabel(BW, 8);
RGB_label=label2rgb(labeled); imshow(RGB_label);
结果分析
- 所需函数:
regionprops()
:可以将检测结果封装成结构体数组.
- 代码实现
I=imread('rice.png');
BG=imopen(I, strel('disk', 15));
I2=imsubtract(I, BG); level=graythresh(I2);
BW=im2bw(I2, level);
[labeled, numObjects]=bwlabel(BW, 8);
graindata = regionprops(labeled, 'basic');
graindata(51)
Area: 155
Centroid: [112.4258 245.8645]
BoundingBox: [108.5000 234.5000 8 22]
鼠标交互
- 所需函数:
bwselect()
:鼠标选择连通区域.
- 代码实现
I=imread('rice.png'); level=graythresh(I);
BG=imopen(I, strel('disk', 15));
I2=imsubtract(I, BG); BW=im2bw(I2, graythresh(I2));
ObjI = bwselect(BW); imshow(ObjI);
data:image/s3,"s3://crabby-images/c9933/c9933758f3173efd733c8d7dbcce0b59a98327ce" alt=""