FrameworkElement.LayoutTransform Propiedad

Definición

Obtiene o establece una transformación gráfica que debe aplicarse a este elemento cuando se realiza el diseño.Gets or sets a graphics transformation that should apply to this element when layout is performed.

public:
 property System::Windows::Media::Transform ^ LayoutTransform { System::Windows::Media::Transform ^ get(); void set(System::Windows::Media::Transform ^ value); };
public System.Windows.Media.Transform LayoutTransform { get; set; }
member this.LayoutTransform : System.Windows.Media.Transform with get, set
Public Property LayoutTransform As Transform

Valor de propiedad

Transformación que este elemento debe utilizar.The transform this element should use. El valor predeterminado es Identity.The default is Identity.

Ejemplos

En el ejemplo siguiente se muestra cómo aplicar un LayoutTransform a un elemento.The following example shows how to apply a LayoutTransform to an element. En el ejemplo se crea una instancia de Button y se hospeda en un Gridprimario.The example creates an instance of Button and hosts it within a parent Grid. También utiliza la propiedad LayoutTransform para aplicar un RotateTransform al Button.It also uses the LayoutTransform property to apply a RotateTransform to the Button.


Button^ btn2 = gcnew Button();
btn2->Background = Brushes::LightCoral;
btn2->Content = "RotateTransform";
btn2->LayoutTransform = gcnew RotateTransform(45, 25, 25);
Grid::SetRow(btn2, 0);
Grid::SetColumn(btn2, 1);
grid1->Children->Add(btn2);


Button btn2 = 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);


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>

Comentarios

A diferencia de RenderTransform, LayoutTransform afectará a los resultados del diseño.In contrast to RenderTransform, LayoutTransform will affect results of layout.

La configuración de una transformación proporciona capacidades eficaces de escalado y rotación.Setting a transform provides powerful capabilities of scaling and rotating. Sin embargo, LayoutTransform omite TranslateTransform operaciones.However, LayoutTransform ignores TranslateTransform operations. Esto se debe a que el comportamiento del sistema de diseño para los elementos secundarios de una FrameworkElement corrige automáticamente cualquier desplazamiento a la posición de un elemento escalado o girado en el diseño y el sistema de coordenadas del elemento primario.This is 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.

LayoutTransform puede provocar un rendimiento deficiente de la aplicación si se invoca en un escenario que no requiere un paso completo por parte del sistema de diseño.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. Cuando se aplica un LayoutTransform a la colección Children de la Panel, desencadena un nuevo paso por el sistema de diseño y obliga a que se vuelvan a medir y reorganizar todos los objetos en pantalla.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. Si está actualizando la aplicación completa interfaz de usuario (UI)user interface (UI), esta funcionalidad podría ser exactamente lo que necesita.If you are updating the complete application interfaz de usuario (UI)user interface (UI), this functionality might be exactly what you need. Sin embargo, si no necesita un paso de diseño completo, use la propiedad RenderTransform, que no invoca el sistema de diseño y, por lo tanto, suele ser una opción mejor para este escenario.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.

Algunos escenarios de ejemplo en los que LayoutTransform sería útil: girar elementos como componentes de menú de horizontal a vertical o viceversa, escalar elementos (acercar) sobre el foco, proporcionar un comportamiento de edición, etc.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.

Información sobre propiedades de dependenciaDependency Property Information

Campo de identificadorIdentifier field LayoutTransformProperty
Propiedades de metadatos establecidas en trueMetadata properties set to true AffectsMeasure

Se aplica a

Consulte también: