Win32 SDK 下的TreeCtrl控件的封装
自己照着MFC封装,半月前封装了一半,碰到问题就放下了,今天终于封装好了.
[Ctree.h]文件
#pragma once
#include <windows.h>
#include <commctrl.h> struct MTVINSERTSTRUCT
{
TVINSERTSTRUCT tvInsert;
TCHAR strMid[2500];
}; class CTree
{
public:
CTree();
~CTree(); HWND m_hWnd;
public:
//获得树控件的句柄
BOOL GetHwnd(HWND _pHwnd, UINT _idd); //插入树节点
HTREEITEM InsertItem(LPTVINSERTSTRUCT lpInsertStruct);
HTREEITEM InsertItem(LPCTSTR lpszItem, int nImage, int nSelectedImage,
HTREEITEM hParent, HTREEITEM hInsertAfter); //获得选中节点的句柄
HTREEITEM GetSelectedItem()const;
//删除选中节点
BOOL DeleteItem(HTREEITEM hItem);
//删除所有的节点项
BOOL DeleteAllItem();
//设置节点附加的32位数据
BOOL SetItemData(HTREEITEM hItem, DWORD dwData);
//设置节点项数据
BOOL SetItem(TVITEM *pItem);
BOOL SetItem(HTREEITEM hItem, UINT nMask, LPCTSTR lpszItem, int nImage, int nSelectedImage,
UINT nState, UINT nStateMask, LPARAM lParam);
//获得选中节点项附加的32位数据
DWORD GetItemData(HTREEITEM hItem)const;
//获得选中节点项的显示的名称
TCHAR* GetItemText(HTREEITEM hItem)const;
//获得选中节点项的图标索引值
BOOL GetItemImage(HTREEITEM hItem, int &nImage, int &nSelectedImage)const;
//获得选中节点项的展开状态
BOOL GetItemState(HTREEITEM hItem, UINT nStateMask) const;
};
[Ctree.cpp]文件
#include "CTree.h"
#include <tchar.h>
#include <atlchecked.h> #pragma region MY_CtreeCtrl_Class CTree::CTree()
{
m_hWnd = NULL; } CTree::~CTree()
{ } BOOL CTree::GetHwnd(HWND _pHwnd, UINT _idd)
{
m_hWnd = GetDlgItem(_pHwnd, _idd);
if (m_hWnd)
{
return TRUE;
}
return FALSE;
} HTREEITEM CTree::InsertItem(LPTVINSERTSTRUCT lpInsertStruct)
{
IsWindow(m_hWnd);
return (HTREEITEM)::SendMessage(m_hWnd, TVM_INSERTITEM, 0, (LPARAM)lpInsertStruct);
} HTREEITEM CTree::InsertItem(LPCTSTR lpszItem, int nImage, int nSelectedImage, HTREEITEM hParent, HTREEITEM hInsertAfter)
{
IsWindow(m_hWnd);
TVINSERTSTRUCT lpInsert;
lpInsert.item.mask = TVIF_TEXT | TVIF_IMAGE | TVIF_SELECTEDIMAGE;
lpInsert.item.iImage = nImage;
lpInsert.item.iSelectedImage = nSelectedImage;
lpInsert.item.pszText = (LPWSTR)lpszItem; if (NULL == hParent)
hParent = TVI_ROOT;
lpInsert.hParent = hParent; lpInsert.hInsertAfter = hInsertAfter; return InsertItem(&lpInsert);
} HTREEITEM CTree::GetSelectedItem() const
{
IsWindow(m_hWnd);
return (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_CARET, 0);
} BOOL CTree::DeleteItem(HTREEITEM hItem)
{
IsWindow(m_hWnd);
return (BOOL)::SendMessage(m_hWnd, TVM_DELETEITEM, 0, (LPARAM)hItem);
} BOOL CTree::DeleteAllItem()
{
IsWindow(m_hWnd);
return (BOOL)::SendMessage(m_hWnd, TVM_DELETEITEM, 0, (LPARAM)TVI_ROOT);
}
//32位系统可用
BOOL CTree::SetItemData(HTREEITEM hItem, DWORD dwData)
{
IsWindow(m_hWnd); return SetItem(hItem, TVIF_PARAM, NULL, 0, 0, 0, 0, (LPARAM)dwData);
}
//64位系统上要用LPARAM 用DWORD要被截断
//***********************************************************************************
BOOL AfxCTreeCtrl::SetItemData(HTREEITEM hItem, LPARAM dwData)
{
ASSERT(IsWindow(m_hWnd));
return SetItem(hItem, TVIF_PARAM, NULL, 0, 0, 0, 0, (LPARAM)dwData);
}
//***********************************************************************************
BOOL CTree::SetItem(TVITEM * pItem)
{
IsWindow(m_hWnd);
return (BOOL)SendMessage(m_hWnd, TVM_SETITEM, 0, (LPARAM)pItem);
} BOOL CTree::SetItem(HTREEITEM hItem, UINT nMask, LPCTSTR lpszItem, int nImage, int nSelectedImage, UINT nState, UINT nStateMask, LPARAM lParam)
{
IsWindow(m_hWnd);
TVITEM item;
item.hItem = hItem;
item.mask = nMask;
item.pszText = (LPTSTR)lpszItem;
item.iImage = nImage;
item.iSelectedImage = nSelectedImage;
item.state = nState;
item.stateMask = nStateMask;
item.lParam = lParam;
return (BOOL)::SendMessage(m_hWnd, TVM_SETITEM, 0, (LPARAM)&item);
}
//32位系统可用
DWORD CTree::GetItemData(HTREEITEM hItem) const
{
IsWindow(m_hWnd);
if (NULL == hItem)
return 0;
TVITEM item;
item.hItem = hItem;
item.mask = TVIF_PARAM;
::SendMessage(m_hWnd, TVM_GETITEM, 0, (LPARAM)&item);
return item.lParam; }
//64位系统用
LPARAM AfxCTreeCtrl::GetItemData(HTREEITEM hItem) const
{
ASSERT(IsWindow(m_hWnd));
TVITEM item;
item.hItem = hItem;
item.mask = TVIF_PARAM;
::SendMessage(m_hWnd, TVM_GETITEM, 0, (LPARAM)&item);
return (LPARAM)item.lParam;
}
TCHAR* CTree::GetItemText(HTREEITEM hItem) const
{
IsWindow(m_hWnd);
TCHAR* str = new TCHAR[128];
TVITEM item;
item.hItem = hItem;
item.mask = TVIF_TEXT;
item.pszText = str;
item.cchTextMax = 128; ::SendMessage(m_hWnd, TVM_GETITEM, 0, (LPARAM)&item); return str;
} BOOL CTree::GetItemImage(HTREEITEM hItem, int &nImage, int &nSelectedImage) const
{
IsWindow(m_hWnd);
TVITEM item = { 0 };
item.hItem = hItem;
item.mask = TVIF_IMAGE | TVIF_SELECTEDIMAGE;
BOOL bRes = (BOOL)::SendMessage(m_hWnd, TVM_GETITEM, 0, (LPARAM)&item);
if (bRes)
{
nImage = item.iImage;
nSelectedImage = item.iSelectedImage;
}
return bRes;
} BOOL CTree::GetItemState(HTREEITEM hItem, UINT nStateMask) const
{
IsWindow(m_hWnd);
TVITEM item = { 0 };
item.hItem = hItem;
item.mask = TVIF_STATE;
item.stateMask = nStateMask;
item.state = 0;
::SendMessage(m_hWnd, TVM_GETITEM, 0, (LPARAM)&item);
return item.state;
} #pragma endregion MY_CtreeCtrl_Class
[test.cpp]中测试
HTREEITEM hItem = m_tree.GetSelectedItem();
//TVITEM tvi;
//TCHAR szName[20] = { 0 };
////LPARAM lp = 0;
//tvi.mask = TVIF_TEXT | TVIF_PARAM;
//tvi.hItem = hItem;
//tvi.pszText = szName;
//tvi.cchTextMax = sizeof(szName);
////tvi.lParam = lp;
//TreeView_GetItem(m_tree.m_hWnd, &tvi);
//Stu *pstu = (Stu*)tvi.lParam; //获得选中节点的附加(由SetItemData设置的)数据
/*Stu* pstu = (Stu*)m_tree.GetItemData(hItem);
TCHAR *pch = (TCHAR*)m_tree.GetItemData(hItem);*/
//上次在封装这附加数据的时候碰到了问题.
在设置的时候:
TCHAR *pch = new TCHAR;
pch=mid;//mid为要设置的附加数据,类型为TCHAR
m_tree.SetItemData(nItem, (DWORD)pch);
就一直取不出来要的数据,就放下了.今天来看的时候才发现
TCHAR *pch = new TCHAR[128];
_tcscpy_s(pch, 128, mid);
m_tree.SetItemData(nItem, (DWORD)pch);
我用结构体指针为附加数据时,又能正确取出数据.就有点晕菜了,最后才发现.
TCHAR new出来时没给定大小.
正确代码为:
TCHAR *pch = new TCHAR[128];
_tcscpy_s(pch, 128, mid);
m_tree.SetItemData(nItem, (DWORD)pch);
//获得选中节点的Text
/*TCHAR *pch = m_tree.GetItemText(hItem);
MessageBox(NULL, pch, TEXT("123"), MB_OK);*/ //获得选中节点的图标的索引
/*int nImate, nSelectedImage;
m_tree.GetItemImage(hItem, nImate, nSelectedImage);*/ //获得选中节点是否展开,返回0为未展开,非0为展开状态 //UINT n = m_tree.GetItemState(hItem, TVIS_EXPANDED); BOOL m = m_tree.GetItemState(hItem, TVIS_EXPANDED) & TVIS_EXPANDED;
释放节点附加数据内存
//5.附加内存的释放
//在子控件通知消息中捕获TVN_DELETEITEM消息
NMHDR *pNMHDR = (NMHDR*)lParam;
if (pNMHDR->idFrom == IDC_TREE1 && pNMHDR->code==TVN_DELETEITEM)
{
NMTREEVIEW *pnmTV = (NMTREEVIEW*)lParam;
HTREEITEM hSelItem = pnmTV-> itemNew.hItem; //从lParam参数中获得选中项的句柄
//释放节点附加数据内存
TVITEM item = pnmTV->itemOld;
if (item.lParam != 0)
{
delete (TCHAR*)item.lParam;//删除的数据类型要和前面添加时你附加的数据类型一样,
} }
Win32 SDK 下的TreeCtrl控件的封装的更多相关文章
- Win32 SDK程序创建一些控件(简单调用InitCommonControlsEx,并指定ICC_LISTVIEW_CLASSES控件就可以了)
在Win32 SDK中创建一些控件的时候需要注意一下(具体是哪些控件请参看MSDN文档中列出来的) /* MSDN:Carries information used to load common co ...
- 9.2.2 .net framework下的MVC 控件的封装(下)
控件封装的部分说明 可能有人觉得应该前后端分离,我也承认这是应该的方向,我们也在考虑使用ng2等简化前端.但是,我们封装控件还是因为如下原因综合考虑的: 我们这是个框架,上面支撑了许多个应用,包含几百 ...
- 9.2.1 .net framework下的MVC 控件的封装(上)
在写.net core下mvc控件的编写之前,我先说一下.net framework下我们MVC控件的做法. MVC下控件的写法,主要有如下三种,最后一种是泛型的写法,mvc提供的控件都是基本控件. ...
- win32 TreeCtrl控件通知消息, LVN_SELCHANGED和LVN_ITEMCHANGED用法
今天出了个奇怪的问题,当我在主窗口上创建一个用模板对话框的子窗口时, 在子窗口上放的TreeCtrl控件不响应LVN_SELCHANGED消息,也是晕死了, 我以为是消息捕获的问题,我在主窗口上也捕获 ...
- Google SwipeRefreshLayout(Goolge官方下拉刷新控件)尝鲜
前天Google官方终于出了Android刷新控件——SwipeRefreshLayout. 使用前先需要将android.support.v4.jar升级到19.1.升级后,可能会出现SDK版本与A ...
- Android——谷歌官方下拉刷新控件SwipeRefreshLayout(转)
转自:http://blog.csdn.net/zouzhigang96/article/details/50476402 版权声明:本文为博主原创文章,未经博主允许不得转载. 前言: 如今谷歌推出了 ...
- android官方下拉刷新控件SwipeRefreshLayout的使用
可能开发安卓的人大多数都用过很多下拉刷新的开源组件,但是今天用了官方v4支持包的SwipeRefreshLayout觉得效果也蛮不错的,特拿出来分享. 简介:SwipeRefreshLayout组件只 ...
- 分享一个 C# Winfrom 下的 OutlookBar 控件的使用
最近在上网的时候,发现了这个C# 下的 OutlookBar 控件,看了一下感觉还真不错,特此记录一下. using System; using System.Drawing; using Syste ...
- [Android]下拉刷新控件RefreshableView的实现
以下内容为原创,欢迎转载,转载请注明 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/4172483.html 需求:自定义一个ViewGroup,实现 ...
- android SwipeRefreshLayout google官方下拉刷新控件
下拉刷新功能之前一直使用的是XlistView很方便我前面的博客有介绍 SwipeRefreshLayout是google官方推出的下拉刷新控件使用方法也比较简单 今天就来使用下SwipeRefres ...
随机推荐
- 聊一聊 C# 弱引用 底层是怎么玩的
一:背景 1. 讲故事 最近在分析dump时,发现有程序的卡死和WeakReference有关,在以前只知道怎么用,但不清楚底层逻辑走向是什么样的,借着这个dump的契机来简单研究下. 二:弱引用的玩 ...
- selenium验证码识别,超级鹰干超级鹰
from selenium.webdriver import Edge from selenium.webdriver.common.by import By # 在这里导入浏览器设置相关的类 fro ...
- ROS2开发BUG记录:在将 use_sim_timer 置为 true 时,节点的 Timer_Callback 行为“异常”
问题: 在将 use_sim_timer 置为 true 时,节点 Timer_Callback 行为 "异常" .在回调函数中,使用 self.get_logger().info ...
- window10设置开机自启动exe的三种方式(亲测有效)
拷贝文件到自启动位置 路径地址:C:\ProgramData\Microsoft\Windows\Start Menu\Programs\StartUp 通过组策略设置脚本随服务器启动 开始-> ...
- 原创软件 | 第3期:PDF合并分割助手V1.0(个人免费)
这是一个短的"发布会". 01 基本介绍 近期开发了一个[PDF合并分割助手]. 它是一个实现pdf快速合并.分割的免费软件. 你拥有以下7种选项设置. >>合并选项& ...
- MySQL_数据库命名规范及约定
操作规范 如无说明,建表时一律采用innodb引擎: 如无说明,数据库表编码集(utf8,utf8_bin)ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf ...
- OpenGL 三角形颜色插值
1.最懒的方法--Nearest Neighbor对于三角形内的点,离三个顶点谁最近,就赋值为那个顶点对应的颜色. 2.最天真的方法--Distance三角形内一点的值应该来自于三个顶点. 计算距离: ...
- 【转载】Win10系统, administrator账户被微软账户强行绑定,怎么破?
首先 声明:这是转载,我只是做一个记录,以下内容可解决问题(本人已尝试并已解决),当然也可以去转载出处查看大佬的原回答: Win10系统, administrator账户被微软账户强行绑定,怎么破? ...
- 新版宝塔面板快速搭建WordPress新手教程
一.宝塔面板介绍 1. 介绍 宝塔面板是一款服务器管理软件,支持Windows和Linux系统,可以通过Web端轻松管理服务器,提升运维效率,该软件内置了创建管理网站.FTP.数据库.可视化文件管理器 ...
- 用jacoco统计JAVA项目测试代码覆盖率
一.概述 Jacoco 统计的是全量代码覆盖率.它不仅支持生成单元测试的覆盖率,也支持监控生成接口测试,功能测试的覆盖率. 在新一代精准测试技术流的影响中,各大型单位对覆盖率的追求越来越迫切.作为一款 ...