Drawing Polygon shapes with data
조회 수: 3 (최근 30일)
이전 댓글 표시
Hello, I have such data,

The code which I am using to plot it is this
k = size(out,2); % k =1 since there is only one file in out struct
%% Drawing from the Data Files %
for i =1:1:k
a = size(out(i).model_data,1)
for j =1:1:(a-1)
x1(j) = [out(i).model_data(j,1)];
x2(j) = [out(i).model_data(j+1,1)];
y1(j) = [out(i).model_data(j,2)];
y2(j) = [out(i).model_data(j+1,2)];
rectangle('Position',[x1(j) x2(j) y1(j) y2(j)])
axis([0 0.02 0 0.2])
hold on
end
end
the result, which I am getting is this:

which is not correct, because all the rectangles should join each other, does any one know what to do?
댓글 수: 4
Turlough Hughes
2020년 1월 24일
Is this what you mean?
k = size(out,2);
for i =1:k
a = size(out(i).model_data,1);
for j =1:(a-1)
coord = out(i).model_data(j:j+1,:);
rectangle('Position',[coord(1,1) 0 coord(2,1)-coord(1,1) coord(1,2)])
axis([0 0.2 0 0.02])
hold on
end
end
If so I will move to the answer section.
채택된 답변
Turlough Hughes
2020년 1월 24일
You can draw the rectangles from your struct as follows:
k = size(out,2);
figure(), hold on
for i = 1:k
a = size(out(i).model_data,1);
for j =1:(a-1)
coord = out(i).model_data(j:j+1,:);
rectangle('Position',[coord(1,1) 0 coord(2,1)-coord(1,1) coord(1,2)])
axis([0 0.2 0 0.02])
end
end
When you have a non-scalar structure, this plots all rectangles on the same figure. For seperate figures you should move "figure(), hold on" into the first loop.
댓글 수: 3
Turlough Hughes
2020년 1월 26일
You would have no output, so it would go something like
function [] = myrectangles(out)
% code above
end
추가 답변 (1개)
Steven Lord
2020년 1월 25일
You could build a polyshape array with one element for each region that you want to draw. Once you've built your polyshape array you can plot it. I'm creating polyshape objects N using the nsidedpoly function, but you could call polyshape with the coordinates of the vertices to build the N's that are combined with union into the polyshape array.
A = polyshape;
for nsides = 3:6
N = nsidedpoly(nsides, 'Center', [nsides nsides], 'Radius', 0.5);
A = union(A, N);
end
plot(A)
댓글 수: 0
참고 항목
카테고리
Help Center 및 File Exchange에서 Elementary Polygons에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!