Using plot handle to replot a graph

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))

 Respuesta aceptada

Les Beckham
Les Beckham el 13 de Ag. de 2022
Editada: Les Beckham el 13 de Ag. de 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

Más respuestas (1)

Ethan Welch
Ethan Welch el 13 de Ag. de 2022
Editada: Ethan Welch el 13 de Ag. de 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 comentarios

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 el 13 de Ag. de 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.

Iniciar sesión para comentar.

Categorías

Más información sobre Creating, Deleting, and Querying Graphics Objects en Centro de ayuda y File Exchange.

Productos

Versión

R2020b

Preguntada:

el 13 de Ag. de 2022

Comentada:

el 13 de Ag. de 2022

Community Treasure Hunt

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

Start Hunting!

Translated by