Your Privacy Matters: We use our own and third-party cookies to improve your experience on our website. By continuing to use the website we understand that you accept their use. Cookie Policy
770
Question about xamDockManager/SplitPane behaviour when floating / docking
posted

Hello,

I noticed that, when docked, the SplitPane / ContentPane is autosizing with his content. 

For example, in my ContentPane, I have a stackpanel with vertical orientation and three expanders in it. When I collapse one of the expanders, the height of the SplitPane is automatically reduced with the height of the collapsed expander.

I think this is great :-)

But if I make the SplitPane float and then, I dock it again, the "autosize" behaviour is not working anymore. 

I thought it may be because of my code in the ultraDockManager1_ToolWindowLoaded method but it's not that. 

Is there a way to make it works or is it a native behaviour we can't override ? 

I tried to change some properties of the pane in the ultraDockManager1_PaneDragEnded method but nothing happens so far. 

Thank you in advance.

 

  • 54937
    Verified Answer
    Offline posted

    By default the Width and Height of the SplitPane are NaN. So for a SplitPane docked to the top/bottom, it's width is governed by the available width of the dockmanager (or whatever horizontal room is left after measuring the SplitPanes that are closer to the outside edge than it). However since the Height is unspecified the SplitPane measures the content with the available size and then returns whatever is the desired size resulting from that. However once you assign a Height (implicitly or explicitly) to that root SplitPane then that is the height of the element - actually regardless of what you measure an element with the WPF framework will provide that constrained extent. By default we don't assume what Height you want for a SplitPane so it was in essence auto sizing for you. Had you set a Height on the root split pane or dragged the adjacent splitter bar (which would set the Height to an explicit height) then that is the height that would have been used to arrange the contained panes. Similarly when you drag a floating window to be docked to the dockmanager, it is the size of the window that is used to calculate the extent of the splitpane created and so that splitpane has a fixed extent (at least when it is a root splitpane). So in theory you could enumerate the panes provided to the PaneDragEnded, walk up to the root splitpane and clear its extent (assuming it is a new root split pane) but then the drop rect won't accurately reflect what the target size/location will be (as that will be based on the size that we would want to make the splitpane based on the floating size) and also the end user could still drag the adjacent split pane and cause an explicit extent to be set.