在SDK中使用TreeView控件

在SDK中使用控件非常的麻烦,不像VB之类的编辑工具,直接设置控件属性就能很方便的控制控件。平时用得最多的控件包括按钮、ListBox、 ComboBox、Edit、Image List等,学了一个多月SDK,发现只会用按钮和Edit控件,其它的控件一点儿都不会用,所以决定拿些时间来熟悉这些常用控件,首先准备熟悉的是 TreeView控件。 一、TreeView 不管是作用TreeView控件还是ListView控件,都得用到几个结构体,如果对这些结构体不了解,那在使用控件时就糊理糊涂的,胡乱修改结构体的值,设置不出想要的结果,也不知改哪里,结果出来了也不知怎么出来的。不知为什么,今晚状态特别好,心很静,前几天熟悉控件的使用时,直接从 MSDN上把代码复制下来,也没心思去读代码,搞了半天也显示不出想要的结果,有句话说得很对,心态决定成败。 使用TreeView控件会用到TVITEM、TVINSERTSTRUCT二个结构体,熟悉了这二个结构体,控制TreeView就基本不成问题了。 1.TVITEM结构体 该结构体是用来设置节点信息的,比如节点的名称、节点名称占用的长度、指定能使用的结构体成员以及节点状态等信息。先来看看TVITEM结构体的定义: typedef struct tagTVITEM { UINT mask; HTREEITEM hItem; UINT state; UINT stateMask; LPTSTR pszText; int cchTextMax; int iImage; int iSelectedImage; int cChildren; LParaM lParam; } TVITEM,*LPTVITEM; mask 是指定能使用的结构体成员,比如将mask的值设置为“TVIF_TEXT | TVIF_STATE”,那么就只能使用TVITEM结构体中的pszText和state成员,当然,mask成员无论在什么时候都是可用的。 hItem 选择该节点的句柄,搞了半天才明白这个成员的作用,既然是句柄,那就得先获取句柄,然后才能使用句柄。在TreeView创建第一个节点时,是不用设置这个成员的。有了第一个节点后,可以通过多种途径来获取一个节点的句柄,如TreeView_InsertItem函数、 TreeView_GetNextItem函数、TreeView_GetParnt函数等,都可以获取节点的句柄,获取节点的句柄后,就可以对该节点进行控制了。 state 这个是用来设置节点状态的,这个成员的设置貌似挺复杂的,一个节点到底有多少种状态,没搞清。好像应该大概可能是16种状态。好好的研究了一下,发现state成员是一个UINT类型,也就是unsigned int数据类型,是16位的,也就是说每1位是一种状态,刚好有16种状态。0-7位是普通节点的状态,8-11是覆盖图像索引,啥意思?没看懂!12-15位是图像索引,我估摸着,8-11和12-15应该是节点图片的几种状态,操,转了一圈又转回去了。到是0-7位的节点状态比较好理解,整理如下: TVIS_BOLD -节点名称加粗 TVIS_CUT - 将选择的节点作为复制和粘贴的目标 TVIS_DROPHILITED - 将选择的节点作为拖拽目标,用于拖动节点的 TVIS_EXPANDED - 展开该节点下的子节点 TVIS_EXPANDEDONCE -搞不懂?????? TVIS_EXPANDPARTIAL -展开部分节点 TVIS_SELECTED -节点处于选择状态 还有三个 TVIS_OVERLAYMASK -覆盖图像索引的掩码,不太懂 TVIS_STATEIMAGEMASK -图像索引掩码,还是不太懂 TVIS_USERMASK -同 TVIS_STATEIMAGEMASK 这数来数去,怎么只有10种状态,还有6种呢? stateMask stateMask的作用类似于mask,是用于指定有效的节点状态,例如要使用TVIS_BOLD和TVIS_EXPANDED两种状态,就必须在stateMask中指定这两种状态,也就是说state和stateMask中的设置得一样。 pszText 节点名称。 cchTextMax 节点名称长度。 iImage 节点在非选中状态下的图像索引,好像是通过IMAGELIST来建立图像索引。 iSelectedImage 节点在选中状态下的图像索引 表示树控件项是否有相关的子结点的标志位。此成员可以是以下值之一: 0 —— 表示此项没有子结点。 1 —— 表示此此项有一个或多个子结点。 I_CHILDRENCALLBACK —— 父窗口会始终跟踪确定此项是否有子结点。此时,如果树控件需要显示项时,它会给父窗口发送TVN_GETdisPINFO通知消息,决定此项是否有子结点。如果树控件含有TVS_HASBUTTONS风格,则它使用此成员来决定是否显示按钮以表明存在子结点。也可以使用此成员来强制树控件显示按钮,尽管没有在此项之下插入任何子结点。这样可以最小化由于在此项之下插入了子结点所占用的控件内存。 lParam 同控件相关的32位值。是些啥值?不知道 到此虽然对TVITEM结构还有些不清不楚,但对于一般的节点控制应该没啥问题了。 2.TVINSERTSTRUCT结构体 TVITEM结构体是对单个的、独立的节点信息进行设置,而TVINSERTSTRUCT则是对要添加节点的所有属性进行设置,也包括TVITEM 结构体,比如节点添加到TreeView的哪个位置、以及父节点的句柄,其结构体的定义中下: typedef struct tagTVINSERTSTRUCT { HTREEITEM hParent; HTREEITEM hInsertAfter; #if (_WIN32_IE >= 0x0400) union { TVITEMEX itemex; TVITEM item; } DUMMYUNIONNAME; #else TVITEM item; #endif } TVINSERTSTRUCT,*LPTVINSERTSTRUCT; 一共个四个成员 hParent 父节点句柄 hInsertAfter 在哪个节点前插入 item 一个TVITEM结构体 以上这两个结构体,除了TVITEM中的少数几个成员的作用还弄不清外,其余的都了解个七七八八了。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Format[$] ( expr [ , fmt ] ) format 返回变体型 format$ 强制返回为文本 -------------------------------- 数字类型的格式化 --------------------------------     固定格式参数:     General Number 普通数字,如可以用来去掉千位分隔号     format$("100,1
VB6或者ASP 格式化时间为 MM/dd/yyyy 格式,竟然没有好的办法, Format 或者FormatDateTime 竟然结果和系统设置的区域语言的日期和时间格式相关。意思是尽管你用诸如 Format(Now, "MM/dd/yyyy"),如果系统的设置格式区域语言的日期和时间格式分隔符是"-",那他还会显示为 MM-dd-yyyy     只有拼凑: <%response.write
在项目中添加如下代码:新建窗口来显示异常信息。 Namespace My ‘全局错误处理,新的解决方案直接添加本ApplicationEvents.vb 到工程即可 ‘添加后还需要一个From用来显示错误。如果到这步还不会则需要先打好基础啦 ‘======================================================== ‘以下事件
转了这一篇文章,原来一直想用C#做k3的插件开发,vb没有C#用的爽呀,这篇文章写与2011年,看来我以前没有认真去找这个方法呀。 https://blog.csdn.net/chzjxgd/article/details/6176325 金蝶K3 BOS的插件官方是用VB6编写的,如果  能用.Net下的语言工具开发BOS插件是一件很愉快的事情,其中缘由不言而喻,而本文则是个人首创,实现在了用V
Sub 分列() ‘以空格为分隔符,连续空格只算1个。对所选中的单元格进行处理 Dim m As Range, tmpStr As String, s As String Dim x As Integer, y As Integer, subStr As String If MsgBox("确定要分列处理吗?请确定分列的数据会覆盖它后面的单元格!", _
  窗体代码 1 Private Sub Text1_OLEDragDrop(Data As DataObject, Effect As Long, Button As Integer, Shift As Integer, X As Single, Y As Single) 2 Dim path As String, hash As String 3 For Each fil
  Imports MySql.Data.MySqlClient Public Class Form1 ‘ GLOBAL DECLARATIONS Dim conString As String = "Server=localhost;Database=net2;Uid=root;Pwd=123456;" Dim con As New MySqlConnection
‘導入命名空間 Imports ADODB Imports Microsoft.Office.Interop   Private Sub A1() Dim Sql As String Dim Cnn As New ADODB.Connection Dim Rs As New ADODB.Recordset Dim S As String   S = "Provider=OraOLEDB.Oracl
Imports System.IO Imports System.Threading Imports System.Diagnostics Public Class Form1 Dim A(254) As String    Function ping(ByVal IP As Integer) As String Dim IPAddress As String IPAddress = "10.0.
VB运行EXE程序,并等待其运行结束 参考:https://blog.csdn.net/useway/article/details/5494084 Private Declare Function WaitForSingleObject Lib "kernel32" (ByVal hHandle As Long, ByVal dwMilliseconds As Long) As Long Pr
今天碰到一个问题,登陆的时候,如果不需要验证手机号为空,则不去验证手机号 因为登陆的时候所有的验证信息都存放在一个数组里 Dim CheckUserInfo() As String ={UserBirthday, SecEmail, UserMob, UserSex, RealNameFirst, RealName, CheckCardID, CheckCardType, Contactemail
在VB6.0中,数据访问接口有三种: 1、ActiveX数据对象(ADO) 2、远程数据对象(RDO) 3、数据访问对象(DAO) 1.使用ADO(ActiveX Data Objec,ActiveX数据对象)连接SQL Server 1)使用ADO控件连接 使用ADO控件的ConnectionString属性就可以连接SQL Server,该属性包含一个由分号分隔的argument=value语
注:大家如果没有VB6.0的安装文件,可自行百度一下下载,一般文件大小在200M左右的均为完整版的软件,可以使用。   特别提示:安装此软件的时候最好退出360杀毒软件(包括360安全卫士,电脑管家等,如果电脑上有这些软件的话),因为现如今的360杀毒软件直接会对VB6.0软件误报,这样的话就可能会在安装过程中被误报阻止而导致安装失败,或者是安装后缺乏很多必须的组件(其它的杀毒软件或安全卫士之类的
Private Sub Form_Load() Call conndb End Sub Private Function conndb() Dim cn As New ADODB.Connection Dim rs As New ADODB.Recordset Dim strCn, sql As String Dim db_host As String Dim db_user As String
  PPSM06S70:  Add  moddate  EDITSPRINTJOB:  MAX(TO_CHAR(ETRN.MODDATE, ‘yyyy/mm/dd/HH24:MI AM‘)) ACTUAL_SHIPDATE   4.Test Scenario (1) :Query SQL Test DN:8016578337 SELECT CTRN.TKCTID TRUCK_ID,        
  沒有出現CrystalReportViewer時,須安裝CRforVS_13_0. 新增1個數據集,新增1個數據表,添加二列,列名要和資料庫名一樣. 修改目標Framework 修改app.config, <startup >改成<startup useLegacyV2RuntimeActivationPolicy ="true">  CrystalReport1.rpt增加數據庫專家 在表單
Imports System.Threading Imports System Public Class Form1 Dim th1, th2 As Thread Public Sub Method1() Dim i As Integer For i = 1 To 100 If Me.Label1.BackColor =
Friend Const PROCESS_ALL_ACCESS = &H1F0FFF = 2035711 Friend Const PROCESS_VM_READ = &H10 Friend Const PROCESS_VM_WRITE = &H20 Friend Const PAGE_READONLY = &H2 Friend Const PAGE_READWRITE = &H4 Friend
以下代码随手写的 并没有大量测试 效率也有待提升 如果需要C#的请自行转换 Function SplitBytes(Data As Byte(), Delimiter As Byte()) As List(Of Byte()) Dim i = 0 Dim List As New List(Of Byte()) Dim bytes As New
Imports System.Data.SqlClient Public Class Form1 REM Public conn1 As SqlConnection = New SqlConnection("server=.; Integrated Security=False;Initial Catalog= mydatabase1; User ID= sa;password")