QT使用QTreeWidget控件制作多级折叠菜单

记录项目中实际用到的多级折叠菜单实现方式:项目代码简化版(亲测可用

开发环境:VS2015+QT5.9.1

多级菜单(左右共两个图标,中间为文字,左图标为固定静态图标,右图标为折叠/展开动态图标),格式如下:图片 菜单标题      图片

          系统配置         ∨

                     基本配置

                     时间配置

         记录管理           >

步骤如下(QTreeWidget布局自行实现):

(1)UI设计师中Qwidget中拖入QTreeWidget控件,将对象名称更改为treeMenuWidget

        然后,在代码中设置隐藏根节点,如下方式2选1

         ui->treeMenuWidget->header()->setVisible(false);      //FastConfForm.cpp文件中代码隐藏方式

Or

        treeMenuWidget->header()->setVisible(false); ui_FastConfForm.h中代码隐藏方式

(2)FastConfForm.cpp,在根节点下使用代码方式创建多个2级和3级节点(根为第1级节点)

/*FastConfForm.cpp*/

//构造函数中主代码
FastConfForm::FastConfForm(QWidget *parent):
    ui(new Ui::FastConfForm)
{
ui->treeMenuWidget->setColumnWidth(0, 143);				//设置TreeItem元素宽度
ui->treeMenuWidget->setLayoutDirection(Qt::RightToLeft);//对其方式设置:右对齐


//TreeItem右侧图标
QIcon icon;
icon.addPixmap(QPixmap(":/image/pic/tab/Blu_selected.png"), QIcon::Selected, QIcon::Off);
icon.addPixmap(QPixmap(":/image/pic/tab/Blu_nomrmal.png"), QIcon::Selected, QIcon::On);


//新增TreeMenu的二级子节点:配置管理
//QTreeWidgetItem *wItemSysConf = new QTreeWidgetItem(ui->treeMenuWidget,QStringList(QStringLiteral("系统配置")),0);
QTreeWidgetItem *wItemSysConf = new QTreeWidgetItem(ui->treeMenuWidget, nullptr, 0);
wItemSysConf->setIcon(0, icon);			//添加右侧图标
wItemSysConf->setTextAlignment(0, Qt::AlignRight);
QTreeWidgetItem *wItemSysConf_Base  = new QTreeWidgetItem(wItemSysConf, QStringList(QStringLiteral("基本配置")), 1);
QTreeWidgetItem *wItemSysConf_Time = new QTreeWidgetItem(wItemSysConf, QStringList(QStringLiteral("时间配置")), 2);
wItemSysConf->addChild(wItemSysConf_Base  );			//添加三级子节点
wItemSysConf->addChild(wItemSysConf_Time);			//添加三级子节点
wItemSysConf_Base->setTextAlignment(0, Qt::AlignHCenter);
wItemSysConf_Time->setTextAlignment(0, Qt::AlignHCenter);



//新增TreeMenu的二级子节点:记录管理
//QTreeWidgetItem *wItemRecordMgt = new QTreeWidgetItem(ui->treeMenuWidget, QStringList(QStringLiteral("记录管理")),3);
QTreeWidgetItem *wItemRecordMgt = new QTreeWidgetItem(ui->treeMenuWidget, nullptr, 3);
wItemParkMgt->setIcon(0, icon);				  //添加右侧图标
wItemParkMgt->setTextAlignment(0, Qt::AlignRight);


//添加槽函数【槽函数需要在.h文件中声明】
connect(ui->treeMenuWidget, SIGNAL(itemClicked(QTreeWidgetItem*, int)), this, SLOT(showSelectedWidget(QTreeWidgetItem*, int)));


    //设置2级菜单的左侧图标和文件
    setLeftIconAndText(":/image/pic/tab/Blu_nomrmal.png", QString(QStringLiteral("系统配置")), wItemSysConf );
    setLeftIconAndText(":/image/pic/tab/Blu_nomrmal.png", QString(QStringLiteral("记录管理")), wItemRecordMgt );

    //展开默认节点
    expandMenu2Item(wItemSysConf , wItemSysConf_Base  , true);
}


//设置TreeItem的左侧图标和文字
void FastConfForm::setLeftIconAndText(QString strIconPath, QString strText, QTreeWidgetItem *treeWItem2)
{
	QWidget *userStateIcons = new QWidget();
	QHBoxLayout *hLayout = new QHBoxLayout();

	QLabel *m_pLabel = new QLabel();
	QLabel *m_pLabelPic = new QLabel();
	m_pLabel->setFixedSize(98, 20);
	m_pLabel->setText(strText);
	m_pLabelPic->setFixedSize(20, 20);
    m_pLabelPic->setPixmap(QPixmap(strIconPath).scaled(m_pLabel->size(), Qt::IgnoreAspectRatio, Qt::SmoothTransformation));
	m_pLabelPic->setScaledContents(true);
    hLayout->addSpacing(0);
	hLayout->addStretch(0);
	hLayout->setContentsMargins(0, 0, 0, 0);
	hLayout->addWidget(m_pLabel);
    hLayout->addWidget(m_pLabelPic);
	userStateIcons->setLayout(hLayout);
	ui->treeMenuWidget->setItemWidget(treeWItem2, 0, userStateIcons);	//Item添加Widget窗口
}


//单击Tree节点处理(点击:展开/折叠)函数
void FastConfForm::showSelectedWidget(QTreeWidgetItem* item, int column)
{
    //添加调试打印 需要包含头文件《QDebug》 + 设为控制台输出("调试"-->选择“属性”-->选怎“连接器”-->选怎“系统”-->“子系统”中选择[控制台]),方便调试
	qDebug() << "==";
	curTreeMenu2Val = item->type(); //new QTreeWidgetItem()的第三个参数

    
	QTreeWidgetItem *parent = item->parent();   //获取父节点
	if (NULL != parent) //注意:最顶端项是没有父节点的(根节点隐藏: 二级节点也无父节点)
	{
		curTreeMenu3Val = parent->indexOfChild(item); //item在父项中的节点行号(从0开始)
	}
    else 
	{
        //展开当前二级节点
		QTreeWidgetItem *firstChild = item->child(0);
		expandMenu2Item(item, firstChild, true);
	}
}


//节点展开的处理函数
void FastConfForm::expandMenu2Item(QTreeWidgetItem* itemMenu2, QTreeWidgetItem* itemMenu3, bool bIsSelect)
{
	itemMenu2->isExpanded() ? itemMenu2->setExpanded(false) : itemMenu2->setExpanded(true);

	if (NULL != itemMenu3)
	{
		selectMenu3Item(itemMenu3, bIsSelect);
		if (true == bIsSelect)
		{
			itemMenu2->setSelected(false);
		}
	}
}


//节点是否被选中处理
void FastConfForm::selectMenu3Item(QTreeWidgetItem* item, bool bIsSelect)
{
	item->setSelected(bIsSelect);
}

(3)FastConfForm.h主要函数和变量的声明

class FastConfForm : public QWidget
{
    Q_OBJECT


public:
    explicit FastConfForm(QWidget *parent = 0);
    ~FastConfForm();
    void setLeftIconAndText(QString strIconPath, QString strText, QTreeWidgetItem *treeWItem2);
	void expandMenu2Item(QTreeWidgetItem* itemMenu2, QTreeWidgetItem* itemMenu3, bool bIsSelect);
	void selectMenu3Item(QTreeWidgetItem* item, bool bIsSelect);


//槽函数声明方式
private slots:
	void showSelectedWidget(QTreeWidgetItem *, int);


private:
    Ui::FastConfForm *ui;


	//菜单层级
	int curTreeMenu2Val = 0;
	int curTreeMenu3Val = 0;
};

(4)其他相关逻辑,请自行实现

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要设置QTreeWidget滚动条右键菜单的样式,可以使用QMenu和QAction来创建自定义右键菜单。 以下是一个示例代码,演示如何创建一个包含两个选项的右键菜单,用于在QTreeWidget中添加和删除节点: ```python from PyQt5.QtWidgets import QApplication, QMainWindow, QTreeWidget, QTreeWidgetItem, QMenu, QAction from PyQt5.QtCore import Qt class MainWindow(QMainWindow): def __init__(self): super().__init__() # 创建QTreeWidget和根节点 self.tree = QTreeWidget() self.tree.setHeaderLabels(['节点']) self.tree.setContextMenuPolicy(Qt.CustomContextMenu) self.tree.customContextMenuRequested.connect(self.show_menu) self.setCentralWidget(self.tree) root = QTreeWidgetItem(self.tree) root.setText(0, '根节点') def show_menu(self, position): # 创建右键菜单 menu = QMenu(self.tree) # 创建添加节点选项 add_action = QAction('添加节点', self.tree) add_action.triggered.connect(self.add_node) menu.addAction(add_action) # 创建删除节点选项 item = self.tree.itemAt(position) if item is not None: delete_action = QAction('删除节点', self.tree) delete_action.triggered.connect(self.delete_node) menu.addAction(delete_action) # 显示右键菜单 menu.exec_(self.tree.mapToGlobal(position)) def add_node(self): # 添加一个新节点 item = QTreeWidgetItem(self.tree.currentItem() or self.tree.invisibleRootItem()) item.setText(0, '新节点') def delete_node(self): # 删除当前选中的节点 item = self.tree.currentItem() if item is not None: parent = item.parent() or self.tree.invisibleRootItem() parent.removeChild(item) if __name__ == '__main__': app = QApplication([]) window = MainWindow() window.show() app.exec_() ``` 在上面的代码中,我们使用QTreeWidget的`customContextMenuRequested`信号来捕获右键单击事件,并在`show_menu`函数中创建了一个QMenu对象,包含了两个QAction对象,用于添加和删除节点。我们还使用了`mapToGlobal`函数将菜单显示在正确的位置。 要更改右键菜单的样式,可以使用QMenu和QAction的样式表属性。例如,要更改菜单的背景颜色和字体颜色,可以使用以下样式表: ```python menu.setStyleSheet('background-color: white; color: black;') ``` 同样地,要更改QAction的样式,可以使用以下样式表: ```python add_action.setStyleSheet('background-color: white; color: black;') delete_action.setStyleSheet('background-color: white; color: black;') ``` 这些样式表可以在`show_menu`函数中添加,以更改右键菜单的外观。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值