Мне нужно создать бинарную маску. У меня есть некоторые координаты, и я делаю эти координаты и внутри этой области равными 1, а фон равен нулю.
Вот что я сделал, но проблема в том, что ROI находится не в правильном положении и находится в правом нижнем углу изображения. Я ценю, если кто-то может указать мне правильное направление.
function [X,Y, BW] = Create_mask(X,Y,im)
X = round(X);
Y = round(Y);
X ( X < 1 ) = 1;
Y ( Y < 1 ) = 1;
BW = im > 255;
for p = 1:length(X)
BW(Y(p),X(p)) = 1;
end
for n = 0:(1/round(sqrt((X(end)-X(1))^2 + (Y(end)-Y(1))^2 ))):1
xn = round(X(1) +(X(end) - X(1))*n);
yn = round(Y(1) +(Y(end) - Y(1))*n);
BW(yn,xn) = 1;
end
se = strel('disk',10);
BW = imclose(BW,se);
BW = imdilate(BW,se);
BW = imfill(BW,'holes');
im( im < 255 ) = 0;
im = imclose(im,se);
BW = BW * 255;
BW = im2uint8(BW);
% BW = imresize(BW, [256 256],'nearest');
figure;
imshow(BW);
% close all;
end
Вот вывод функции:
I ожидал быть похожим на это изображение. Это не точное решение, но оно показывает мои ожидания.
Координаты X и Y прикреплены здесь , первый столбец X и второй Y.