方法 : TreeView のパフォーマンスを改善する
更新 : 2008 年 7 月
TreeView に多くの項目が含まれていると、読み込みに時間を要するためにユーザー インターフェイスに大きな遅れが生じる可能性があります。VirtualizingStackPanel.IsVirtualizing 添付プロパティを true に設定することによって、読み込み時間を改善できます。また、マウス ホイールの操作、またはスクロール バーのつまみのドラッグによる TreeView のスクロール時に、UI の反応が遅れる場合があります。VirtualizingStackPanelVirtualizationMode() 添付プロパティを Recycling に設定することで、ユーザーがスクロールを実行したときの TreeView のパフォーマンスを向上させることができます。
使用例
説明
TreeView を作成する例を次に示します。この例では、VirtualizingStackPanel.IsVirtualizing を true に設定し、VirtualizingStackPanelVirtualizationMode() を Recycling に設定することにより、パフォーマンスを最適化します。
コード
<StackPanel>
<StackPanel.Resources>
<src:TreeViewData x:Key="dataItems"/>
<HierarchicalDataTemplate DataType="{x:Type src:ItemsForTreeView}"
ItemsSource="{Binding Path=SecondLevelItems}">
<!--Display the TopLevelName property in the first level.-->
<TextBlock Text="{Binding Path=TopLevelName}"/>
<!--Display each string in the SecondLevelItems property in
the second level.-->
<HierarchicalDataTemplate.ItemTemplate>
<DataTemplate>
<TextBlock Text="{Binding}"/>
</DataTemplate>
</HierarchicalDataTemplate.ItemTemplate>
<!--Set the foreground of the items in the second level
to Navy.-->
<HierarchicalDataTemplate.ItemContainerStyle>
<Style TargetType="TreeViewItem">
<Setter Property="Foreground" Value="Navy"/>
</Style>
</HierarchicalDataTemplate.ItemContainerStyle>
</HierarchicalDataTemplate>
</StackPanel.Resources>
<TreeView Height="200" ItemsSource="{Binding Source={StaticResource dataItems}}"
VirtualizingStackPanel.IsVirtualizing="True"
VirtualizingStackPanel.VirtualizationMode="Recycling">
<TreeView.ItemContainerStyle>
<!--Expand each TreeViewItem in the first level and
set its foreground to Green.-->
<Style TargetType="TreeViewItem">
<Setter Property="IsExpanded" Value="True"/>
<Setter Property="Foreground" Value="Green"/>
</Style>
</TreeView.ItemContainerStyle>
</TreeView>
</StackPanel>
次の例は、前の例で使用するデータを示しています。
public class TreeViewData : ObservableCollection<ItemsForTreeView>
{
public TreeViewData()
{
for (int i = 0; i < 100; ++i)
{
ItemsForTreeView item = new ItemsForTreeView();
item.TopLevelName = "item " + i.ToString();
Add(item);
}
}
}
public class ItemsForTreeView
{
public string TopLevelName { get; set; }
private ObservableCollection<string> level2Items;
public ObservableCollection<string> SecondLevelItems
{
get
{
if (level2Items == null)
{
level2Items = new ObservableCollection<string>();
}
return level2Items;
}
}
public ItemsForTreeView()
{
for (int i = 0; i < 10; ++i)
{
SecondLevelItems.Add("Second Level " + i.ToString());
}
}
}
参照
概念
履歴の変更
日付 |
履歴 |
理由 |
---|---|---|
2008 年 7 月 |
新しい UI の仮想化機能とコンテナのリサイクル機能を示すトピックを追加 |
SP1 機能変更 |