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

Определение

Получает или задает графическое преобразование, которое применяется к элементу при изменении параметров размещения.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

Значение свойства

Преобразование, которое должен использовать данный элемент.The transform this element should use. Значение по умолчанию — Identity.The default is Identity.

Примеры

В следующем примере показано, как применить LayoutTransform на элемент.The following example shows how to apply a LayoutTransform to an element. В примере создается экземпляр Button и размещает его в родительском элементе Grid.The example creates an instance of Button and hosts it within a parent Grid. Он также использует LayoutTransform свойство для применения 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>

Комментарии

В отличие от к RenderTransform, LayoutTransform повлияет на результаты макета.In contrast to RenderTransform, LayoutTransform will affect results of layout.

Задание преобразования предоставляет мощные возможности масштабирования и вращения.Setting a transform provides powerful capabilities of scaling and rotating. Тем не менее LayoutTransform игнорирует TranslateTransform операций.However, LayoutTransform ignores TranslateTransform operations. Это обусловлено тем, поведение системы макета для дочерних элементов FrameworkElement автоматически исправляет любые смещения расположения элемента масштабированный и повернутый с макетом и системы координат родительского элемента.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 может привести к ухудшению производительности приложения, если ее можно вызвать в сценарии, который не требуется полный проход системы макета.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. При применении LayoutTransform для Children коллекцию Panel, оно активирует новый проход системы макета и заставляет все объекты на экране необходимо повторно измерить и упорядочить.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. Если вы обновляете полное приложение пользовательский интерфейсuser interface (UI), эта функция может оказаться именно то, что вам нужно.If you are updating the complete application пользовательский интерфейсuser interface (UI), this functionality might be exactly what you need. Тем не менее, если не требуется полная передача макета, используйте RenderTransform свойство, которое не вызывает систему макета и, как правило, лучшим выбором для этого сценария.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.

Примеры сценариев где LayoutTransform может быть полезно, включают: поворот элементов, таких как компоненты меню с горизонтального на вертикальное или наоборот, масштабирование элементы (увеличивать) при получении фокуса, предоставляя возможность редактирования и т. д.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.

Сведения о свойстве зависимостейDependency Property Information

Поле идентификатораIdentifier field LayoutTransformProperty
Значение свойства метаданных trueMetadata properties set to true AffectsMeasure

Применяется к

Дополнительно