Using plot handle to replot a graph

61 vues (au cours des 30 derniers jours)
Ethan Welch
Ethan Welch le 13 Août 2022
Commenté : Les Beckham le 13 Août 2022
In my project, I make an array of graphs. If one of the graphs is interesting, I would like to copy that graph with all of its formatting to a separate figure. I would like to do something like this. I know I could just replot everything, but a lot goes into each graph, and this seems like it should be possible.
x = 0:0.1:10;
y = [sin(x);cos(x);tan(x)];
for i = 1:3;
subplot(1,3,i)
p(i) = plot(x,y(i,:));
end
figure
plot(p(2))

Réponse acceptée

Les Beckham
Les Beckham le 13 Août 2022
Modifié(e) : Les Beckham le 13 Août 2022
Read the documentation for the copyobj function. Here is an example:
x = 0:0.1:10;
y = [sin(x);cos(x);tan(x)];
for i = 1:3;
a(i) = subplot(1,3,i);
p(i) = plot(x,y(i,:));
end
f = figure;
copyplot = copyobj(p(2), gca); % copy the plot from subplot 2 to the newly created axis in f

Plus de réponses (1)

Ethan Welch
Ethan Welch le 13 Août 2022
Modifié(e) : Ethan Welch le 13 Août 2022
Thank you for your help. Now I realize I need one step further. I have multiple plots on the same graph and only the last plot is copied over. Is there a way to copy them all at once?
x = 0:0.1:10;
y = [sin(x);cos(x);tan(x)];
for i = 1:3
a(i) = subplot(1,3,i);
hold on
plot(x,y(i,:));
p(i) = plot(x,y(mod(i+1,3)+1,:));
hold off
end
f = figure;
copyplot = copyobj(p(2), gca);
  2 commentaires
Ethan Welch
Ethan Welch le 13 Août 2022
Okay, I figured it out.
x = 0:0.1:10;
y = [sin(x);cos(x);tan(x)];
for i = 1:3
a(i) = subplot(1,3,i);
hold on
p(i) = plot(x,y(i,:));
plot(x,y(mod(i+1,3)+1,:))
hold off
end
f = figure;
copyplot = copyobj(a(2).Children, gca);
Les Beckham
Les Beckham le 13 Août 2022
Great. Exactly what I was going to suggest. That's how to learn: read the docs and experiment until you get the result that you want.

Connectez-vous pour commenter.

Catégories

En savoir plus sur 2-D and 3-D Plots dans Help Center et File Exchange

Produits


Version

R2020b

Community Treasure Hunt

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

Start Hunting!

Translated by