博客
关于我
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:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
    查看>>
    MYSQL:基础——3N范式的表结构设计
    查看>>
    MYSQL:基础——触发器
    查看>>
    Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
    查看>>
    mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
    查看>>
    mysqldump 参数--lock-tables浅析
    查看>>
    mysqldump 导出中文乱码
    查看>>
    mysqldump 导出数据库中每张表的前n条
    查看>>
    mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
    查看>>
    Mysqldump参数大全(参数来源于mysql5.5.19源码)
    查看>>
    mysqldump备份时忽略某些表
    查看>>
    mysqldump实现数据备份及灾难恢复
    查看>>
    mysqldump数据库备份无法进行操作只能查询 --single-transaction
    查看>>
    mysqldump的一些用法
    查看>>
    mysqli
    查看>>
    MySQLIntegrityConstraintViolationException异常处理
    查看>>
    mysqlreport分析工具详解
    查看>>
    MySQLSyntaxErrorException: Unknown error 1146和SQLSyntaxErrorException: Unknown error 1146
    查看>>
    Mysql_Postgresql中_geometry数据操作_st_astext_GeomFromEWKT函数_在java中转换geometry的16进制数据---PostgreSQL工作笔记007
    查看>>