TreeVIEw控件显示的内容比较单一,如果需要呈现更详细信息TreeListVIEw是一个不错的选择。
先看效果:
首先需要引用文件System.windows.Forms.TreeListVIEw.dll、System.Runtime.InteropServices.APIs.dll
你可以将TreeListVIEw加入到工具箱中然后在添加到窗体中。
1.你需要添加列
2.你需要添加一个ImageList作为节点图标的容器(你还需要配置TreeListVIEw的SmallimageList属性为ImageList控件的ID)
3.现在可以给控件绑定数据了
此控件比较适合呈现具有父子级关系的复杂数据结构,当然也包含XML格式的数据
下面尝试解析一个设备树XML然后绑定到控件中:
<Device name="hIDc-1600tv _192.168.230.188" ItemType="DVR" type="Onvif" TypeID="" Code="" location="" Description="" ID="" UniqueID="192.168.230.188"> <IP Value="192.168.230.188" /> <Port Value="80" /> <Username Value="admin" /> <Password Value="1234" /> <AuthenAddress Value="/" /> <AuthenMode Value="1" /> <OnvifUser Value="admin" /> <OnvifPwd Value="1234" /> <OnvifAddress Value="/onvif/device_service" /> <RTSPUser Value="admin" /> <RTSPPwd Value="1234" /> <ChildDevices> <Device name="" ItemType="Channel" type="" TypeID="" Code="" location="" Description="" ID="" UniqueID=""> <PTZenable Value="True" /> <PTZ1 Value="5" /> <PTZ2 Value="15" /> <PTZ3 Value="25" /> <PTZ4 Value="35" /> <PTZ5 Value="45" /> <PTZ6 Value="55" /> <PTZ7 Value="65" /> <PTZ8 Value="75" /> <PTZ9 Value="85" /> <ChildDevices> <Device name="" ItemType="RStreamer" type="" TypeID="1" Code="" location="" Description="" ID=""> <MediaProfile Value="1" /> <Multicast Value="False" /> </Device> <Device name="" ItemType="RStreamer" type="" TypeID="2" Code="" location="" Description="" ID=""> <MediaProfile Value="2" /> <Multicast Value="False" /> </Device> </ChildDevices> </Device> </ChildDevices></Device>
使用递归算法很容易提取XML的结构
public voID LoadXmlTree(string xml) { Xdocument xDoc = Xdocument.Parse(xml); TreeListVIEwItem item = new TreeListVIEwItem(); string Title = xDoc.Root.Attribute("name")?.Value ?? xDoc.Root.name.Localname; item.Text = Title; item.ImageIndex = 0; item.SubItems.Add(xDoc.Root.Attribute("UniqueID")?.Value); item.SubItems.Add(xDoc.Root.Attribute("ItemType")?.Value); PopulateTree (xDoc.Root,item.Items); tvDevice.Items.Add(item); } public voID PopulateTree (XElement element,TreeListVIEwItemCollection items) { foreach (XElement node in element.Nodes()) { TreeListVIEwItem item = new TreeListVIEwItem(); string Title = node.name.Localname.Trim(); item.Text = Title; if (Title == "Device") { var attr = node.Attribute("ItemType")?.Value; switch (attr) { case "Channel": item.ImageIndex = 1; break; case "RStreamer": item.ImageIndex = 3; break; default: break; } item.SubItems.Add(node.Attribute("UniqueID")?.Value); item.SubItems.Add(node.Attribute("ItemType")?.Value); } else { item.ImageIndex = 2; item.SubItems.Add(node.Attribute("Value")?.Value); } if (node.HasElements) { PopulateTree (node,item.Items); } items.Add(item); } }
说明:
TreeListVIEwItem可构造传入value和imageindex,其中value会赋值给Text属性,imageindex就是节点显示的图标所对应的ImageList的索引。TreeListVIEwItem的SubItems就是其扩展列,它会按顺序依次显示到后面的列中。
你可以设置ExpandMethod属性来控制节点展开的方式,设置CheckBoxes属性控制是否显示复选框。
你可以通过订阅BeforeExpand、BeforeCollapse、BeforeLabelEdit三个事件来修改不同状态下的图标,如:
private voID treeListVIEw1_BeforeExpand(object sender,TreeListVIEwCancelEventArgs e) { if(e.Item.ImageIndex == 0) e.Item.ImageIndex = 1; }
你可以设置LabelEdit属性来激活或禁用编辑,TreeListVIEwBeforeLabelEditEventArgs参数提供了相应的属性值。
private voID treeListVIEw1_BeforeLabelEdit(object sender,TreeListVIEwBeforeLabelEditEventArgs e) { if(e.ColumnIndex == 1) { ComboBox comboBox = new ComboBox(); comboBox.Items.AddRange(new string[]{"HTML","CSS","JavaScript"}); e.Editor = comboBox; } }
TreeListVIEw开源你也可以根据自己的需要进行修改。
总结
以上所述是小编给大家介绍的c# winform treeListvIEw的使用(treegrIDvIEw),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程小技巧网站的支持!
总结以上是内存溢出为你收集整理的c# winform treelistview的使用(treegridview)实例详解全部内容,希望文章能够帮你解决c# winform treelistview的使用(treegridview)实例详解所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)