【发布时间】: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];'但我不完全确定这些是参考还是什么......我用另一种方法填充它。我遇到的主要困难是我认为如何更改其中的属性或子对象。