File Exchange

image thumbnail

setFigDockGroup

version 1.4 (31.1 KB) by

Sets a figure's docking group container

15 Downloads

Updated

View License

setFigDockGroup sets a figure's (or list of figures') docking group container, enabling to dock figures to containers other than the default 'Figures' container (for example, to the 'Editor' group as shown in the screenshot, or to any new user-defined group, or even to another figure's button).
 
Syntax:
   hGroup = setFigDockGroup(hFig, group)
   hButton = setFigDockGroup(hFig, hButton)
 
Inputs:
   hFig is an optional handle or list of handles. These are normally figure handles, but not necessarily: the handles' containing figures are automatically inferred and used. If hFig is not supplied, then the current figure handle (gcf) is assumed.
 
   group is either a group name (e.g., 'Editor', 'Figures', 'my group') or a group handle returned from a previous setFigDockGroup function call.
 
   hButton is the handle of a uicontrol pushbutton on another figure. This button would typically be labeled "undock" or have an undocking icon. Note that the docked figure will be minimized to the target hButton - you will NOT be able to see the docked figure's contents in the target figure, only to undock it via the button. Docking into a figure panel will perhaps be added in some future version.
 
Outputs:
   The returned hGroupContainer object allows access to many useful properties and callbacks. Type "get(hGroupContainer)" to see the full list. Note that hGroupContainer may return empty ([]) if the group container is not visible.
 
See extended help within.
 
Warning:
   This code heavily relies on undocumented and unsupported Matlab functionality. It works on Matlab 7.4+, but use at your own risk!
 
Bugs and suggestions:
   Please send to Yair Altman (altmany at gmail dot com)

Comments and Ratings (13)

Jim Hokanson

Jim Hokanson (view profile)

Hi Yair,

A few things. On 2016b, I needed to comment out setting the userdata for the container, similar to Ian's message. I am also a bit confused by the usage, since it seems like the function just associates the docking group and doesn't actually dock the figure. Commenting out setting the oldStyle fixes this (line 182?). This is fine and could be fixed with an optional input, but it seems to contradict the documentation.

Thanks,
Jim

Ian Phillips

Hi Yair,
If I use: set(0,'DefaultFigureWindowStyle','docked')

hFig1 = figure('Name','One');
plot(sin(0:0.1:6.2));
hGroupContainer = setFigDockGroup(hFig1, 'myFigGroup');

I get the following error:
setFigDockGroup: Error using set
The name 'userdata' is not an accessible property for an instance of class
'com.mathworks.widgets.desk.DTDocumentContainer'.

Error in setFigDockGroup (line 196)
          set(hContainer,'userdata',group);

Error in test_setFigDockGroup (line 14)
hGroupContainer = setFigDockGroup(hFig1, 'myFigGroup');

If I use:
set(0,'DefaultFigureWindowStyle','normal');

hFig1 = figure('Name','One');
plot(sin(0:0.1:6.2));
hGroupContainer = setFigDockGroup(hFig1, 'myFigGroup');

Everything works ok. Is this a know issue?
I am using Matlab 2016a.

thanks for your help.

Yair Altman

Yair Altman (view profile)

@Jochen - the hGroupContainer returns empty ([]) if the group container is not visible.

Jochen

Jochen (view profile)

Dear Yair,
thanks for all your effort. I am successfully using multiple of your other submissions, but can't get this one to work on 8.6.0.267246 (R2015b).

hFig = figure('Name','One');
hGroupContainer = setFigDockGroup(hFig,'My App')

Returns an empty hGroupContainer, i.e. [].

Your generous help is greatly appreciated.

Thomas

Thomas (view profile)

Error in version R2014a.

line192: set(hContainer,'userdata',group);

throws error:

The name 'userdata' is not an accessible property for an instance of class 'com.mathworks.widgets.desk.DTDocumentContainer'.

This function is awesome!

Apparently the dock group window remembers its last layout (i.e. how many tiles it has and where they are located).
Is it possible to control which tile a given figure goes into?

Yair Altman

Yair Altman (view profile)

Jonathan - yes, this utility can indeed be used in deployed apps. If you need consulting help regarding docking, or Matlab in general, please contact me offline (altmany at gmail).

Can this be used in deployed applications?

Brian B

This is exactly what I was searching for!

Feature requests:

1) add functionality to close these docked group windows groups! ('close all' doesn't do the trick, as the group container remains)

2) keep the grouped windows from populating Matlab's Desktop menu list (The drop down alongside File | Edit | Debug |... ). It seems to include every single grouped window I create :(

almog shalom

Very nice!
Another useful function by Yair Altman.
On R2009a, JavaFrame still works, and I guess that when it won't work, there will be a replacement (I'm sure that Y. Altman will find it even it will be undocumented ;) )

jun ziyang

Very Usefull!
But the figure JavaFrame property will be obsoleted after R2008a. Hope there is a way around.

Dan Haeg

Great function.

Updates

1.4

Removed annoying warnings about possible future features removal (yes, we know...)

1.3

Fixes for Macs

1.2

Fix for R2011a

1.1

Enabled docking to a figure button (minimized), and undocking back from that figure button.

MATLAB Release
MATLAB 7.4 (R2007a)
Acknowledgements

Inspired: DOCK and UNDOCK figures into groups

Download apps, toolboxes, and other File Exchange content using Add-On Explorer in MATLAB.

» Watch video