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

相关文章

C#实现WinForm控件焦点的获取与失去

《C#实现WinForm控件焦点的获取与失去》在一个数据输入表单中,当用户从一个文本框切换到另一个文本框时,需要准确地判断焦点的转移,以便进行数据验证、提示信息显示等操作,本文将探讨Winform控件... 目录前言获取焦点改变TabIndex属性值调用Focus方法失去焦点总结最后前言在一个数据输入表单

最好用的WPF加载动画功能

《最好用的WPF加载动画功能》当开发应用程序时,提供良好的用户体验(UX)是至关重要的,加载动画作为一种有效的沟通工具,它不仅能告知用户系统正在工作,还能够通过视觉上的吸引力来增强整体用户体验,本文给... 目录前言需求分析高级用法综合案例总结最后前言当开发应用程序时,提供良好的用户体验(UX)是至关重要

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与其他元素相