filling area enclosed by multiple curves

조회 수: 25 (최근 30일)
dileesh pv
dileesh pv 2022년 7월 12일
댓글: dileesh pv 2022년 7월 12일
I want to fill an area enclosed by multiple curves. I'm currently using the fill command to achieve it. Below is the figure I'm getting. Ideally, i should get the filled in color only inside the enclosed space (on the right side). Fill command worked for me in my earlier usage. Not sure what is happening here!
xdata and ydata are attached along with. The code I'm using has bee given below;
fileID = fopen('dataX.txt','r');
formatSpec = '%f';
xd = fscanf(fileID,formatSpec);
fileID = fopen('dataY.txt','r');
formatSpec = '%f';
yd = fscanf(fileID,formatSpec);
figure(101)
fill(xd,yd,'g','facealpha',0.3);axis equal
Any clue to sort this out is appreciated.
Thanks
  댓글 수: 4
dpb
dpb 2022년 7월 12일
Have you tried reversing the direction? Probably won't matter, but...
Alternatively to figuring out what's wrong here, you could try to draw second patch of the LH side that follows the bifurcation and then the three points and see if can fill it with background color to simulate the effect. A hack, yes, but...
Otherwise try patch() or break the above into mutiple sections -- looks like the pointy ends are confusing area as to what it's trying to enclose.
dileesh pv
dileesh pv 2022년 7월 12일
@dpb.. Yes I tried them all :).. @John D'Errico's solution worked like charm and I will try @Star Strider's suggestion too..
Thanks a lot for your time!

댓글을 달려면 로그인하십시오.

채택된 답변

John D'Errico
John D'Errico 2022년 7월 12일
편집: John D'Errico 2022년 7월 12일
No problem (as long as you use a more capable tool), although it appears you have duplicate points.
X = load('dataX.txt');
Y = load('dataY.txt');
PS = polyshape(X,Y);
Warning: Polyshape has duplicate vertices, intersections, or other inconsistencies that may produce inaccurate or unexpected results. Input data has been modified to create a well-defined polyshape.
plot(PS)
axis equal
  댓글 수: 1
dileesh pv
dileesh pv 2022년 7월 12일
편집: dileesh pv 2022년 7월 12일
Thanks a lot. It worked smooth. I was creating this shape by combining three curves. Therefore, as you rightly suggested, there could be few overlapping points which might be creating duplicates in the corners. Even though I tried by removing those end points, fill/patch were not giving me desired results.
Thanks again for this solution! It worked for all the cases I was looking for!

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

Help CenterFile Exchange에서 2-D and 3-D Plots에 대해 자세히 알아보기

제품

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by