%本脚本的作用是:在图像中随机取两点,统计两点之间的像素,
clc;
clear all;
img = imread('F:\DataSet\retina Vessal\all\images\01_dr.jpg');
img = rgb2gray(img);
figure(1), imshow(img);
hold on;
%取点
[coordX, coordY] = ginput(2);
%连线
line([coordX(1) coordY(1)], [coordX(2) coordY(2)], 'Color', 'c');
%线的长度占多少个像素
linelength = ceil(sqrt((ceil(coordX(2)) - floor(coordX(1)))^2 + ...
(ceil(coordY(2)) - floor(coordY(1)))^2));
%存储线的灰度值
linepts = zeros(linelength, 2);
idx1 = 1;
idx2 = 1;
for idxx = floor(coordX(1)):ceil(coordX(2))
for idxy = floor(coordY(1)):ceil(coordY(2))
linepts(idx1, idx2) = img(idxx, idxy);
idx1 = idx1 + 1;
idx2 = idx2 + 1;
end
end
hold off;
怎么不能正确显示呢?
修改如下:
%本脚本的作用是:在图像中随机取两点,统计两点之间的像素,
%并将其灰度值绘制成一个曲线图(类似直方图&