How to use DockStyle.Fill for standard controls in WPF?

后端 未结 4 1827
醉梦人生
醉梦人生 2021-01-29 22:17

I\'m used from windows forms, that I create a panel, place controls inside it and give them DockStyle.Fill to max out their size to the surrounding panel.

I

4条回答
  •  暖寄归人
    2021-01-29 22:51

    The WPF equivalent of WinForms' DockStyle.Fill is:

    HorizontalAlignment="Stretch" VerticalAlignment="Stretch"
    

    This is the default for almost controls, so in general you don't have to do anything at all to have a WPF control fill its parent container: They do so automatically. This is true for all containers that don't squeeze their children to minimum size.

    Common Mistakes

    I will now explain several common mistakes that prevent HorizontalAlignment="Stretch" VerticalAlignment="Stretch" from working as expected.

    1. Explicit Height or Width

    One common mistake is to explicitly specify a Width or Height for a control. So if you have this:

    
      

    Just remove the Width and Height attributes:

    
      

    2. Containing panel squeezes control to minimum size

    Another common mistake is to have the containing panel squeezing your control as tight as it will go. For example a vertical StackPanel will always squeeze its contents vertically as small as they will go:

    
      

    Change to another Panel and you'll be good to go:

    
      

    Also, any Grid row or column whose height is "Auto" will similarly squeeze its content in that direction.

    Some examples of containers that don't squeeze their children are:

    • ContentControls never squeeze their children (this includes Border, Button, CheckBox, ScrollViewer, and many others)
    • Grid with a single row and column
    • Grid with "*" sized rows and columns
    • DockPanel doesn't squeeze its last child
    • TabControl doesn't squeeze its content

    Some examples of containers that do squeeze their children are:

    • StackPanel squeezes in its Orientation direction
    • Grid with an "Auto" sized row or column squeezes in that direction
    • DockPanel squeezes all but its last child in their dock direction
    • TabControl squeezes its header (what is displayed on the tab)

    3. Explicit Height or Width further out

    It's amazing how many times I see Grid or DockPanel given an explicit height and width, like this:

    
      

    In general you never want to give any Panel an explicit Height or Width. My first step when diagnosing layout problems is to remove every explicit Height or Width I can find.

    4. Window is SizeToContent when it shouldn't be

    When you use SizeToContent, your content will be squeezed to minimum size. In many applications this is very useful and is the correct choice. But if your content has no "natural" size then you'll probably want to omit SizeToContent.

提交回复
热议问题