Хобрук: Ваш путь к мастерству в программировании

wpf — HierarchicalDataTemplate, VirtualizingStackPanel, изменение размера окна (развернуть)

У меня проблема с древовидным представлением wpf, которое использует HierarchicalDataTemplate в сочетании с VirtualizingStackPanel. Используя приведенный ниже код, я запускаю приложение и раскрываю все элементы дерева.

http://img227.imageshack.us/img227/3536/wpftv03.png

Затем я делаю область просмотра «маленькой», чтобы элементы были виртуализированы. Я прокручиваю вниз и выбираю последний элемент.

(извините, недостаточно представителей, чтобы опубликовать более одной ссылки... лол)

http://img291.imageshack.us/img291/9020/wpftv01.png

Затем я максимизирую окно:

http://img706.imageshack.us/img706/607/wpftv02.png

Кажется, что при максимизации (но не только) реализуются не все элементы дерева. Я в тупике, в чем может быть проблема. Любая помощь будет оценена по достоинству! :D

(это также происходит в win7, когда вы «закрепляете» приложение, чтобы заполнить половину экрана)

App.xaml

<Application x:Class="WpfApplication4.App"
             xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
             xmlns:local="clr-namespace:WpfApplication4"
             StartupUri="MainWindow.xaml">
    <Application.Resources>

        <HierarchicalDataTemplate 
            DataType="{x:Type local:Alpha}" 
            ItemsSource="{Binding Items}">
            <Border Width="50" Height="10" Background="Red">

            </Border>
        </HierarchicalDataTemplate>

        <Style x:Key="TreeViewStyle">
            <Setter Property="TreeView.Background" Value="Transparent"/>
            <Setter Property="VirtualizingStackPanel.IsVirtualizing" Value="True"/>
            <Setter Property="VirtualizingStackPanel.VirtualizationMode" Value="Recycling"/>
            <Setter Property="TreeView.SnapsToDevicePixels" Value="True" />
            <Setter Property="TreeView.OverridesDefaultStyle" Value="True" />
            <Setter Property="ItemsControl.ItemsPanel">
                <Setter.Value>
                    <ItemsPanelTemplate>
                        <VirtualizingStackPanel IsItemsHost="True"/>
                    </ItemsPanelTemplate>
                </Setter.Value>
            </Setter>
            <Setter Property="TreeView.Template">
                <Setter.Value>
                    <ControlTemplate TargetType="TreeView">
                        <ScrollViewer Focusable="False" CanContentScroll="True" Padding="4">
                            <ItemsPresenter HorizontalAlignment="Stretch"/>
                        </ScrollViewer>
                    </ControlTemplate>
                </Setter.Value>
            </Setter>
        </Style>
    </Application.Resources>
</Application>

MainWindow.xaml

<Window x:Class="WpfApplication4.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="MainWindow" Height="350" Width="525">
    <Grid>
        <TreeView 
            x:Name="tv"
     Style="{DynamicResource TreeViewStyle}"
            ItemsSource="{Binding Items}"/>
    </Grid>
</Window>

MainWindow.xaml.cs

using System.Collections.ObjectModel;
using System.ComponentModel;
using System.Windows;

namespace WpfApplication4
{
    /// <summary>
    /// Interaction logic for MainWindow.xaml
    /// </summary>
    public partial class MainWindow : Window, INotifyPropertyChanged
    {
        private ObservableCollection<Alpha> _Items;
        public ObservableCollection<Alpha> Items
        {
            get
            {
                return(_Items);
            }
            set
            {
                _Items = value;
                OnPropertyChanged("Items");
            }
        }

        public MainWindow()
        {
            InitializeComponent();
            DataContext = this;

            Items = new ObservableCollection<Alpha>();

            Alpha a = new Alpha(null);

            Alpha a0 = new Alpha(a);
            Alpha a1 = new Alpha(a);
            Alpha a2 = new Alpha(a);
            Alpha a3 = new Alpha(a);
            Alpha a4 = new Alpha(a);
            Alpha a5 = new Alpha(a);
            Alpha a6 = new Alpha(a);
            Alpha a7 = new Alpha(a);
            Alpha a8 = new Alpha(a);
            Alpha a9 = new Alpha(a);

            Alpha b = new Alpha(null);

            Alpha b0 = new Alpha(b);
            Alpha b1 = new Alpha(b);
            Alpha b2 = new Alpha(b);
            Alpha b3 = new Alpha(b);
            Alpha b4 = new Alpha(b);
            Alpha b5 = new Alpha(b);
            Alpha b6 = new Alpha(b);
            Alpha b7 = new Alpha(b);
            Alpha b8 = new Alpha(b);
            Alpha b9 = new Alpha(b);


            a.Items.Add(a0);
            a.Items.Add(a1);
            a.Items.Add(a2);
            a.Items.Add(a3);
            a.Items.Add(a4);
            a.Items.Add(a5);
            a.Items.Add(a6);
            a.Items.Add(a7);
            a.Items.Add(a8);
            a.Items.Add(a9);

            b.Items.Add(b0);
            b.Items.Add(b1);
            b.Items.Add(b2);
            b.Items.Add(b3);
            b.Items.Add(b4);
            b.Items.Add(b5);
            b.Items.Add(b6);
            b.Items.Add(b7);
            b.Items.Add(b8);
            b.Items.Add(b9);

            Items.Add(a);
            Items.Add(b);


        }

        #region INotifyPropertyChanged Members

        public event PropertyChangedEventHandler PropertyChanged;

        void OnPropertyChanged(string propertyName)
        {
            if (this.PropertyChanged != null)
                this.PropertyChanged(this, new PropertyChangedEventArgs(propertyName));
        }

        #endregion // INotifyPropertyChanged Members
}

    public class Alpha: INotifyPropertyChanged
    {
        private Alpha()
            : base()
        {
            Items = new ObservableCollection<Alpha>();
        }

        public Alpha(Alpha parent) : this()
        {
            Parent = parent;
        }

        private string _Description;
        public string Description
        {
            get
            {
                return (_Description);
            }
            set
            {
                _Description = value;
                OnPropertyChanged("Description");
            }
        }

        private ObservableCollection<Alpha> _Items;
        public ObservableCollection<Alpha> Items
        {
            get
            {
                return (_Items);
            }
            set
            {
                _Items = value;
                OnPropertyChanged("Items");
            }
        }

        private Alpha _Parent;
        public Alpha Parent
        {
            get
            {
                return (_Parent);
            }
            set
            {
                _Parent = value;
                OnPropertyChanged("Parent");
            }
        }

        #region INotifyPropertyChanged Members

        public event PropertyChangedEventHandler PropertyChanged;

        void OnPropertyChanged(string propertyName)
        {
            if (this.PropertyChanged != null)
                this.PropertyChanged(this, new PropertyChangedEventArgs(propertyName));
        }

        #endregion // INotifyPropertyChanged Members
    }
}

Ответы:


1

Редактировать :

Я думал, что проблема в CanContentScroll, но оказалось, что если я установлю для этого значение false, то элементы не виртуализируются.

вздыхает

30.09.2010
Новые материалы

Аргументы прогрессивного улучшения почти всегда упускают суть
В наши дни в кругах веб-разработчиков много болтают о Progressive Enhancement — PE, но на самом деле почти все аргументы с обеих сторон упускают самую фундаментальную причину, по которой PE..

Введение в Джанго Фреймворк
Схема «работать умно, а не усердно» В этой и последующих статьях я познакомлю вас с тем, что такое фреймворк Django и как создать свое первое приложение с помощью простых и понятных шагов, а..

Настольный ПК как «одно кольцо, чтобы править всеми» домашних компьютеров
Вид после 9 месяцев использования С настольных компьютеров все началось, но в какой-то момент они стали «серверами», и мы все перешли на ноутбуки. В прошлом году я столкнулся с идеей настольных..

Расширенные методы безопасности для VueJS: реализация аутентификации без пароля
Руководство, которое поможет вам создавать безопасные приложения в долгосрочной перспективе Безопасность приложений часто упускается из виду в процессе разработки, потому что основная..

стройный-i18следующий
Представляем стройную оболочку для i18next. Эта библиотека, основанная на i18next, заключает экземпляр i18next в хранилище svelte и отслеживает события i18next, такие как languageChanged,..

Обзор 20 основных и современных методов работы с массивами в JavaScript
Вы знаете их всех? В этом коротком посте я покажу сводку методов, доступных в JavaScript для работы с массивами. Я надеюсь, что вы найдете это полезным! В конце поста вы найдете ссылку на..

Да, но я чувствую необходимость указать, что это или не единственные два.
Да, но я чувствую необходимость указать, что это или не единственные два. Обучение с подкреплением (в качестве примера) также является важным.