wpf 缩放导致线宽不一致

在WPF中,当矩形和线条在进行缩放操作时,线宽会出现不一致的情况。本文通过实例代码展示了问题的现象,并提出了两种解决方案:一是通过调整StrokeThickness来保持线宽比例;二是利用PathFigureCollection的Path画法,尤其在缩放比例不相等时更为适用。
摘要由CSDN通过智能技术生成

wpf画矩形和划线时需要横向放大或者纵向放大,导致线宽不相等,如下图所示

1.矩形代码如下

            <Rectangle Width="100" Height="100" Stroke="Black" Canvas.Top="20">
                <Rectangle.RenderTransform>
                    <ScaleTransform ScaleX="3" ScaleY="1"/>
                </Rectangle.RenderTransform>
            </Rectangle>

效果图如下

2.折现代码如下

            <Polyline Points="0 0 20 100 30 0 40 100 50 100 60 0" Stroke="Black" Canvas.Top="20">
                <Polyline.RenderTransform>
                    <ScaleTransform ScaleX="3" ScaleY="1"/>
                </Polyline.RenderTransform>
            &l
要实现WPF缩放时不改变控件在画布中心位置的效果,可以尝试以下步骤: 1. 将控件放置在一个Canvas控件中,并设置Canvas.Left和Canvas.Top属性,将控件放置在画布中心。 2. 将Canvas控件放置在一个Grid控件中,并将该Grid控件放置在Window中。 3. 在Window的Loaded事件中,通过VisualTreeHelper.GetChild方法获取Canvas控件,并获取其RenderTransform属性。 4. 创建一个ScaleTransform对象,并将其应用于Canvas控件的RenderTransform属性中。 5. 在ScaleTransform对象中设置CenterX和CenterY属性,使其缩放时围绕画布中心进行缩放。 下面是一个示例代码: ```xml <Window x:Class="WpfApp1.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" Title="MainWindow" Height="450" Width="800" Loaded="Window_Loaded"> <Grid> <Canvas Width="200" Height="200" Background="LightGray" Left="300" Top="125" RenderTransformOrigin="0.5,0.5"> <Ellipse Width="100" Height="100" Fill="Red"/> </Canvas> </Grid> </Window> ``` ```csharp private void Window_Loaded(object sender, RoutedEventArgs e) { var canvas = VisualTreeHelper.GetChild(this.grid, 0) as Canvas; var transform = new ScaleTransform(); canvas.RenderTransform = transform; transform.CenterX = canvas.Width / 2; transform.CenterY = canvas.Height / 2; } ``` 在上面的示例中,我们将Canvas控件放置在Grid控件中,并将其放置在Window中。在Window的Loaded事件中,我们获取了Canvas控件,并创建了一个ScaleTransform对象,将其应用于Canvas控件的RenderTransform属性中。然后,我们设置了ScaleTransform对象的CenterX和CenterY属性,使其缩放时围绕画布中心进行缩放
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值