FrameworkElement.LayoutTransform FrameworkElement.LayoutTransform FrameworkElement.LayoutTransform FrameworkElement.LayoutTransform Property

Definition

Ruft eine Grafiktransformation ab, die auf dieses Element angewendet werden soll, wenn Layout ausgeführt wird, oder legt diese fest.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

Eigenschaftswert

Die Transformation, die dieses Element verwenden soll.The transform this element should use. Die Standardeinstellung ist Identity.The default is Identity.

Beispiele

Das folgende Beispiel zeigt, wie Sie Anwenden einer LayoutTransform auf ein Element.The following example shows how to apply a LayoutTransform to an element. Das Beispiel erstellt eine Instanz des Button an und hostet es in einem übergeordneten Grid.The example creates an instance of Button and hosts it within a parent Grid. Darüber hinaus verwendet er die LayoutTransform Eigenschaft anwenden einer RotateTransform auf die 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>

Hinweise

Im Gegensatz zu RenderTransform, LayoutTransform Einfluss auf die Ergebnisse des Layouts.In contrast to RenderTransform, LayoutTransform will affect results of layout.

Festlegen einer Transformation stellt leistungsfähige Funktionen skalieren und rotieren.Setting a transform provides powerful capabilities of scaling and rotating. Allerdings LayoutTransform ignoriert TranslateTransform Vorgänge.However, LayoutTransform ignores TranslateTransform operations. Grund hierfür ist das Verhalten des Layouts für untergeordnete Elemente des eine FrameworkElement alle Offsets, die die Position eines Elements skaliert oder gedreht, in das Layout und der Koordinatensystem des übergeordneten Elements automatisch korrigiert.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 kann zu schlechter Anwendungsleistung führen, wenn Sie es in einem Szenario aufrufen, die nicht über einen vollständigen Durchlauf des Layoutsystems erfordert.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. Beim Anwenden einer LayoutTransform auf die Children Auflistung von der Panel, einen neuen Durchlauf des Layoutsystems auslöst werden soll, und erzwingt, dass alle Objekte auf dem Bildschirm dieses erneut berechnet und neu angeordnet werden.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. Wenn Sie die vollständige Anwendung aktualisieren Benutzeroberfläche (User Interface, UI)user interface (UI), diese Funktionalität kann sein, genau die benötigten.If you are updating the complete application Benutzeroberfläche (User Interface, UI)user interface (UI), this functionality might be exactly what you need. Wenn Sie nicht über eine vollständige Layoutphase benötigen, allerdings verwenden der RenderTransform -Eigenschaft, die das Layoutsystem nicht aufruft, und aus diesem Grund ist in der Regel eine bessere Wahl für dieses Szenario.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.

Beispielszenarien, in denen LayoutTransform wäre nützlich sind: Drehen von Elementen wie z. B. Menükomponenten, von der horizontalen, vertikalen oder umgekehrt, skalieren (vergrößern) Elemente von fokussierten, bereitstellen usw. Bearbeitungsverhalten.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.

Informationen zur AbhängigkeitseigenschaftDependency Property Information

Feld "ID"Identifier field LayoutTransformProperty
Legen Sie auf der Metadaten-Eigenschaften trueMetadata properties set to true AffectsMeasure

Gilt für:

Siehe auch