笔记:简单介绍WPF中RenderTransform,LayoutTransform, VisualTransform区别

一、目的:简单介绍WPF中RenderTransform,LayoutTransform, VisualTransform区别

在 WPF 中,RenderTransform、LayoutTransform 和 VisualTransform 是用于对控件进行变换的属性,他们的主要区别是什么,如何选用合适的Transform,本文简要介绍。

它们的主要区别在于应用变换的时机和影响范围。

二、区别

RenderTransform

RenderTransform 是在渲染阶段应用的变换。它不会影响控件的布局,只会影响控件的外观。常用于动画和视觉效果。
• 应用时机: 在控件已经完成布局之后。
• 影响范围: 仅影响控件的外观,不影响布局。
**• 常见用途:**旋转、缩放、平移、倾斜等视觉效果。

示例:

XML 复制代码
<Button Content="RenderTransform Example" Width="200" Height="50">
    <Button.RenderTransform>
        <RotateTransform Angle="45"/>
    </Button.RenderTransform>
</Button>

LayoutTransform

LayoutTransform 是在布局阶段应用的变换。它会影响控件的布局,并且会触发重新布局。常用于需要影响布局的变换。
• 应用时机: 在控件布局之前。
• 影响范围: 影响控件的布局和外观。
• 常见用途: 旋转、缩放等需要影响布局的变换。

示例:

XML 复制代码
<Button Content="LayoutTransform Example" Width="200" Height="50">
    <Button.LayoutTransform>
        <RotateTransform Angle="45"/>
    </Button.LayoutTransform>
</Button>

VisualTransform

VisualTransform 是在视觉层次结构中应用的变换。它是 Visual 类的属性,通常在更底层的视觉对象中使用,而不是直接在控件中使用。
• 应用时机: 在视觉层次结构中。
• 影响范围: 影响视觉对象的外观。
• 常见用途: 更底层的视觉效果变换,通常不直接在控件中使用。

示例:

VisualTransform 通常不直接在 XAML 中使用,而是在更底层的视觉对象中使用。以下是一个使用 VisualTransform 的示例代码:

cs 复制代码
// 假设你有一个自定义控件 MyVisualControl
public class MyVisualControl : Control
{
    private VisualCollection _children;
    private DrawingVisual _drawingVisual;

    public MyVisualControl()
    {
        _children = new VisualCollection(this);
        _drawingVisual = new DrawingVisual();
        _children.Add(_drawingVisual);

        using (DrawingContext dc = _drawingVisual.RenderOpen())
        {
            dc.DrawRectangle(Brushes.Blue, null, new Rect(0, 0, 100, 100));
        }

        // 应用 VisualTransform
        _drawingVisual.Transform = new RotateTransform(45);
    }

    protected override int VisualChildrenCount => _children.Count;

    protected override Visual GetVisualChild(int index)
    {
        return _children[index];
    }
}

总结
• RenderTransform:在渲染阶段应用,不影响布局,常用于动画和视觉效果。
• LayoutTransform:在布局阶段应用,影响布局和外观,常用于需要影响布局的变换。
• VisualTransform:在视觉层次结构中应用,影响视觉对象的外观,通常在更底层的视觉对象中使用。

选择哪种变换属性取决于你需要的效果和变换的时机。如果你只需要改变控件的外观而不影响布局,使用 RenderTransform。如果你需要变换影响布局,使用 LayoutTransform。如果你在更底层的视觉对象中工作,可以使用 VisualTransform。

三、如何选择,性能上有什么区别

RenderTransform

• 性能特点:

高效 :因为 RenderTransform 仅在渲染阶段应用变换,不会触发重新布局,所以性能较高。

• 适用场景:适用于需要频繁更新的动画和视觉效果,例如旋转、缩放、平移等。

• 性能优势:
• 不会触发布局重算,减少了布局计算的开销。
• 适合需要高频率更新的场景,如动画。

LayoutTransform

• 性能特点:

较低效 :因为 LayoutTransform 会影响控件的布局,并且会触发重新布局,所以性能较低。

• 适用场景:适用于需要影响布局的变换,例如旋转、缩放等。

• 性能劣势:
• 会触发布局重算,增加了布局计算的开销。
• 不适合需要高频率更新的场景。

VisualTransform

• 性能特点:

• 高效:VisualTransform 是在视觉层次结构中应用的变换,通常用于更底层的视觉对象,性能较高。

• 适用场景:适用于需要对视觉对象进行变换的场景,通常不直接在控件中使用。

• 性能优势:

• 不会触发布局重算,减少了布局计算的开销。

• 适合需要高频率更新的场景,如动画。

VisualTransform 通常不直接在 XAML 中使用,而是在更底层的视觉对象中使用。以下是一个使用 VisualTransform 的示例代码:

总结

• RenderTransform:性能较高,因为它仅在渲染阶段应用变换,不会触发重新布局。适用于需要频繁更新的动画和视觉效果。

• LayoutTransform:性能较低,因为它会影响控件的布局,并且会触发重新布局。适用于需要影响布局的变换,但不适合高频率更新的场景。

• VisualTransform:性能较高,因为它在视觉层次结构中应用变换,不会触发重新布局。适用于更底层的视觉对象变换,通常不直接在控件中使用。

选择哪种变换属性取决于你的具体需求和性能考虑。如果你需要高效的变换效果,RenderTransform 和 VisualTransform 是更好的选择。如果你需要变换影响布局,LayoutTransform 是必要的,但要注意其性能开销。

需要了解的知识点

UIElement.RenderTransform 属性 (System.Windows) | Microsoft Learn

FrameworkElement.LayoutTransform Property (System.Windows) | Microsoft Learn

Visual.VisualTransform 属性 (System.Windows.Media) | Microsoft Learn

System.Windows.Controls 命名空间 | Microsoft Learn

源码地址

GitHub - HeBianGu/WPF-ControlDemo: 示例

GitHub - HeBianGu/WPF-ControlBase: Wpf封装的自定义控件资源库

GitHub - HeBianGu/WPF-Control: WPF轻量控件和皮肤库

了解更多

System.Windows.Controls 命名空间 | Microsoft Learn

https://github.com/HeBianGu

HeBianGu的个人空间-HeBianGu个人主页-哔哩哔哩视频

相关推荐
三千道应用题4 小时前
WPF&C#超市管理系统(6)订单详情、顾客注册、商品销售排行查询和库存提示、LiveChat报表
开发语言·c#·wpf
✎ ﹏梦醒͜ღ҉繁华落℘1 天前
开发WPF项目时遇到的问题总结
wpf
hqwest2 天前
C#WPF实战出真汁06--【系统设置】--餐桌类型设置
c#·.net·wpf·布局·分页·命令·viewmodel
Vae_Mars2 天前
WPF中使用InputBindings进行快捷键绑定
wpf
hqwest2 天前
C#WPF实战出真汁05--左侧导航
开发语言·c#·wpf·主界面·窗体设计·视图viewmodel
hqwest2 天前
C#WPF实战出真汁01--项目介绍
开发语言·c#·wpf
wuty0073 天前
WPF 实现支持动态调整高度的文本显示控件
wpf·scrollviewer·extentheight·自动高度控件·动态调整高度
范纹杉想快点毕业6 天前
C 语言主控开发与显控开发能力体系及技术栈详解,STM32、QT、嵌入式、边缘系统显示
stm32·单片机·tcp/ip·microsoft·fpga开发·51单片机·wpf
weixin_447103586 天前
WPF之绑定!
c#·wpf
DataIntel6 天前
wpf问题记录
wpf