【问题标题】:Scroll according to selected item in stack panel根据堆栈面板中的选定项目滚动
【发布时间】:2016-09-25 13:52:05
【问题描述】:

我有一个与 ItemsControl 绑定的视图模型。在 ItemsControl 里面我有一个堆栈面板。现在我想要的是可以使用箭头键更改所选项目。就像在附图中一样,我选择了第一个项目,当我按下第四个项目时应该被选中。问题是每行的项目取决于屏幕分辨率,因此在某些屏幕上每行有 4 个项目,而在某些屏幕上有 3 个。其次,当我向下移动到页面结束的位置时,滚动应该向下移动。我怎样才能做到这一点?。

这是我的 xaml:

<ScrollViewer  HorizontalAlignment="Center" VerticalScrollBarVisibility="Auto" Width="Auto" Grid.Row="2" Grid.Column="1" Grid.ColumnSpan="2" Grid.RowSpan="2"  VerticalAlignment="Top" Margin="0,10,10,0">
            <ItemsControl  Name="productVariants">
                <ItemsControl.ItemsPanel>
                    <ItemsPanelTemplate>
                        <WrapPanel Orientation="Horizontal"  />
                    </ItemsPanelTemplate>
                </ItemsControl.ItemsPanel>
                <ItemsControl.ItemTemplate>
                    <DataTemplate>
                        <DockPanel MouseLeftButtonDown="ProductVariantClicked" Tag="{Binding VariantCBX}" Margin="8" MaxHeight="160" MaxWidth="200" MinWidth="200" MinHeight="160">
                            <Border Name="ItemBorder" CornerRadius="6" BorderBrush="Gray" Background="White" BorderThickness="2" DockPanel.Dock="Top">
                                <StackPanel Margin="0">

                                    <TextBlock Name="ProductVariantOption" Text="{Binding VariantOption}" HorizontalAlignment="Center" FontWeight="Bold" FontSize="20"/>
                                    <Image Source="{Binding ProductVariantLogoPath}" Height="80" Width="180" />
                                    <TextBlock Text="{Binding VendorName}" HorizontalAlignment="Center" FontSize="15" FontWeight="Bold" />
                                    <TextBlock Text="{Binding SellingPrice}" HorizontalAlignment="Center" FontSize="20" FontWeight="Bold" Foreground="Red" />

                                </StackPanel>
                            </Border>
                        </DockPanel>
                        <DataTemplate.Triggers>
                            <DataTrigger Binding="{Binding IsSelected}" Value="True" >
                                <Setter TargetName="ItemBorder" Property="BorderBrush" Value="Yellow"/>
                            </DataTrigger>
                        </DataTemplate.Triggers>
                    </DataTemplate>
                </ItemsControl.ItemTemplate>

            </ItemsControl>

        </ScrollViewer>

【问题讨论】:

  • 这是相当复杂的行为,因此最好在代码隐藏中执行。您可以使用各种元素的 ActualHeight 和 ActualWidth 和 Margin 进行一些数学运算,以确定触发键盘事件时有多少列/行,您可以使用它以及按下的特定键来确定哪个元素需要被选中。我不认为有一个干净的、仅限 XAML 的方法来解决这个问题。
  • @TimOehler 我只需要知道一行数据网格中有多少个元素。我怎样才能做到这一点。在知道我可以根据数据网格中的一行堆栈面板中的元素数量添加或减去之后

标签: c# wpf itemscontrol stackpanel


【解决方案1】:

就像我说的,我不知道有什么干净的方法可以做到这一点。我可能会先查看您的项目的 ActualWidth(例如您的“ItemBorder”Border 元素)。如果您知道项目的 ActualWidth(加上任何水平边距)和 ItemsControl 的 ActualWidth,则可以计算出此时一行中有多少元素。您需要按需重新计算 - 您可以在执行滚动时重新计算(因为大小可能已更改),或者您可以通过重新计算布局更改来使其保持最新。

要查找实际宽度,您有几个选择。一种是您可以在滚动时遍历视觉后代,直到找到您关心的元素。另一个是您可以订阅“Loaded”事件并记住当时的实际宽度,假设宽度不会随时间变化。

【讨论】:

    猜你喜欢
    • 2011-01-02
    • 2015-11-18
    • 1970-01-01
    • 1970-01-01
    • 2014-04-05
    • 2017-09-15
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多