介绍

  • 本文将介绍 使用 TabBox的用法
  • 更多用法,请参考源码

TabBox.h 文件

文件中定义了公有接口,其中包括,添加tab页下的控件,删除、设置TabBox的属性

其中,我常用的有:GetCurSelSelectItemSetAttribute

其中,源码如下, 注释很完备,一看就看懂

/// 重写父类方法,提供个性化功能,请参考父类声明
virtual bool Add(Control* pControl) override;
virtual bool AddAt(Control* pControl, std::size_t iIndex) override;
virtual bool Remove(Control* pControl) override;
virtual bool RemoveAt(std::size_t iIndex) override;
virtual void RemoveAll() override;
virtual void SetAttribute(const std::wstring& strName, const std::wstring& strValue) override; /**
* @brief 获取当前选择项
* @return 返回当前选择项索引
*/
int GetCurSel() const; /**
* @brief 根据控件索引选择一个子项
* @param[in] iIndex 要选择的子项索引
* @return 成功返回 true,否则返回 false
*/
bool SelectItem(int iIndex); /**
* @brief 根据控件指针选择一个子项
* @param[in] pControl 要选择的子项指针
* @return 成功返回 true,否则返回 false
*/
bool SelectItem(Control* pControl); /**
* @brief 根据控件名称选择一个子项
* @param[in] pControlName 要选择的控件名称
* @return 成功返回 true,否则返回 false
*/
bool SelectItem(const std::wstring& pControlName); /**
* @brief 设置是否显示动画效果
* @param[in] bFadeSwitch 设置为 true 则显示,false 为不显示动画
* @return 无
*/
void SetFadeSwitch(bool bFadeSwitch); /**
* @brief 判断是否需要显示动画效果
* @return 返回 true 显示动画,false 为不显示动画效果
*/
bool IsFadeSwitch() { return m_bFadeSwith; }

一个样式

TabBox它个布局控件,不过只能同时只能选择一个; 它默认没有类似MFC的tab按钮可以点击,不过,我用了 Option按钮代替。 每个tab页下有两个按钮。

tab1

tab2

tab3

xml中定义

xml中定义如下

tab page 按钮,

option按钮

<HBox height="30">
<Option class="checkbox_push" text="tab1" name="page_1" group="selct_tab" selected="true"/>
<Option class="checkbox_push" text="tab2" name="page_2" group="selct_tab" />
<Option class="checkbox_push" text="tab3" name="page_3" group="selct_tab" />
</HBox>

TabBox控件

TabBox控件定义如下,我用了水平布局分别定义了每个tab窗口下显示的内容

 <TabBox width="stretch" height="stretch" name="tab_show" selectedid="0" >
<HBox bkcolor="dark_gray">
<Option class="checkbox_push" text="1" group="selct_tab2" />
<Option class="checkbox_push" text="2" group="selct_tab2" />
</HBox>
<HBox bkcolor="light_green">
<Option class="checkbox_push" text="3" group="selct_tab1" />
<Option class="checkbox_push" text="4" group="selct_tab1" />
</HBox>
<HBox bkcolor="blue">
<Option class="checkbox_push" text="5" group="selct_tab3" />
<Option class="checkbox_push" text="6" group="selct_tab3" />
</HBox>
</TabBox>

代码关联

option关联

定义如下

ui::Option*	tab_page_arr_[3] = { nullptr };

与界面控件关联

// 1.用option代替tab页
std::wstring page_btn_name_arr[] = {L"page_1", L"page_2", L"page_3" };
auto find_func = [&](ui::Option* pdst, const std::wstring name)
{
// 先找到控件
ui::Control* ppage_tmp = FindControl(name);
if (ppage_tmp)
{
// 找到控件再绑定点击处理函数
pdst = dynamic_cast<ui::Option*> (ppage_tmp);
if (pdst)
pdst->AttachSelect(nbase::Bind(&BasicForm::OnTabPageClicked, this, std::placeholders::_1));
} }; find_func(tab_page_arr_[0], page_btn_name_arr[0]);
find_func(tab_page_arr_[1], page_btn_name_arr[1]);
find_func(tab_page_arr_[2], page_btn_name_arr[2]);

其中,OnTabPageClicked函数体如下:

bool BasicForm::OnTabPageClicked(ui::EventArgs* msg)
{
if (NULL == msg || nullptr == msg)
return false; static std::map<std::wstring, int> map_page_name = { {L"page_1", 0}, {L"page_2", 1}, {L"page_3", 2} }; // 1. 获取控件的名字
std::wstring name = msg->pSender->GetName(); // 2.寻找索引
std::map<std::wstring, int>::iterator it = map_page_name.find(name); // 找到了就设置当前选中的是哪一个tab
if (it != map_page_name.end())
if (tab_box_)
tab_box_->SelectItem(it->second); return false;
}

TabBox关联

// 2.关联tabbox控件
ui::Control* pcontrol_2 = FindControl(L"tab_show");
if (pcontrol_2)
tab_box_ = dynamic_cast<ui::TabBox*>(pcontrol_2);

num_duilib之TabBox用法(21)的更多相关文章

  1. Mybatis-Plus 实战完整学习笔记(九)------条件构造器核心用法大全(上)

    一.Mybatisplus通用(公共方法)CRUD,一共17种(3.0.3版),2.3系列也是这么多,这个新版本一定程度进行了改造和删减. 二.构造器UML图(3.0.3)-----实体包装器,主要用 ...

  2. JSP目录

    JSP目录   课时1    jsp概述和背后原理31:11 课时2    三种jsp的scriptlet语法27:29 课时3    jsp的注释14:00 课时4    JSP4个域对象的作用域3 ...

  3. Boost程序库完全开发指南——深入C++“准”标准库(第3版)

    内容简介  · · · · · · Boost 是一个功能强大.构造精巧.跨平台.开源并且完全免费的C++程序库,有着“C++‘准’标准库”的美誉. Boost 由C++标准委员会部分成员所设立的Bo ...

  4. mysql语法总结及例子

    1. DDL相关 a. -- 查询所有数据库 show databases;-- 删除数据库drop database ladeng; b. -- use `数据库名称`; 表示使用此数据库 use ...

  5. 小白—职场之Java基础篇

    java基础篇 java基础 目录 1.java是一种什么语言,jdk,jre,jvm三者的区别 2.java 1.5之后的三大版本 3.java跨平台及其原理 4.java 语言的特点 5.什么是字 ...

  6. Java 复习整理day05

    1 package com.it.demo01_oop; 2 3 import java.util.Arrays; 4 5 /* 6 案例: 演示面向过程和面向对象代码的区别 7 8 面向过程编程思想 ...

  7. 21.xpath定位中id 、starts-with、contains、text()和last() 的用法

    xpath语法:id .starts-with.contains.text()和last() 的用法 <input id="su" class="bg s_btn ...

  8. 21.Python算术运算符及用法详解

    算术运算符是处理四则运算的符号,在数字的处理中应用得最多.Python 支持所有的基本算术运算符,如表 1 所示. 表 1 Python常用算术运算符 运算符 说明 实例 结果 + 加 12.45 + ...

  9. [mybatis]Example的用法 标签: mybatis 2017-05-21 21:46 651人阅读 评论(11)

    Example类是什么? Example类指定如何构建一个动态的where子句. 表中的每个non-BLOB列可以被包括在where子句中. 例子是展示此类用法的最好方式. Example类可以用来生 ...

随机推荐

  1. shell编程100列

    1.编写hello world脚本 #!/bin/bash# 编写hello world脚本 echo "Hello World!"2.通过位置变量创建 Linux 系统账户及密码 ...

  2. react native 导航器 Navigator 简单的例子

    最近学习react native 是在为全栈工程师而努力,看网上把react native说的各种好,忍不住学习了一把.总体感觉还可以,特别是可以开发android和ios这点非常厉害,刚开始入门需要 ...

  3. academy

    academy at/in school都行,academy一般用at. The word comes from the Academy in ancient Greece, which derive ...

  4. day16 Linux三剑客之awk

    day16 Linux三剑客之awk 1.什么是awk,主要作用是什么? 什么是awk,主要作用是什么? awk 主要用来处理文件,将文本按照指定的格式输出.其中包含变量,循环以及数组. 2.awk的 ...

  5. 转 android开发笔记之handler+Runnable的一个巧妙应用

    本文链接:https://blog.csdn.net/hfreeman2008/article/details/12118817 版权 1. 一个有趣Demo: (1)定义一个handler变量 pr ...

  6. Android 小知识

    1.判断sd卡是否存在 boolean sdCardExist = Environment.getExternalStorageState().equals(android.os.Environmen ...

  7. Mysql 常见报错和疑问汇总

    1.初始化数据库的时候报错 error while loading shared libraries: libstdc++.so.5: cannot open shared object file:  ...

  8. Linux 双网卡绑定及Bridge

    Linux 双网卡绑定及Bridge 阅读(5,202) 一:linux操作系统下双网卡绑定有七种模式.现在一般的企业都会使用双网卡接入,这样既能添加网络带宽,同时又能做相应的冗余,可以说是好处多多. ...

  9. my36_InnoDB关键特性之change buffer

    一.关于IOT:索引组织表 表在存储的时候按照主键排序进行存储,同时在主键上建立一棵树,这样就形成了一个索引组织表,一个表的存储方式以索引的方式来组织存储的. 所以,MySQL表一定要加上主键,通过主 ...

  10. SQL 父子表,显示表中每条记录所在层级

    1.sqlserer 中有一张父子关系表,表结构如下: CREATE TABLE [dbo].[testparent]( [ID] [int] IDENTITY(1,1) NOT NULL, [nam ...