gui coded with uifigure

45 次查看(过去 30 天)
Alain Barraud
Alain Barraud 2024-6-17
评论: Alain Barraud 2024-8-14,15:38
Hi every body,
I have coded a moderatly complex gui first within a standard figure and a second version within a uifigure. As usually observed the second version is very very slow compared against the first one. This is not my problem. To obtain a correct gui I must execute ma code in debug mode step by step. Otherwise, the gui is very strange as if each graphic object was not finished before the next one begins to be buit. I have tried to add pause, drawnow, drownow limiterate, uifigure visible off until the last command... Nothing works.
Any idea to find a workaround?
Thank a lot
  17 个评论
Mario Malic
Mario Malic 2024-6-28
编辑:Mario Malic 2024-6-28
Alright, I have encountered this issue. I think what helps is, if you resize the figure, and it will update the layout.
I don't know the reason why this would happen.

请先登录,再进行评论。

采纳的回答

Alice
Alice 2024-8-10,16:37
For figures created via the uifigure() function and for containers within a uifigure, the property AutoResizeChildren will be 'on' by default. This means that AutoResizeChildren will try to resize the content when the uifigure is resized, without the need to write a SizeChangedFcn callback or to use uigridlayout.
An important note about AutoResizeChildren: it will resize components even if the components are in normalized units, and treat them as if they were in pixels units.
In this case, AutoResizeChildren on the panel that contains the uitabgroup is not working well because the panel is positioned by a uigridlayout, but the content is absolutely positioned. It is not recommended to mix absolute positioning and use of uigridlayout.
Here is my recommendation:
- If you would like to leverage normalized units, turn off AutoResizeChildren on all containers within the uifigure using the following right after the uifigure call:
set(IdD.Container, 'DefaultUipanelAutoresizechildren', 'off');
set(IdD.Container, 'DefaultUitabAutoresizechildren', 'off');
- Alternatively, use uigridlayout throughout the app. In other words, insert a uigridlayout between containers and their content, e.g. between the uipanel and the uitabgroup, and between the uitab and the axes.
  1 个评论
Alain Barraud
Alain Barraud 2024-8-14,15:38
The code I sent works correctly adding this two lines. I think using uifigure and coding manually must be done very rigouresly. My full code using uifigure does not work correctly the GUI remains very strange with superposition or bad sized components. The figure version works nicely without any issues.
Thanks a lot for the time spent around this question
Alain

请先登录,再进行评论。

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 Graphics Object Programming 的更多信息

标签

产品


版本

R2024a

Community Treasure Hunt

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

Start Hunting!

Translated by