#1,041 – Stretched Child Elements Not Stretched when Rotated
April 1, 2014 2 Comments
A value of Stretch for HorizontalAlignment or VerticalAlignment means that a child control should be stretched to fill the available width (HorizontalAlignment) or height (VerticalAlignment). This is the default setting for child elements in a StackPanel.
If a rotate or skew transform is being applied using a LayoutTransform, however, the element will only be stretched when the rotation or skew angle is a multiple of 90.
In the example below, notice that the middle button is initially stretched, but then is not stretched as soon as we start rotating it. It is stretched again once we rotate it by 90 and 180 degrees.
<StackPanel> <Slider Name="sliRotate" Margin="10,10,10,0" Minimum="0" Maximum="359" TickFrequency="1" IsSnapToTickEnabled="True"/> <Label Content="{Binding Path=Value, ElementName=sliRotate}" HorizontalAlignment="Center" Margin="0,0,0,10"/> <Button Content="Eat" Padding="0,5"/> <Button Content="Love" Padding="0,5"> <Button.LayoutTransform> <RotateTransform Angle="{Binding Path=Value, ElementName=sliRotate}"/> </Button.LayoutTransform> </Button> <Button Content="Pray" Padding="0,5"/> </StackPanel>
Looks stretched to me, how else would the item fit into the box with the given height or width?
Make the box large enough to allow stretching without cropping, and it will work:
Meh, code was not sumbitted… =(