要达到的目的:提取颗粒图像的边缘,然后将颗粒图像用椭圆拟合。在实现的代码如下:
I1=imread('F:\automatic\pic\photo\particleOverlap1.bmp');
I2=im2bw(rgb2gray(I1));
ie=edge(I2,'canny');
figure,imshow(ie);
hold on;
[x y pixelvalue]=find(ie);
plot(x,y,'r.')
hold off;
运行的结果是find后的图像竟然与原图方向不同,倾斜了一定角度,所以拟合后的椭圆也倾斜了。
请高手们帮帮我。
clear;clc
I1=imread('particleOverlap2.jpg');
I2=im2bw(rgb2gray(I1));
ie=edge(double(I2),'canny');
figure,imshow(ie);
hold on;
[x y pixelvalue]=find(ie');
plot(x,y,'r.')
hold off;