【问题标题】:set selecteditem in treeview to a databinded custom item wpf将树视图中的选定项设置为数据绑定的自定义项 wpf
【发布时间】:2016-10-22 19:02:01
【问题描述】:

我正在使用TreeViewListView 在C# 和WPF 中构建一个文件资源管理器,它们都绑定到一个名为DataItem 的类。当我按下要导入的项目时,孩子们会转到ListView。但是我无法在TreeView 中设置所选项目并将其扩展,因为TreeView 的属性SelectedItem 是只读的。如何将我要选择的项目从ListView 设置为TreeView? 我在网上查找并尝试了不同类型的解决方案,但没有运气。

我的数据项代码(C#):

public abstract class DataItem
{
    private ObservableCollection<DataItem> FolderItems;

    public String Title {get; protected set; }

    public DataItem()
    {
        this.FolderItems = new ObservableCollection<DataItem>();

        this.Title = "";
    }

    public DataItem(DataItem Other) 
    {
        this.FolderItems = new ObservableCollection<DataItem>();

        this.Title = Other.Title;

        foreach (DataItem Folder in Other.FolderItems)
        {
            this.FolderItems.Add(Folder);
        }
    }

    public int Count()
    {
        int DataItemsCounter = 0;

        List<DataItem> FilesList = new List<DataItem>();

        foreach (DataItem File in this.Files)
        {
            FilesList.Add(File);

            DataItemsCounter++;
        }

        const int Empty = 0;

        const int FirstItem = 0;

        while (FilesList.Count != Empty)
        {
            DataItem File = FilesList[FirstItem];

            FilesList.RemoveAt(FirstItem);

            ObservableCollection<DataItem> Folder = File.Files;

            foreach (DataItem SubFile in Folder)
            {
                FilesList.Add(SubFile);

                DataItemsCounter++;
            }

        }

        return DataItemsCounter;
    }

    public virtual ObservableCollection<DataItem> Open()
    {
        return FolderItems;
    }

    public virtual ObservableCollection<DataItem> Files
    {
        get
        {
            return FolderItems;
        }
    }

    public ObservableCollection<DataItem> Folders
    {
        get
        {
            return FolderItems;
        }
    }

    public abstract String Format { get; }

    public String Icon
    {
        get
        {
            return String.Format("Icons/{0}.png", this.Format);
        }
    }
}

我的列表视图代码和TreeView (WPF):

<TreeView x:Name="FileExplorerTreeView" SelectedItemChanged="FileExplorerTreeView_SelectedItemChanged">
                        <TreeView.ItemTemplate>
                            <HierarchicalDataTemplate DataType="{x:Type local:DataItem}" ItemsSource="{Binding Folders}">
                                <DockPanel>
                                    <TextBlock Name="CaptionTextblock" Text="{Binding Title}"  DockPanel.Dock="Right"/>
                                    <Image Source="{Binding Icon, Converter={StaticResource EmptyImageToImageSourceConverter}}" RenderOptions.BitmapScalingMode= "HighQuality" Stretch="Uniform" Height="{Binding ElementName=CaptionTextblock,Path=ActualHeight}" DockPanel.Dock="Left"/>
                                </DockPanel>
                            </HierarchicalDataTemplate>
                        </TreeView.ItemTemplate>
                    </TreeView>

                    <ListView x:Name="FileExplorerListView" Grid.Column="1" Margin="4,0,0,0" ItemsSource= "{Binding}" ScrollViewer.HorizontalScrollBarVisibility="Disabled"
                          SelectedItem="{Binding DataItem, RelativeSource={RelativeSource AncestorType=Window}}" SelectionChanged="FileExplorerListView_SelectionChanged">
                        <ListView.ItemsPanel>
                            <ItemsPanelTemplate>
                                <WrapPanel/>
                            </ItemsPanelTemplate>
                        </ListView.ItemsPanel>

                        <ListView.ItemTemplate>
                            <DataTemplate>
                                <DockPanel>
                                    <TextBlock DockPanel.Dock="Bottom" Text="{Binding Title}"/>
                                    <Image Source="{Binding Icon, Converter={StaticResource EmptyImageToImageSourceConverter}}" Width="32" Height="32" DockPanel.Dock="Top"/>
                                </DockPanel>
                            </DataTemplate>
                        </ListView.ItemTemplate>
                    </ListView>

【问题讨论】:

标签: c# wpf xaml data-binding treeview


【解决方案1】:

得到它的工作,树视图的项目的设置器不起作用,因为项目本身没有显示在树视图上(他的父母被折叠了)并且我没有实现 inotifypropertychanged 接口所以我更改了项目当它被选中时,它的所有父母都将被消耗(因此需要重做我的一半项目)并且我实现了 inotifypropertychanged 接口,现在它就像一个魅力一样工作。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2012-06-12
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多