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

Im folgenden Beispiel wird gezeigt, wie ein LayoutTransform auf ein Element angewendet wird.The following example shows how to apply a LayoutTransform to an element. Im Beispiel wird eine Instanz von Button erstellt und in einem übergeordneten GridElement gehostet.The example creates an instance of Button and hosts it within a parent Grid. Außerdem wird die LayoutTransform -Eigenschaft verwendet, um RotateTransform eine auf Buttondas anzuwenden.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 RenderTransformwirkt LayoutTransform sich auf die layoutergebnisse aus.In contrast to RenderTransform, LayoutTransform will affect results of layout.

Das Festlegen einer Transformation bietet leistungsstarke Funktionen zum Skalieren und drehen.Setting a transform provides powerful capabilities of scaling and rotating. LayoutTransform IgnoriertTranslateTransform jedoch Vorgänge.However, LayoutTransform ignores TranslateTransform operations. Dies liegt daran, dass das layoutsystemverhalten für unter FrameworkElement geordnete Elemente eines automatisch alle Offsets an die Position eines skalierten oder gedrehten Elements in das Layout-und Koordinatensystem des übergeordneten Elements 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.

LayoutTransformkann zu schlechter Anwendungsleistung führen, wenn Sie Sie in einem Szenario aufrufen, für das kein vollständiger Pass durch das Layoutsystem erforderlich ist.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. Wenn Sie ein LayoutTransform auf die Children -Auflistung von anwenden Panel, löst es einen neuen Durchlauf durch das Layoutsystem aus und erzwingt, dass alle Bildschirm Objekte neu gemessen 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 gesamte Anwendung Benutzeroberfläche (User Interface, UI)user interface (UI)aktualisieren, ist diese Funktion möglicherweise genau das, was Sie benötigen.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 jedoch keinen vollständigen Layoutdurchlauf benötigen, verwenden Sie die RenderTransform -Eigenschaft, die das Layoutsystem nicht aufruft und daher in der Regel eine bessere Wahl für dieses Szenario ist.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.

Beispiele für Szenarien LayoutTransform , in denen nützlich wäre, sind z. b. das Drehen von Elementen, z. b. Menü Komponenten von horizontal zu vertikal oder umgekehrt, das Skalieren von Elementen (Zoomen) auf den Fokus, das Bereitstellen von Bearbeitungs VerhaltenExample 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

BezeichnerfeldIdentifier field LayoutTransformProperty
Metadateneigenschaften auf festgelegttrueMetadata properties set to true AffectsMeasure

Gilt für:

Siehe auch