WPF —— TreeView树形控件

2024-04-02 08:04
文章标签 控件 treeview 树形 wpf

本文主要是介绍WPF —— TreeView树形控件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1 TreeView简介

 TreeView 表示一个控件,该控件在树结构(其中的项可以展开和折叠)中显示分层数据。 

    TreeView 是一个 ItemsControl,这意味着它可以包含任何类型的对象的集合 (,例如字符串、图像或面板) 。

2 Tree View常用的属性

        meun 水平菜单
        contextMenu 内容菜单
        TreeView 树形菜单,

        SelectedItemChanged 当选择子项发生改变的时候触发

        TreeViewItem 子项

3关于Tree View的实例 使用动态绑定数据

 <StackPanel><TreeView Name="t1" SelectedItemChanged="t1_SelectedItemChanged"><!--静态数据绑定 TreeViewItem 子项--><TreeViewItem Header="实验小学"><TreeViewItem Header="一年级"></TreeViewItem><TreeViewItem Header="二年级"></TreeViewItem><TreeViewItem Header="三年级"></TreeViewItem><TreeViewItem Header="四年级"></TreeViewItem></TreeViewItem><TreeViewItem Header="外国语小学"><TreeViewItem Header="炼器基础篇"></TreeViewItem><TreeViewItem Header="筑基篇"></TreeViewItem><TreeViewItem Header="结丹凝丹篇"></TreeViewItem><TreeViewItem Header="元婴化婴篇"></TreeViewItem></TreeViewItem><TreeViewItem Header="裕禄小学"></TreeViewItem><!--动态绑定数据:单个对象绑定例如textblock label textbox等绑定list集合 listbox、combobox、各种菜单、datagrid德国可以绑定属性一般都是: itemsoure--><TreeView ItemsSource="{Binding }" Name="t2"><!--子项绑定是其中一个对象的属性--><TreeView.ItemTemplate><!--树形数据的模板 ItemsSource 子级菜单对象的集合--><HierarchicalDataTemplate ItemsSource="{Binding SubMenus}"><!--绑定子集标题--><TextBlock Text="{Binding Name}"></TextBlock></HierarchicalDataTemplate></TreeView.ItemTemplate></TreeView></TreeView></StackPanel>

模型类的两种方法

一:

MenuInfo m1 = new MenuInfo(){Name = "实验小学",// 存放子集标题对象SubMenus = new List<MenuInfo>(){new MenuInfo() {Name= "一年级",SubMenus= new List<MenuInfo>(){new MenuInfo() {Name = "语文"},new MenuInfo() {Name = "数学"},new MenuInfo() {Name = "体育"},new MenuInfo() {Name = "英语"},}},new MenuInfo() { Name="二年级"},new MenuInfo() { Name="三年级"},new MenuInfo() { Name="四年级"},new MenuInfo() { Name="五年级"},}};MenuInfo m2 = new MenuInfo(){Name = "特殊学校",SubMenus = new List<MenuInfo>(){new MenuInfo(){Name = "一年班"},new MenuInfo(){Name = "二年班"},}};List<MenuInfo> list = new List<MenuInfo>();list.Add(m1);list.Add(m2);this.t2.ItemsSource = list;public class MenuInfo
{public string Name { get; set; }public List<MenuInfo> SubMenus { get; set; } // 子集菜单的集合public MenuInfo(string n, MenuInfo m1) {Name = n;if(m1 != null){// 如果父级对象的subMenus 为null 则新建,如果不为空 则添加if (m1.SubMenus is null) m1.SubMenus = new List<MenuInfo>();m1.SubMenus.Add(this);}}public MenuInfo(){}
}

二:

 

        // 标题对象MenuInfo gaibang = new MenuInfo("丐帮",null);// 二级菜单MenuInfo qiaofeng = new MenuInfo("乔峰", gaibang);MenuInfo zhuangjuxian = new MenuInfo("庄聚贤", gaibang);MenuInfo wuzhuanglao = new MenuInfo("五长老",gaibang);// 三级菜单MenuInfo xifu1 = new MenuInfo("阿紫", qiaofeng);MenuInfo xifu2 = new MenuInfo("阿紫她姐", qiaofeng);List<MenuInfo> list = new List<MenuInfo>();list.Add(gaibang);this.t2.ItemsSource = list;}private void t1_SelectedItemChanged(object sender, RoutedPropertyChangedEventArgs<object> e){MessageBox.Show((t1.SelectedItem as TreeViewItem).Header.ToString());}
}
public class MenuInfo
{public string Name { get; set; }public List<MenuInfo> SubMenus { get; set; } // 子集菜单的集合public MenuInfo(string n, MenuInfo m1) {Name = n;if(m1 != null){// 如果父级对象的subMenus 为null 则新建,如果不为空 则添加if (m1.SubMenus is null) m1.SubMenus = new List<MenuInfo>();m1.SubMenus.Add(this);}}public MenuInfo(){}
}

这篇关于WPF —— TreeView树形控件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/869429

相关文章

hdu1011(背包树形DP)

没有完全理解这题, m个人,攻打一个map,map的入口是1,在攻打某个结点之前要先攻打其他一个结点 dp[i][j]表示m个人攻打以第i个结点为根节点的子树得到的最优解 状态转移dp[i][ j ] = max(dp[i][j], dp[i][k]+dp[t][j-k]),其中t是i结点的子节点 代码如下: #include<iostream>#include<algorithm

lvgl8.3.6 控件垂直布局 label控件在image控件的下方显示

在使用 LVGL 8.3.6 创建一个垂直布局,其中 label 控件位于 image 控件下方,你可以使用 lv_obj_set_flex_flow 来设置布局为垂直,并确保 label 控件在 image 控件后添加。这里是如何步骤性地实现它的一个基本示例: 创建父容器:首先创建一个容器对象,该对象将作为布局的基础。设置容器为垂直布局:使用 lv_obj_set_flex_flow 设置容器

oracle11.2g递归查询(树形结构查询)

转自: 一 二 简单语法介绍 一、树型表结构:节点ID 上级ID 节点名称二、公式: select 节点ID,节点名称,levelfrom 表connect by prior 节点ID=上级节点IDstart with 上级节点ID=节点值 oracle官网解说 开发人员:SQL 递归: 在 Oracle Database 11g 第 2 版中查询层次结构数据的快速

小程序button控件上下边框的显示和隐藏

问题 想使用button自带的loading图标功能,但又不需要button显示边框线 button控件有一条淡灰色的边框,在控件上了样式 border:none; 无法让button边框隐藏 代码如下: <button class="btn">.btn{border:none; /*一般使用这个就是可以去掉边框了*/} 解决方案 发现button控件有一个伪元素(::after

MFC中Spin Control控件使用,同时数据在Edit Control中显示

实现mfc spin control 上下滚动,只需捕捉spin control 的 UDN_DELTAPOD 消息,如下:  OnDeltaposSpin1(NMHDR *pNMHDR, LRESULT *pResult) {  LPNMUPDOWN pNMUpDown = reinterpret_cast(pNMHDR);  // TODO: 在此添加控件通知处理程序代码    if

MFC 控件重绘(2) NM_CUSTOMDRAW, WM_DRAWITEM, 虚函数DrawItem

控件重绘有三种方法: 1 设定界面属性 2 利用Windows的消息机制,通过Windows消息映射(Message Mapping)和反映射(Message Reflecting),在合适的时机修改控件的状态和行为。此方式涉及NM_CUSTOMDRAW和WM_DRAWITEM 3 利用虚函数机制,重载虚函数。即DrawItem虚函数。 对于NM_CUSTOMDRAW,某些支持此消息的控件

C# 通过拖控件移动窗体

目录 引言一、通过控件事件移动窗体1、创建窗体界面2、添加控件事件3、添加代码 二、通过windowsAPI移动窗体1、 构建窗体和添加事件2、代码展示 引言 在C#Form窗体设计中,如果我们不需要使用默认边框设计自己个性化的窗体(FromBorderStyle=none时),这时候你会发现拖动窗体的功能就没有了,这里需要自己构建方法让用户可以拖动整个窗体,这里我们使用前辈的

WPF入门到跪下 第十三章 3D绘图 - 3D绘图基础

3D绘图基础 四大要点 WPF中的3D绘图涉及4个要点: 视口,用来驻留3D内容3D对象照亮部分或整个3D场景的光源摄像机,提供在3D场景中进行观察的视点 一、视口 要展示3D内容,首先需要一个容器来装载3D内容。在WPF中,这个容器就是Viewport3D(3D视口),它继承自FrameworkElement,因此可以像其他元素那样在XAML中使用。 Viewport3D与其他元素相

Qt-常用控件(3)-多元素控件、容器类控件和布局管理器

1. 多元素控件 Qt 中提供的多元素控件有: QListWidgetQListViewQTableWidgetQTableViewQTreeWidgetQTreeView xxWidget 和 xxView 之间的区别,以 QTableWidget 和 QTableView 为例. QTableView 是基于 MVC 设计的控件.QTableView 自身不持有数据,使用 QTab

ASP.NET手动触发页面验证控件事件

开发环境:.NET Framework 3.5.1 sp1 参考文章: http://www.codeproject.com/KB/aspnet/JavascriptValidation.aspx http://msdn.microsoft.com/zh-cn/library/aa479045.aspx http://www.cnblogs.com/minsentinel/archive/