Assembly: PresentationFramework (in presentationframework.dll)
XML Namespace: http://schemas.microsoft.com/winfx/2006/xaml/presentation
'Declaration Public Property LayoutTransform As Transform 'Usage Dim instance As FrameworkElement Dim value As Transform value = instance.LayoutTransform instance.LayoutTransform = value
/** @property */ public Transform get_LayoutTransform () /** @property */ public void set_LayoutTransform (Transform value)
public function get LayoutTransform () : Transform public function set LayoutTransform (value : Transform)
Property ValueThe transform this element should use. The default is Identity.
In contrast to RenderTransform, LayoutTransform will affect results of layout.
Setting a transform provides powerful capabilities of scaling and rotating. However, LayoutTransform ignores TranslateTransform operations. This is because because the layout system behavior for child elements of a FrameworkElement auto-corrects any offsets to the position of a scaled or rotated element into the layout and coordinate system of the parent element.
Example scenarios where LayoutTransform would be useful include: rotating elements such as menu components from horizontal to vertical or vice versa, scaling elements (zooming in) on focus, providing editing behavior, etc.
This example shows how to apply a LayoutTransform to an element. The example creates an instance of Button and hosts it within a parent Grid. It also uses the LayoutTransform property to apply a RotateTransform to the Button.
Performance Note: Before using LayoutTransform, be sure that you understand how this property can affect performance.
LayoutTransform can lead to poor application performance if you invoke it in a scenario that does not require a full pass by the layout system. When you apply a LayoutTransform to the Children collection of the Panel, it triggers a new pass by the layout system and forces all on-screen objects to be remeasured and rearranged. If you are updating the complete application user interface (UI), this functionality might be exactly what you need. However, if you do not need a full layout pass, use the RenderTransform property, which does not invoke the layout system, and therefore, is typically a better choice for this scenario.
Dim btn2 As New Button() btn2.Background = Brushes.LightCoral btn2.Content = "RotateTransform" btn2.LayoutTransform = New RotateTransform(45, 25, 25) Grid.SetRow(btn2, 0) Grid.SetColumn(btn2, 1) grid1.Children.Add(btn2)
<Button Grid.Row="0" Grid.Column="1" Background="LightCoral" Content="RotateTransform Applied"> <Button.LayoutTransform> <RotateTransform CenterX="25" CenterY="25" Angle="45" /> </Button.LayoutTransform> </Button>
For the complete sample, which shows each of the available layout transforms, see Applying a LayoutTransform to an Element Sample.
Windows 98, Windows Server 2000 SP4, Windows CE, Windows Millennium Edition, Windows Mobile for Pocket PC, Windows Mobile for Smartphone, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter EditionThe Microsoft .NET Framework 3.0 is supported on Windows Vista, Microsoft Windows XP SP2, and Windows Server 2003 SP1.