1

我想同时调整多个形状的大小。这是我的 xaml 代码。它有 2 个名为 g6 和 g10 的画布,但在实际项目中我得到了近 100 个画布。有什么解决办法吗?

<Canvas
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    x:Name="svg2"
    Width="612"
    Height="800">
    <Canvas
        x:Name="g4"
        RenderTransform="1.3702001,0,0,1.4522231,268.12186,265.31238">
        <Canvas x:Name="g6">
            <Path
                x:Name="path8"
                Data="F1 M-153.219,-37.369C-153.219,-37.369 -153.168,-36.483 -153.579,-36.491 -153.99,-36.5 -162.189,-58.998 -172.418,-57.948 -172.419,-57.948 -163.557,-61.389 -153.219,-37.369L-153.219,-37.369z"
                Fill="#FFFFFFFF"
                Stroke="#FF000000"
                StrokeMiterLimit="4"
                StrokeThickness="0.172" />
        </Canvas>
        <Canvas x:Name="g10">
            <Path
                x:Name="path12"
                Data="F1 M-151.46,-38.783C-151.46,-38.783 -151.734,-37.933 -152.117,-38.073 -152.5,-38.212 -152.06,-61.988 -162.059,-64.269 -162.059,-64.269 -152.48,-64.673 -151.46,-38.783z"
                Fill="#FFFFFFFF"
                Stroke="#FF000000"
                StrokeMiterLimit="4"
                StrokeThickness="0.172" />
        </Canvas>
    </Canvas>
</Canvas>
4

3 回答 3

1

在您的代码中,您可以执行以下操作:

IEnumerable<Canvas> Collection = RootControl.Chidren.ofType<Canvas>();
foreach(Canvas c in Collection)
{
    c.Height = NewHeight;
    c.Width = NewWidth;
}
于 2012-07-04T10:37:06.273 回答
1

根据目前的信息——

您可以在您的(或 CodeBehind 或您在/usercontrol中设置的任何对象)中创建WidthHeight属性,并将您的每个对象绑定到它们;在代码中更改这些属性将调整 xaml 中所有画布的大小。ViewModelDataContextWindowWidthHeightCanvas

如果您不想为每个画布添加绑定,您可以为Canvas( withoutx:Key ) 创建一个全局样式,该样式将自动应用于每个画布Canvas;但是您必须小心地将这种样式放在正确的位置,在您提供的当前 xaml 中,将其添加style到最顶层的 Canvas 资源中是有意义的。

像这样的东西 -

<Canvas xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"    
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        x:Name="svg2" Width="612" Height="800" >
    <Canvas.Resources>
        <Style TargetType="{x:Type Canvas}">
            <Setter Property="Width" Value="{Binding GlobalWidth}" />
            <Setter Property="Height" Value="{Binding GlobalHeight}" />
        </Style>
    </Canvas.Resources>

    <Canvas x:Name="g4" ... />
    <Canvas x:Name="g6" ... />
    <Canvas x:Name="g10" ... />
</Canvas>

作为旁注,我建议您不要依赖转换后的 XAML。尝试重构它以使用适当的控制/面板,将相关部分提取到用户控件中,使用样式/触发器等。

于 2012-07-04T13:28:12.033 回答
0

您可以创建一个包含所有画布的 Viewbox... 向我们提供有关您项目的更多信息。

于 2012-07-04T10:52:12.337 回答