Update multiple plot fills using XData and YData

조회 수: 14 (최근 30일)
Jeremy
Jeremy 2018년 1월 29일
댓글: Walter Roberson 2018년 1월 30일
I was doing the following to generate n filled areas on a graph between n pairs of upper and lower curves.
for i = 1:n
x = % x values, function of i
y1 = % upper curve, function of i
y2 = % lower curve, function i
fill([x fliplr(x)], [y2 fliplr(y1)]);
hold on
end
However, I need to be able to plot an empty fill, and then add the fills in a loop using XData and YData, like this (I know the following won't work, but schematically)
h = fill(nan, nan, 'r');
for i = 1:n
x = % x values, function of i
y1 = % upper curve, function of i
y2 = % lower curve, function i
h(i).XData = [x fliplr(x)]
h(i).YData = [y2 fliplr(y1)]
end
What's the proper way to do this? My need for this stems from using scrollplots, which doesn't work well with re-plotting the data, but instead you need to update the data of the existing plot if changes are made. Any ideas?
  댓글 수: 1
Jan
Jan 2018년 1월 29일
It is not clear, what you want to do. What is "an empty fill"? "Doesn't work well" is no clear description of the problem you have.

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

답변 (1개)

Jan
Jan 2018년 1월 29일
편집: Jan 2018년 1월 29일
[EDITED] Sorry, I've posted some nonsense code here by accident. Thanks, Walter. I do not remove the answer to keep the valuable comments.
  댓글 수: 8
Jeremy
Jeremy 2018년 1월 30일
I also tried (with just 3 entries)
(this works)
p3 = [fill(nan, nan, 'r') fill(nan, nan, 'r') fill(nan, nan, 'r')
and
(this doesn't)
p3(1, 1:3) = fill(nan, nan, 'r')
Replacing the x & y data of both attempts in a loop with
p3(1, i).XData = [x fliplr(x)];
p3(1, i).YData = [y2 fliplr(y1)];
Any reason why those two behave differently?
Walter Roberson
Walter Roberson 2018년 1월 30일
p3(1, 1:3) = fill(nan, nan, 'r') would assign the same patch handle to those elements.
The easiest fix is to loop. But you could use an implicit loop such as
arrayfun(@(~) fill(nan,nan), 1:3)

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

카테고리

Help CenterFile Exchange에서 Annotations에 대해 자세히 알아보기

태그

제품

Community Treasure Hunt

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

Start Hunting!

Translated by