FrameworkElement.LayoutTransform Propriedade

Definição

Obtém ou define a transformação de gráficos que devem ser aplicados a esse elemento quando o layout é executado.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 da propriedade

A transformação que esse elemento deve usar.The transform this element should use. O padrão é Identity.The default is Identity.

Exemplos

O exemplo a seguir mostra como aplicar um LayoutTransform a um elemento.The following example shows how to apply a LayoutTransform to an element. O exemplo cria uma instância de Button e a hospeda em um Gridpai.The example creates an instance of Button and hosts it within a parent Grid. Ele também usa a propriedade LayoutTransform para aplicar uma RotateTransform à 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>

Comentários

Em contraste com RenderTransform, LayoutTransform afetará os resultados do layout.In contrast to RenderTransform, LayoutTransform will affect results of layout.

Definir uma transformação fornece recursos poderosos de dimensionamento e rotação.Setting a transform provides powerful capabilities of scaling and rotating. No entanto, LayoutTransform ignora as operações de TranslateTransform.However, LayoutTransform ignores TranslateTransform operations. Isso ocorre porque o comportamento do sistema de layout para elementos filho de um FrameworkElement corrige automaticamente qualquer deslocamento para a posição de um elemento dimensionado ou girado no sistema de layout e de coordenadas do elemento pai.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 pode levar a um desempenho de aplicativo insatisfatório se você o invocar em um cenário que não requer uma passagem completa pelo sistema de layout.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. Quando você aplica um LayoutTransform à coleção de Children do Panel, ele dispara uma nova passagem pelo sistema de layout e força todos os objetos na tela a serem remedidos e reorganizados.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. Se você estiver atualizando o aplicativo completo UI (interface do usuário)user interface (UI), essa funcionalidade poderá ser exatamente o que você precisa.If you are updating the complete application UI (interface do usuário)user interface (UI), this functionality might be exactly what you need. No entanto, se você não precisar de uma passagem de layout completo, use a propriedade RenderTransform, que não invoca o sistema de layout, e, portanto, é normalmente uma opção melhor para esse cenário.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.

Os cenários de exemplo em que LayoutTransform seriam úteis incluem: rotação de elementos como componentes de menu de horizontal para vertical ou vice-versa, dimensionamento de elementos (ampliação) no foco, fornecendo comportamento de edição, 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.

Informações de Propriedade de DependênciaDependency Property Information

Campo de identificadorIdentifier field LayoutTransformProperty
Propriedades de metadados definidas como trueMetadata properties set to true AffectsMeasure

Aplica-se a

Veja também