博客
关于我
Win32 树视图控件的基本使用
阅读量:113 次
发布时间:2019-02-26

本文共 4078 字,大约阅读时间需要 13 分钟。

使用C++创建树视图控件

一、创建树视图控件

在C++中使用Windows公共控件库创建树视图控件的基本步骤如下:

  • 导入必要的头文件

    • 包括<windows.h><commctrl.h>,确保有树视图控件的支持。
  • 注册窗口类

    • 使用RegisterClassEx函数注册窗口类,指定窗口的类名和窗口处理函数。
  • 创建主窗口

    • 使用CreateWindowEx函数创建主窗口,设置窗口的位置和样式。
  • 创建树视图控件

    • 使用CreateWindow函数创建树视图控件,指定窗口的类名和样式参数。常用的样式参数包括:

      • WS_CHILD:表示该窗口是另一个窗口的子窗口。
      • WS_BORDER:设置边框。
      • WS_VISIBLE:设置可见。
      • TVM_HASLINES:显示线条。
      • TVM_HASBUTTONS:显示按钮。
      • TVM_LINESATROOT:根结点下方显示线条。
    • 将树视图控件插入主窗口,获取其句柄。

  • 验证控件创建

    • 使用wsprintf函数格式化树视图句柄地址,并通过MessageBox显示确认。

  • 二、添加根结点

  • 定义插入结构体

    • 创建TVINSERTSTRUCT结构体TvInsertItem,用于描述要插入的树节点。
  • 设置结构体属性

    • hParent:父结点句柄,根结点填NULL
    • hInsertAfter:插入位置,使用TVI_LAST表示插入列表末尾。
    • item:存储节点信息,包括:
      • mask:设置节点类型,使用TVIF_TEXT表示文本节点。
      • pszText:节点显示文本。
  • 发送插入消息

    • 使用SendMessage函数发送TVM_INSERTITEM消息,传递结构体指针,获取新增节点句柄。
  • 验证插入结果

    • 检查是否成功获取节点句柄,确认树节点已正确添加。

  • 三、扩展树结构

  • 添加子节点

    • 重复上述步骤,使用已存在节点的句柄作为新的父节点。
    • 将新的节点插入到父节点的末尾或指定位置。
  • 创建多层级结构

    • 逐步添加子节点,确保树结构层次清晰。

  • 四、完整代码示例

    #include 
    #include
    #define IDM_EXIT 10001#define IDM_ABOUT 10002#define IDC_WIN32TREEDEMO 10101LRESULT CALLBACK WindowProcedure(HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam){ static HINSTANCE hInst = NULL; static HWND hTree = NULL; switch (message) { case WM_CREATE: hTree = CreateWindow("SysTreeView32", NULL, WS_CHILD | WS_BORDER | WS_VISIBLE | TVS_HASLINES | TVS_HASBUTTONS | TVS_LINESATROOT, 10, 20, 200, 400, hwnd, NULL, NULL, NULL); TvInsertItem.hParent = NULL; TvInsertItem.hInsertAfter = TVI_LAST; TvInsertItem.item.mask = TVIF_TEXT; TvInsertItem.item.pszText = "根结点AAAA"; hitema = SendMessage(hTree, TVM_INSERTITEM, 0, (LPARAM)&TvInsertItem); TvInsertItem2.hParent = hitema; TvInsertItem2.hInsertAfter = TVI_LAST; TvInsertItem2.item.mask = TVIF_TEXT; TvInsertItem2.item.pszText = "子结点AABB"; hitemab = SendMessage(hTree, TVM_INSERTITEM, 0, (LPARAM)&TvInsertItem2); TvInsertItem3.hParent = hitema; TvInsertItem3.hInsertAfter = TVI_LAST; TvInsertItem3.item.mask = TVIF_TEXT; TvInsertItem3.item.pszText = "子结点AACC"; hitemac = SendMessage(hTree, TVM_INSERTITEM, 0, (LPARAM)&TvInsertItem3); TvInsertItem4.hParent = NULL; TvInsertItem4.hInsertAfter = TVI_LAST; TvInsertItem4.item.mask = TVIF_TEXT; TvInsertItem4.item.pszText = "根结点BBBB"; hitemb = SendMessage(hTree, TVM_INSERTITEM, 0, (LPARAM)&TvInsertItem4); break; case WM_DESTROY: PostQuitMessage(0); break; default: return DefWindowProc(hwnd, message, wParam, lParam); } return 0;}int WINAPI WinMain(HINSTANCE hThisInstance, HINSTANCE hPrevInstance, LPSTR lpszArgument, int nFunsterStil){ HWND hwnd; MSG messages; WNDCLASSEX wincl; wincl.hInstance = hThisInstance; wincl.lpszClassName = "win32TreeDemo"; wincl.lpfnWndProc = WindowProcedure; wincl.style = CS_DBLCLKS; wincl.cbSize = sizeof(WNDCLASSEX); wincl.hIcon = LoadIcon(NULL, IDI_APPLICATION); wincl.hIconSm = LoadIcon(NULL, IDI_APPLICATION); wincl.hCursor = LoadCursor(NULL, IDC_ARROW); wincl.lpszMenuName = MAKEINTRESOURCE(IDC_WIN32TREEDEMO); wincl.cbClsExtra = 0; wincl.cbWndExtra = 0; wincl.hbrBackground = (HBRUSH)(COLOR_WINDOW + 1); if (!RegisterClassEx(&wincl)) return 0; hwnd = CreateWindowEx( 0, "win32TreeDemo", TEXT("win32TreeDemo"), WS_OVERLAPPEDWINDOW, CW_USEDEFAULT, CW_USEDEFAULT, 300, 500, HWND_DESKTOP, NULL, hThisInstance, NULL ); ShowWindow(hwnd, nFunsterStil); while (GetMessage(&messages, NULL, 0, 0)) { TranslateMessage(&messages); DispatchMessage(&messages); } return messages.wParam;}

    五、资源文件

    #resource.hIDC_WIN32TREEDEMO MENU BEGINPOPUP "File"BEGINMENUITEM "E&xit",        IDM_EXITENDPOPUP "Help"BEGINMENUITEM "&About ...",    IDM_ABOUTENDEND

    六、常用宏定义

    #define IDM_EXIT        10001#define IDM_ABOUT       10002#define IDC_WIN32TREEDEMO  10101

    转载地址:http://mquy.baihongyu.com/

    你可能感兴趣的文章
    mysql 存储过程每隔一段时间执行一次
    查看>>
    mysql 存在update不存在insert
    查看>>
    Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
    查看>>
    Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
    查看>>
    Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
    查看>>
    Mysql 学习总结(89)—— Mysql 库表容量统计
    查看>>
    mysql 实现主从复制/主从同步
    查看>>
    mysql 审核_审核MySQL数据库上的登录
    查看>>
    mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
    查看>>
    mysql 导入导出大文件
    查看>>
    MySQL 导出数据
    查看>>
    mysql 将null转代为0
    查看>>
    mysql 常用
    查看>>
    MySQL 常用列类型
    查看>>
    mysql 常用命令
    查看>>
    Mysql 常见ALTER TABLE操作
    查看>>
    MySQL 常见的 9 种优化方法
    查看>>
    MySQL 常见的开放性问题
    查看>>
    Mysql 常见错误
    查看>>
    mysql 常见问题
    查看>>