I was wondering if I can have 2 controls in a horizontal-oriented StackPanel so that the right item should be docked to the right side of the StackPanel.
I tried the following but it didn’t work:
<StackPanel Orientation="Horizontal">
<TextBlock>Left</TextBlock>
<Button Width="30" HorizontalAlignment="Right">Right<Button>
</StackPanel>
In the snippet above I want the Button to be docked to the right side of the StackPanel.
Note: I need it to be done with StackPanel, not Grid etc.
You can achieve this with a
DockPanel:The difference is that a
StackPanelwill arrange child elements into single line (either vertical or horizontally) whereas aDockPaneldefines an area where you can arrange child elements either horizontally or vertically, relative to each other (theDockproperty changes the position of an element relative to other elements within the same container. Alignment properties, such asHorizontalAlignment, change the position of an element relative to its parent element).Update
As pointed out in the comments you can also use the
FlowDirectionproperty of aStackPanel. See @D_Bester’s answer.