【问题标题】:How to copy WPF grid cell to another cell in the same grid如何将 WPF 网格单元格复制到同一网格中的另一个单元格
【发布时间】:2020-09-06 02:08:04
【问题描述】:

我有一个 17x13 的网格,每个单元格包含一个图像,另一个网格是 2x2,每个单元格都包含一个图像。 用于此的 xaml 是:(Grid_0_0 重复了很多,所以这只是它的主要内容)

<Canvas x:Name="baseContainer">
    <Grid x:Name="MainGrid" ScrollViewer.VerticalScrollBarVisibility="Disabled" Width="{Binding ActualWidth, ElementName=baseContainer, Mode=OneWay}" Height="{Binding ActualHeight, ElementName=baseContainer, Mode=OneWay}">
        <Grid.RowDefinitions>
            <RowDefinition/>
            <RowDefinition/>
            <RowDefinition/>
            <RowDefinition/>
            <RowDefinition/>
            <RowDefinition/>
            <RowDefinition/>
            <RowDefinition/>
            <RowDefinition/>
            <RowDefinition/>
            <RowDefinition/>
            <RowDefinition/>
            <RowDefinition/>
        </Grid.RowDefinitions>
        <Grid.ColumnDefinitions>
            <ColumnDefinition/>
            <ColumnDefinition/>
            <ColumnDefinition/>
            <ColumnDefinition/>
            <ColumnDefinition/>
            <ColumnDefinition/>
            <ColumnDefinition/>
            <ColumnDefinition/>
            <ColumnDefinition/>
            <ColumnDefinition/>
            <ColumnDefinition/>
            <ColumnDefinition/>
            <ColumnDefinition/>
            <ColumnDefinition/>
            <ColumnDefinition/>
            <ColumnDefinition/>
            <ColumnDefinition/>
        </Grid.ColumnDefinitions>    
        <Grid x:Name="Grid_0_0" Grid.Row="0" Grid.Column="0" RenderTransformOrigin="0.5,0.5">
            <Grid.RenderTransform>
                <TransformGroup>
                    <ScaleTransform/>
                    <SkewTransform/>
                    <RotateTransform/>
                    <TranslateTransform/>
                </TransformGroup>
            </Grid.RenderTransform>
            <Grid.RowDefinitions>
                <RowDefinition/>
                <RowDefinition/>
            </Grid.RowDefinitions>
            <Grid.ColumnDefinitions>
                <ColumnDefinition/>
                <ColumnDefinition/>
            </Grid.ColumnDefinitions>
            <Image x:Name="Baseimg_0_0" Grid.Column = "0" Grid.Row = "0" Source = "/psyduck larger.jpg" Stretch = "Fill" Visibility="Visible" Grid.RowSpan="2" Grid.ColumnSpan="2" RenderTransformOrigin="0.5,0.5" />
            <Image x:Name="Altimg_0_0_TL" Source="/psyduck larger.jpg" Stretch="Fill" Visibility="Hidden" Width="{Binding ActualWidth, ElementName=Baseimg_0_0, Mode=OneWay}" Height="{Binding ActualHeight, ElementName=Baseimg_0_0, Mode=OneWay}"/>
            <Image x:Name="Altimg_0_0_TR" Source="/psyduck larger.jpg" Stretch="Fill" Visibility="Hidden" Width="{Binding ActualWidth, ElementName=Baseimg_0_0, Mode=OneWay}" Height="{Binding ActualHeight, ElementName=Baseimg_0_0, Mode=OneWay}" Grid.Column="1" HorizontalAlignment="Right"/>
            <Image x:Name="Altimg_0_0_BL" Source="/psyduck larger.jpg" Stretch="Fill" Visibility="Hidden" Width="{Binding ActualWidth, ElementName=Baseimg_0_0, Mode=OneWay}" Height="{Binding ActualHeight, ElementName=Baseimg_0_0, Mode=OneWay}" Grid.Row="1" VerticalAlignment="Bottom"/>
            <Image x:Name="Altimg_0_0_BR" Source="/psyduck larger.jpg" Stretch="Fill" Visibility="Hidden" Width="{Binding ActualWidth, ElementName=Baseimg_0_0, Mode=OneWay}" Height="{Binding ActualHeight, ElementName=Baseimg_0_0, Mode=OneWay}" Grid.Column="1" Grid.Row="1" VerticalAlignment="Bottom" HorizontalAlignment="Right"/>
        </Grid>

这些“迷你网格”根据按下的箭头键上下左右滑动一个网格单元。然后每个单元格将在视觉上位于相邻单元格的位置。 最后,我会将移动单元格的内容复制到它已移动到其顶部的单元格。

我试图简单地做到这一点

Grid_0_0 = Grid_0_1;

但实际上并没有导致任何更改。或者至少它没有复制“可见”和“隐藏”等值。 我还尝试为它做一个 foreach 循环。

private void ResetBoardSlide()
    {
        foreach (Grid grid in MainGrid.Children) 
        { 
            grid.RenderTransform = new TranslateTransform(0, 0);
            grid = Grid_0_0;
        } 
    }

但是这个没有工作,因为“CS1656 C# 不能赋值,因为它是一个'foreach 迭代变量'” 调查它,似乎是因为 foreach 是一个只读的东西。整洁的。但是是否有任何内置或简单的方法可以将所有子节点及其状态复制到另一个单元格?

【问题讨论】:

  • 另一种方法是使用包装板。你可以让itemscontrol 的itemspresenter 和绑定图片视图模型的集合。集合中的顺序将驱动位置从左到右,然后是下一行......等等。您可以将相同的视图模型加载到二维数组中,这样索引更容易使用。与其移动视图模型,不如更改其中的属性。或者每个中的一个子对象。
  • 有趣。我没有弄乱 wrappanel,但我确实尝试了一些 UniformGrid。我还有一个小网格数组'Grid[,] board = new Grid[13,17];'但我不完全确定这些是参考还是什么......我用另一种方法填充它。我遇到的主要困难是我认为如何更改其中的属性或子对象。

标签: c# arrays wpf grid copy


【解决方案1】:

您需要以编程方式更改小网格“Grid_0_0”对象的附加属性(Grid.RowProperty 和 Grid.ColumnProperty)的值。假设你有一个按键事件的回调,代码应该是这样的

private void OnKeyPress(KeyNameEnum key)
{
    switch(key)
    {
        case KeyNameEnum.Up: 
             Grid_0_0.SetValue(Grid.RowProperty, ((int)Grid_0_0.GetValue(Grid.RowProperty))-1);
             break;
        case KeyNameEnum.Down:
             Grid_0_0.SetValue(Grid.RowProperty, ((int)Grid_0_0.GetValue(Grid.RowProperty))+1);
             break;
        case KeyNameEnum.Left: 
             Grid_0_0.SetValue(Grid.ColumnProperty, ((int)Grid_0_0.GetValue(Grid.ColumnProperty))-1);
             break;
        case KeyNameEnum.Right:
             Grid_0_0.SetValue(Grid.ColumnProperty, ((int)Grid_0_0.GetValue(Grid.ColumnProperty))+1);
             break;
        default:
             break;
    }
}

当然,您需要添加边界检查以防止微型电网从字面上脱离电网。

【讨论】:

  • 啊,所以通过更改 RowProperty 和 ColumnProperty,这有点像更改指向 minigrid 对象的指针,以便主网格指向邻居?你能澄清一下你展示的 SetValue 函数在做什么吗?我相信第一个值是正在更改的值,第二个是新值,但是为什么要类型转换为 int 和 xButton 是什么?
  • 我正在使用System.Windows.DependencyObject.SetValue (docs.microsoft.com/en-us/dotnet/api/…}) 我们需要在这里进行类型转换的原因是 DependencyObject.GetValue 返回一个对象,编译器会报错,除非我们类型转换为int 在执行“+”操作之前。
  • 很抱歉给您带来了困惑。 xButton 应该是 Grid_0_0。我在这里更新了我的答案。
  • 仅供参考,汤米。 Grid.Row 和 Grid.Column 是附加属性。他们“附加”到任何旧的用户界面。网格在布置子项时会查找这些属性。所以属性对网格有意义,但对孩子没有意义。
  • 我对 Grid.Row 和 Grid.Column 感到困惑...我正在使用 Visual Studio,当我尝试使用这些时,我收到一个错误 CS1061 C# 'Grid' does not contain a 'Row' 的定义,并且没有可访问的扩展方法 'Row' 接受类型为 'Grid' 的第一个参数(您是否缺少 using 指令或程序集引用?) 这似乎不是第一次有人引用似乎不起作用的方法/属性。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-08-04
  • 1970-01-01
  • 2022-11-14
  • 2018-03-15
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多