使用大集合 - Windows 8 DataGrid

时间:2013-05-29 09:44:25

标签: c# xaml windows-8 datagrid

我正在开发Windows 8应用程序(C#/ XAML)。 其中一个要求是在DataGrid中加载一组单词,我们在这里使用语义缩放选项。

当集合包含超过1500个项目时,应用程序将挂起并出现此错误:

+ Exception {“没有足够的配额可用于处理此命令。(HRESULT异常:0x80070718)”} System.Exception

使用的一些代码:

_collection = _readDictionary.GetModeDetailsForModeDetails(modeId);

var query = from item in _collection
            orderby (item.WordName.ToLower())
            group item by item.WordName[0].ToString().ToUpper() into g
            select new { GroupName = g.Key.ToString().ToUpper(), Items = g };

foreach (var g in query)
{
  GroupInfoList<Words> info = new GroupInfoList<Words>();
  info.Key = g.GroupName;

  foreach (var item in g.Items)
  {
    info.Add(item);
  }

  groups.Add(info);
}

bindGroupData.Source = groups;
(semanticZoom.ZoomedOutView as ListViewBase).ItemsSource = bindGroupData.View.CollectionGroups;

这是XAML代码:

 <SemanticZoom  x:Name="semanticZoom" VerticalAlignment="Bottom" >
        <SemanticZoom.ZoomedOutView>
            <GridView ScrollViewer.IsHorizontalScrollChainingEnabled="False" VerticalAlignment="Top" HorizontalAlignment="Left">
                <GridView.ItemTemplate>
                    <DataTemplate>
                        <TextBlock Text="{Binding Group.Key}" FontFamily="Segoe UI Light" Foreground="Red" FontSize="24"/>
                    </DataTemplate>
                </GridView.ItemTemplate>
                <GridView.ItemsPanel>
                    <ItemsPanelTemplate>
                        <WrapGrid ItemWidth="75" ItemHeight="75" MaximumRowsOrColumns="5" VerticalChildrenAlignment="Center" />
                    </ItemsPanelTemplate>
                </GridView.ItemsPanel>
                <GridView.ItemContainerStyle>
                    <Style TargetType="GridViewItem">
                        <Setter Property="Margin" Value="4" />
                        <Setter Property="Padding" Value="10" />
                        <Setter Property="BorderBrush" Value="Gray" />
                        <Setter Property="BorderThickness" Value="2" />
                        <Setter Property="HorizontalContentAlignment" Value="Center" />
                        <Setter Property="VerticalContentAlignment" Value="Center" />
                    </Style>
                </GridView.ItemContainerStyle>
            </GridView>
            </SemanticZoom.ZoomedOutView>
        <SemanticZoom.ZoomedInView>
            <GridView x:Name="GrdViewWord" SelectionMode="Multiple" ItemsSource="{Binding Source={StaticResource bindGroupData}}"  ItemClick="GrdViewWord_ItemClick" SelectionChanged="GrdViewWord_SelectionChanged" Background="#FFE2E2E2" Height="396" VerticalAlignment="Top" >
                <!-- ItemContainerStyle="{StaticResource GridViewItemStyle}"   -->
                <GridView.ItemsPanel>
                    <ItemsPanelTemplate>
                        <!--<WrapGrid Orientation="Vertical"  Background="{Binding BG}"/>-->
                        <StackPanel Orientation="Horizontal" />
                    </ItemsPanelTemplate>
                </GridView.ItemsPanel>

                <GridView.ItemTemplate>
                    <DataTemplate>
                        <StackPanel Orientation="Horizontal" Height="20" Width="75"  >
                            <TextBlock Text="{Binding WordName}" Tag="{Binding WordID}" FontFamily="Segoe UI" FontSize="12" Margin="5,5,0,0" Foreground="Black" HorizontalAlignment="Left" Height="20" Padding="0"/>
                        </StackPanel>
                    </DataTemplate>
                </GridView.ItemTemplate>

                <GridView.GroupStyle>
                    <GroupStyle>
                        <GroupStyle.HeaderTemplate>
                            <DataTemplate>
                                <Grid Margin="10">
                                    <!--Background="{StaticResource ApplicationPageBackgroundThemeBrush}"-->
                                    <TextBlock Text='{Binding Key}'  FontSize="25" Foreground="Red" Margin="5" />
                                </Grid>
                            </DataTemplate>
                        </GroupStyle.HeaderTemplate>

                        <GroupStyle.Panel>
                            <ItemsPanelTemplate>
                                <VariableSizedWrapGrid Orientation="Vertical" Height="300" />
                            </ItemsPanelTemplate>
                        </GroupStyle.Panel>
                    </GroupStyle>
                </GridView.GroupStyle>
            </GridView>
        </SemanticZoom.ZoomedInView>
    </SemanticZoom>

有人可以帮我解决这个问题吗?

3 个答案:

答案 0 :(得分:0)

Syncfusion为WinRT提供最快的数据网格控件。它支持UI虚拟化。

http://www.syncfusion.com/products/winrt/grid

答案 1 :(得分:0)

您必须使用虚拟化。 GridView可以轻松实现虚拟化(UI virt。或Data virt。)。请参阅Microsoft Documentation以了解您需要哪种类型的虚拟化。

答案 2 :(得分:0)

这似乎是语义缩放的一个大问题,任何超过1200项的东西都不起作用。

在上面的“使用列表或网格虚拟化”链接中,它显示“分组数据 - 分组数据不支持UI虚拟化。”

语义缩放使用分组数据,因此无效。

即使是微软自己的语义示例也会因为莫尔条纹而崩溃,而不是1200项。

此链接可能有用:

http://social.msdn.microsoft.com/Forums/windowsapps/en-US/680136e1-67de-4111-824a-fa9f530ffc10/binding-largesets-of-data-to-gridview-is-causing-a-problem