How can I force legend not to overlap the graph?

125 visualizaciones (últimos 30 días)
GIorgi Tsutskiridze
GIorgi Tsutskiridze el 17 de Jun. de 2019
Comentada: Olivia Plunkett el 7 de Nov. de 2020
I am trying to save figure from .fig to png format but the legend changes its place.
The .fig file that I am trying to save .png from is attached to the post. On my screen it looks like the following (produced using snipping tool on windows).
For forum.PNG
So, I want to save png exactly in the same form as it appears here on the screen. For this I click on File>Save As>Choose png format and save but it results in the following picture.png
for_forum.png
As you clearly see, legened is overlapped. Also the resolution of the picture is 768x576 which is almost quadratic. I want it to be more like a perpenndicular (wider as it is above produced using snipping tool)
Can anyone help me resolve this problem?

Respuestas (2)

Ruger28
Ruger28 el 17 de Jun. de 2019
legend(legendNames,'Location','southeastoutside')
This will shift the legend outside of the graph. you can try
legend(legendNames,'Location','best') % or best outside
for a different view.
  2 comentarios
GIorgi Tsutskiridze
GIorgi Tsutskiridze el 17 de Jun. de 2019
Editada: GIorgi Tsutskiridze el 17 de Jun. de 2019
Unfortunately, I do not have the code. What I have is only .fig file. Is not it possible to do it using dialogbox?
Olivia Plunkett
Olivia Plunkett el 7 de Nov. de 2020
The default legend placement obscured part of my graph, but this fixed the problem. Thanks!

Iniciar sesión para comentar.


Abdulaziz Milhem
Abdulaziz Milhem el 17 de Abr. de 2020
you can use the following:
openfig('figurename.fig')
legend('Location','best');
  1 comentario
Walter Roberson
Walter Roberson el 17 de Abr. de 2020
It would be a bit more complicated than that. The original poster shows four or more axes, and legends are associated with axes (but are not children of axes). It would be necessary to find the legend object. Possibly
fig = openfig('figurename.fig');
legobjs = findall(fig, 'type', 'legend');
for K = 1 : length(legobjs) %loop in case there are several
legobjs(K).Location = 'best';
end
However in my brief test, "best" turned out to be right on top of a line, whereas northwest inside would have been fine in my test. So it might be necessary to tweak the "best"

Iniciar sesión para comentar.

Etiquetas

Productos


Versión

R2018a

Community Treasure Hunt

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

Start Hunting!

Translated by