PyQt5基本控件详解之QToolBar(二十五)

59 篇文章 355 订阅

QToolBar

前言

QToolBar控件是由文本按钮,图标或其他小控件按钮组成的可移动面板,通常位于菜单栏下方

QToolBar类中的常用方法

方法描述
addAction()添加具有文本或图标的工具按钮
addSeperator()分组显示工具按钮
addWidget()添加工具栏中按钮以外的控件
addToolBar()使用QMainWindow类的方法添加一个新的工具栏
setMovable()工具变得可移动
setOrientation()工具栏的方向可以设置为Qt.Horizontal或Qt.certical

每当单击工具栏中的按钮时,都将发射actionTriggered信号,另外,这个信号将关联的QAction对象的引用发到连接的槽函数上

实例:QToolBar的使用

import sys
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *

class ToolBarDemo(QMainWindow):
    def __init__(self,parent=None):
        super(ToolBarDemo, self).__init__(parent)
        #设置标题与初始大小
        self.setWindowTitle('toolbar例子')
        self.resize(300,200)

        #垂直布局
        layout=QVBoxLayout()

        #在工具栏区域添加文件工具栏
        tb=self.addToolBar('File')
        #添加图形按钮
        new=QAction(QIcon('images\\new.png'),'new',self)
        tb.addAction(new)
        open=QAction(QIcon('images\open.png'),'open',self)
        tb.addAction(open)
        save=QAction(QIcon('images\save.png'),'save',self)
        tb.addAction(save)

        #图形对象点击触发自定义槽函数
        tb.actionTriggered[QAction].connect(self.toolbtnpressed)

        self.setLayout(layout)

    def toolbtnpressed(self,a):
        #输出,点击地图性按钮
        print('pressed tool button is ',a.text())
if __name__ == '__main__':
    app=QApplication(sys.argv)
    demo=ToolBarDemo()
    demo.show()
    sys.exit(app.exec_())

运行程序,显示效果如图
这里写图片描述

代码分析

在这个例子中,首先调用addToolBar()方法在工具栏区域添加文件工具栏

  tb=self.addToolBar('File')

然后,添加具有文本标题的工具按钮,工具栏通常包含图形按钮,具有图标和名称的QAction对象将被添加到工具栏中

        new=QAction(QIcon('images\\new.png'),'new',self)
        tb.addAction(new)
        open=QAction(QIcon('images\open.png'),'open',self)
        tb.addAction(open)
        save=QAction(QIcon('images\save.png'),'save',self)
        tb.addAction(save)

最后,将actionTriggered信号连接到槽函数toolbtnpressed()

 tb.actionTriggered[QAction].connect(self.toolbtnpressed)

源码以及相关文件下载:https://download.csdn.net/download/jia666666/10597897

  • 2
    点赞
  • 0
    评论
  • 18
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

相关推荐
©️2020 CSDN 皮肤主题: 酷酷鲨 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值