4

我的语义缩放有些奇怪。我有两个部分:

在此处输入图像描述 在此处输入图像描述

当我设置 ZoomOut 时,分组是好的,这是图像:

在此处输入图像描述

但例如,如果我选择第二个选项,语义缩放不会将我导航到单击的项目。

这是我的程序中最重要的部分。

    <!-- from resources -->
    <CollectionViewSource
        x:Name="groupedItemsViewSource"
        Source="{Binding Groups}"
        IsSourceGrouped="False">

    ...

    <!-- Horizontal scrolling grid used in most view states -->
    <SemanticZoom x:Name="semanticZoomControl" Grid.Row="1" >
        <SemanticZoom.ZoomedInView>
            <ListView x:Name="itemGridView" SelectionMode="None" IsItemClickEnabled="False"
                      ScrollViewer.VerticalScrollBarVisibility="Disabled"
                      ScrollViewer.VerticalScrollMode="Disabled"
                      ScrollViewer.HorizontalScrollBarVisibility="Auto"
                      ScrollViewer.HorizontalScrollMode="Auto"
                      Margin="0,-3,0,0"
                      Padding="116,0,40,46"
                      ItemTemplateSelector="{StaticResource StartItemSelector}"
                      ItemsSource="{Binding Source={StaticResource groupedItemsViewSource}}"
                      ItemContainerStyle="{StaticResource ListViewItemStyleFlat}">
                <ListView.ItemsPanel>
                    <ItemsPanelTemplate>
                        <StackPanel Orientation="Horizontal" />
                    </ItemsPanelTemplate>
                </ListView.ItemsPanel>
            </ListView>
        </SemanticZoom.ZoomedInView>
        <SemanticZoom.ZoomedOutView>
            <ListView x:Name="groupGridView" CanDragItems="False"
                      CanReorderItems="False" SelectionMode="None" IsItemClickEnabled="True"
                      ScrollViewer.HorizontalScrollBarVisibility="Auto"
                      ScrollViewer.HorizontalScrollMode="Auto"
                      ScrollViewer.VerticalScrollBarVisibility="Disabled"
                      ScrollViewer.VerticalScrollMode="Disabled"
                      ItemContainerStyle="{StaticResource ListViewItemStyleSimple}"
                      ItemsSource="{Binding Source={StaticResource groupedItemsViewSource}}"
                      ItemTemplateSelector="{StaticResource ZoomedOutSelector}">
                <ListView.ItemsPanel>
                    <ItemsPanelTemplate>
                        <StackPanel Orientation="Horizontal"  Height="330"
                                    HorizontalAlignment="Left" VerticalAlignment="Top" />
                    </ItemsPanelTemplate>
                </ListView.ItemsPanel>
            </ListView>

发生这种情况的原因可能是什么?

如果您觉得更舒服,您可以从 SkyDrive 下载该项目:http: //sdrv.ms/Ma0LmE

4

2 回答 2

11

您需要在代码隐藏中设置 Zoomed Out GridView 的 ItemsSource,例如

groupGridView.ItemsSource = groupedItemsViewSource.View.CollectionGroups;

您很可能需要更新该网格的模板,以附加“组”。在你的绑定之前。

您的 ItemTemplateSelector 也将停止工作,它将传递一个 DependencyObject 而不是您的绑定组。您可以将对象转换为具有 Group 属性的 ICollectionViewGroup,您可以将其转换为模型对象等。

这一切都很痛苦,但我目前找不到更好的方法。

于 2012-07-26T21:05:25.000 回答
7

我的情况有些不同,但我决定在这里分享,希望有人会发现它有用。在我的应用程序中,我必须有两个不同的数据源用于语义缩放的放大/缩小视图。当然,这打破了两者之间的联系,所以我不能做上面@Nigel 建议的事情以及在一般情况下会起作用的事情。相反,我必须自己处理滚动。

因此,我为视图更改事件添加了一个事件处理程序:

<SemanticZoom ViewChangeStarted="OnSemanticZoomViewChangeStarted">
...
</SemanticZoom>

然后我在代码隐藏中定义了它:

private void OnSemanticZoomViewChangeStarted(object sender, SemanticZoomViewChangedEventArgs e)
{
    // only interested in zoomed out->zoomed in transitions
    if (e.IsSourceZoomedInView)
    {
        return;
    }

    // get the selected group
    MyItemGroup selectedGroup = e.SourceItem.Item as MyItemGroup;

    // identify the selected group in the zoomed in data source (here I do it by its name, YMMV)
    ObservableCollection<MyItemGroup> myItemGroups = this.DefaultViewModel["GroupedItems"] as ObservableCollection<MyItemGroup>;
    MyItemGroup myGroup = myItemGroups.First<MyItemGroup>((g) => { return g.Name == selectedGroup.Name; });

    // workaround: need to reset the scroll position first, otherwise ScrollIntoView won't work
    SemanticZoomLocation zoomloc = new SemanticZoomLocation();
    zoomloc.Bounds = new Windows.Foundation.Rect(0, 0, 1, 1);
    zoomloc.Item = myItemGroups[0];
    zoomedInGridView.MakeVisible(zoomloc);

    // now we can scroll to the selected group in the zoomed in view
    zoomedInGridView.ScrollIntoView(myGroup, ScrollIntoViewAlignment.Leading);
}

如您所见,hack 是首先需要重绕 gridviewScrollIntoView才能正常工作。我想这只是微软的另一个“设计”决定......:P

于 2012-10-09T11:36:44.673 回答