zoukankan      html  css  js  c++  java
  • 第十五篇 -- QListWidget与QToolButton(界面)

    效果图:

    这还只是一个界面,并没有实现相应功能。

    先看下这图的构成吧。

    工具栏的就是将Action拖上去,这部分前面已经介绍过了,那就看下面这部分的构图。

    1.左侧是一个工具箱(ToolBox)组件,可以右键insert page或者delete page实现分组的添加或删除。在属性编辑器可以设置常用属性的值。

    • currentIndex:当前分组的编号,第一个分组的编号是0,通过改变这个值,可以选择不同的分组页面。
    • currentItemText:当前分组的标题。
    • currentItemName:当前分组的对象名称
    • currentItemIcon:为当前分组设置一个图标,显示在文字标题的左侧。

    在第一个分组里防止几个QToolButton按钮,并设置为网格布局。注意不要使用水平布局,因为水平布局时组内的ToolButton按钮都是自动左对齐,而使用网格布局则是自动居中。如果碰到按钮大小的问题的话,可以设置按钮属性minimumsize中的Width和Height值。

    2. 右侧是一个多页(QTabWidget)组件。

    QTabWidget是一个多页的容器类组件。在窗体上放置一个QTabWidget组件,通过右键insert page或delete page等菜单项实现页面的添加或删除。在属性编辑器里可以设置一些常用属性的值。

    tabPosition:页标签的位置,东南西北四个方位中选择一个

    currentIndex:当前页的编号

    currentTabText:当前页的标题
    currentTabName:当前页的对象名称

    currentTabIcon:可以为当前页设置一个图标,显示在文字标题的左侧

    tabsCloseable:页面是否可以被关闭。若设置为True,则每个页面的标题栏上会出现一个关闭按钮,点击关闭按钮可以关闭页面。

    3. 使用QSplitter设计分割界面

    具有分割效果的典型界面就是Windows的资源管理器,QSplitter用于设计具有分割效果的界面,可以左右或上下分割。本示例主窗体工作区的两个主要组件是toolBox和tabWidget,希望这两个组件设计为左右分割的效果。同时选中这两个组件,右击选择Lay out->Lay Out Horizontally in Splitter,就可以为这两个组件创建一个水平分割的布局组件splitter。

    在QmyMainWindow的构造函数里使用下面一行语句就可以使splitter充满整个工作区:

    self.setCentralWidget(self.ui.splitter)

    4. QListWidget组件

    在第一页中,第一行是一个label标签,一个Line Edit控件,还有一个Check Box。第二行是四个QToolButton按钮,第三行就是一个QlistWidget组件。

    在窗体可视化设计时双击ListWidget组件,可以打开其列表项编辑器,在这个编辑器里可以增加、删除、上移、下移列表项,可以设置每个项的属性,包括文字内容、字体、文字对齐方式、背景色、前景色等。

    比较重要的是其flags属性(如图3-18所示),用于设置项的一些标志,以下这些标志是枚举类型Qt.ItemFlag的值的组合。

    • Selectable:项可被选择,对应枚举值Qt.ItemIsSelectable。
    • Editable:项可被编辑,对应枚举值Qt.ItemIsEditable。
    • DragEnabled:项可以被拖动,对应枚举值Qt.ItemIsDragEnabled。
    • DropEnabled:项可以接收拖放的项,对应枚举值Qt.ItemIsDropEnabled。
    • UserCheckable:项可以被复选,若为True,项前面出现一个CheckBox,对应枚举值Qt.ItemIsUserCheckable。
    • Enable:项被使能,对应枚举值Qt.ItemIsEnabled。
    • Tristate:允许Check的第三种状态,若为False,则只有checked和unchecked两种状态,对应枚举值Qt.ItemIsAutoTristate。

    QListWidget的列表项一般是在程序里动态创建。

    5. Action和槽

    ui_listwidget.py

    # -*- coding: utf-8 -*-
    
    # Form implementation generated from reading ui file 'ui_listwidget.ui'
    #
    # Created by: PyQt5 UI code generator 5.13.0
    #
    # WARNING! All changes made in this file will be lost!
    
    
    from PyQt5 import QtCore, QtGui, QtWidgets
    
    
    class Ui_MainWindow(object):
        def setupUi(self, MainWindow):
            MainWindow.setObjectName("MainWindow")
            MainWindow.resize(800, 483)
            self.centralwidget = QtWidgets.QWidget(MainWindow)
            self.centralwidget.setObjectName("centralwidget")
            self.splitter = QtWidgets.QSplitter(self.centralwidget)
            self.splitter.setGeometry(QtCore.QRect(10, 10, 781, 381))
            self.splitter.setOrientation(QtCore.Qt.Horizontal)
            self.splitter.setObjectName("splitter")
            self.toolBox = QtWidgets.QToolBox(self.splitter)
            self.toolBox.setMaximumSize(QtCore.QSize(16777215, 16777215))
            self.toolBox.setObjectName("toolBox")
            self.page = QtWidgets.QWidget()
            self.page.setGeometry(QtCore.QRect(0, 0, 152, 291))
            self.page.setObjectName("page")
            self.gridLayout = QtWidgets.QGridLayout(self.page)
            self.gridLayout.setObjectName("gridLayout")
            self.btnList_Ini = QtWidgets.QToolButton(self.page)
            self.btnList_Ini.setMinimumSize(QtCore.QSize(130, 30))
            self.btnList_Ini.setObjectName("btnList_Ini")
            self.gridLayout.addWidget(self.btnList_Ini, 0, 0, 1, 1)
            self.btnList_Clear = QtWidgets.QToolButton(self.page)
            self.btnList_Clear.setMinimumSize(QtCore.QSize(130, 30))
            self.btnList_Clear.setObjectName("btnList_Clear")
            self.gridLayout.addWidget(self.btnList_Clear, 1, 0, 1, 1)
            self.btnList_Insert = QtWidgets.QToolButton(self.page)
            self.btnList_Insert.setMinimumSize(QtCore.QSize(130, 30))
            self.btnList_Insert.setObjectName("btnList_Insert")
            self.gridLayout.addWidget(self.btnList_Insert, 2, 0, 1, 1)
            self.btnList_Append = QtWidgets.QToolButton(self.page)
            self.btnList_Append.setMinimumSize(QtCore.QSize(130, 30))
            self.btnList_Append.setObjectName("btnList_Append")
            self.gridLayout.addWidget(self.btnList_Append, 3, 0, 1, 1)
            self.btnList_Delete = QtWidgets.QToolButton(self.page)
            self.btnList_Delete.setMinimumSize(QtCore.QSize(130, 30))
            self.btnList_Delete.setObjectName("btnList_Delete")
            self.gridLayout.addWidget(self.btnList_Delete, 4, 0, 1, 1)
            icon = QtGui.QIcon()
            icon.addPixmap(QtGui.QPixmap("Image/icons/list.ico"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
            self.toolBox.addItem(self.page, icon, "")
            self.page_2 = QtWidgets.QWidget()
            self.page_2.setGeometry(QtCore.QRect(0, 0, 152, 291))
            self.page_2.setObjectName("page_2")
            icon1 = QtGui.QIcon()
            icon1.addPixmap(QtGui.QPixmap("Image/icons/tree.ico"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
            self.toolBox.addItem(self.page_2, icon1, "")
            self.page_3 = QtWidgets.QWidget()
            self.page_3.setObjectName("page_3")
            icon2 = QtGui.QIcon()
            icon2.addPixmap(QtGui.QPixmap("Image/icons/tabel.ico"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
            self.toolBox.addItem(self.page_3, icon2, "")
            self.tabWidget = QtWidgets.QTabWidget(self.splitter)
            self.tabWidget.setObjectName("tabWidget")
            self.tab = QtWidgets.QWidget()
            self.tab.setObjectName("tab")
            self.gridLayout_2 = QtWidgets.QGridLayout(self.tab)
            self.gridLayout_2.setObjectName("gridLayout_2")
            self.btnSel_None = QtWidgets.QToolButton(self.tab)
            self.btnSel_None.setObjectName("btnSel_None")
            self.gridLayout_2.addWidget(self.btnSel_None, 1, 3, 1, 1)
            self.checkBox = QtWidgets.QCheckBox(self.tab)
            font = QtGui.QFont()
            font.setPointSize(10)
            self.checkBox.setFont(font)
            self.checkBox.setObjectName("checkBox")
            self.gridLayout_2.addWidget(self.checkBox, 0, 6, 1, 1)
            self.listWidget = QtWidgets.QListWidget(self.tab)
            self.listWidget.setObjectName("listWidget")
            item = QtWidgets.QListWidgetItem()
            item.setFlags(QtCore.Qt.ItemIsSelectable|QtCore.Qt.ItemIsEditable|QtCore.Qt.ItemIsDragEnabled|QtCore.Qt.ItemIsUserCheckable|QtCore.Qt.ItemIsEnabled)
            self.listWidget.addItem(item)
            item = QtWidgets.QListWidgetItem()
            item.setFlags(QtCore.Qt.ItemIsSelectable|QtCore.Qt.ItemIsEditable|QtCore.Qt.ItemIsDragEnabled|QtCore.Qt.ItemIsUserCheckable|QtCore.Qt.ItemIsEnabled)
            self.listWidget.addItem(item)
            self.gridLayout_2.addWidget(self.listWidget, 2, 0, 1, 7)
            self.label = QtWidgets.QLabel(self.tab)
            font = QtGui.QFont()
            font.setPointSize(10)
            self.label.setFont(font)
            self.label.setObjectName("label")
            self.gridLayout_2.addWidget(self.label, 0, 0, 1, 1)
            self.lineEdit = QtWidgets.QLineEdit(self.tab)
            self.lineEdit.setObjectName("lineEdit")
            self.gridLayout_2.addWidget(self.lineEdit, 0, 1, 1, 5)
            self.btnSel_ALL = QtWidgets.QToolButton(self.tab)
            self.btnSel_ALL.setObjectName("btnSel_ALL")
            self.gridLayout_2.addWidget(self.btnSel_ALL, 1, 2, 1, 1)
            self.btnSel_Invs = QtWidgets.QToolButton(self.tab)
            self.btnSel_Invs.setObjectName("btnSel_Invs")
            self.gridLayout_2.addWidget(self.btnSel_Invs, 1, 4, 1, 1)
            self.btnSelectItem = QtWidgets.QToolButton(self.tab)
            self.btnSelectItem.setObjectName("btnSelectItem")
            self.gridLayout_2.addWidget(self.btnSelectItem, 1, 0, 1, 2)
            self.tabWidget.addTab(self.tab, "")
            self.tab_2 = QtWidgets.QWidget()
            self.tab_2.setObjectName("tab_2")
            self.tabWidget.addTab(self.tab_2, "")
            self.tab_3 = QtWidgets.QWidget()
            self.tab_3.setObjectName("tab_3")
            self.tabWidget.addTab(self.tab_3, "")
            MainWindow.setCentralWidget(self.centralwidget)
            self.menubar = QtWidgets.QMenuBar(MainWindow)
            self.menubar.setGeometry(QtCore.QRect(0, 0, 800, 21))
            self.menubar.setObjectName("menubar")
            MainWindow.setMenuBar(self.menubar)
            self.statusbar = QtWidgets.QStatusBar(MainWindow)
            self.statusbar.setObjectName("statusbar")
            MainWindow.setStatusBar(self.statusbar)
            self.toolBar = QtWidgets.QToolBar(MainWindow)
            self.toolBar.setToolButtonStyle(QtCore.Qt.ToolButtonTextUnderIcon)
            self.toolBar.setObjectName("toolBar")
            MainWindow.addToolBar(QtCore.Qt.TopToolBarArea, self.toolBar)
            self.actList_Ini = QtWidgets.QAction(MainWindow)
            icon3 = QtGui.QIcon()
            icon3.addPixmap(QtGui.QPixmap("Image/icons/initial.jpg"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
            self.actList_Ini.setIcon(icon3)
            self.actList_Ini.setObjectName("actList_Ini")
            self.actList_Clear = QtWidgets.QAction(MainWindow)
            icon4 = QtGui.QIcon()
            icon4.addPixmap(QtGui.QPixmap("Image/icons/clear.jpg"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
            self.actList_Clear.setIcon(icon4)
            self.actList_Clear.setObjectName("actList_Clear")
            self.actList_Insert = QtWidgets.QAction(MainWindow)
            icon5 = QtGui.QIcon()
            icon5.addPixmap(QtGui.QPixmap("Image/icons/insert.jpg"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
            self.actList_Insert.setIcon(icon5)
            self.actList_Insert.setObjectName("actList_Insert")
            self.actList_Append = QtWidgets.QAction(MainWindow)
            icon6 = QtGui.QIcon()
            icon6.addPixmap(QtGui.QPixmap("Image/icons/append.jpg"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
            self.actList_Append.setIcon(icon6)
            self.actList_Append.setObjectName("actList_Append")
            self.actList_Delete = QtWidgets.QAction(MainWindow)
            icon7 = QtGui.QIcon()
            icon7.addPixmap(QtGui.QPixmap("Image/icons/delete.jpg"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
            self.actList_Delete.setIcon(icon7)
            self.actList_Delete.setObjectName("actList_Delete")
            self.actSel_ALL = QtWidgets.QAction(MainWindow)
            self.actSel_ALL.setObjectName("actSel_ALL")
            self.actSel_None = QtWidgets.QAction(MainWindow)
            self.actSel_None.setObjectName("actSel_None")
            self.actSel_Invs = QtWidgets.QAction(MainWindow)
            self.actSel_Invs.setObjectName("actSel_Invs")
            self.actQuit = QtWidgets.QAction(MainWindow)
            icon8 = QtGui.QIcon()
            icon8.addPixmap(QtGui.QPixmap("Image/icons/quit.jpg"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
            self.actQuit.setIcon(icon8)
            self.actQuit.setObjectName("actQuit")
            self.actSelPopMenu = QtWidgets.QAction(MainWindow)
            icon9 = QtGui.QIcon()
            icon9.addPixmap(QtGui.QPixmap("Image/icons/popmenu.jpg"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
            self.actSelPopMenu.setIcon(icon9)
            self.actSelPopMenu.setObjectName("actSelPopMenu")
            self.toolBar.addAction(self.actList_Ini)
            self.toolBar.addAction(self.actList_Clear)
            self.toolBar.addAction(self.actList_Insert)
            self.toolBar.addAction(self.actList_Append)
            self.toolBar.addAction(self.actList_Delete)
    
            self.retranslateUi(MainWindow)
            self.toolBox.setCurrentIndex(0)
            self.tabWidget.setCurrentIndex(0)
            self.actSelPopMenu.triggered.connect(self.actSel_Invs.trigger)
            self.actQuit.triggered.connect(MainWindow.close)
            QtCore.QMetaObject.connectSlotsByName(MainWindow)
    
        def retranslateUi(self, MainWindow):
            _translate = QtCore.QCoreApplication.translate
            MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))
            self.btnList_Ini.setText(_translate("MainWindow", "btnList_Ini"))
            self.btnList_Clear.setText(_translate("MainWindow", "btnList_Clear"))
            self.btnList_Insert.setText(_translate("MainWindow", "btnList_Insert"))
            self.btnList_Append.setText(_translate("MainWindow", "btnList_Append"))
            self.btnList_Delete.setText(_translate("MainWindow", "btnList_Delete"))
            self.toolBox.setItemText(self.toolBox.indexOf(self.page), _translate("MainWindow", "QListWidget操作"))
            self.toolBox.setItemText(self.toolBox.indexOf(self.page_2), _translate("MainWindow", "QTreeWidget"))
            self.toolBox.setItemText(self.toolBox.indexOf(self.page_3), _translate("MainWindow", "QTabelWidget"))
            self.btnSel_None.setText(_translate("MainWindow", "btnSel_None"))
            self.checkBox.setText(_translate("MainWindow", "可编辑"))
            __sortingEnabled = self.listWidget.isSortingEnabled()
            self.listWidget.setSortingEnabled(False)
            item = self.listWidget.item(0)
            item.setText(_translate("MainWindow", "New Item"))
            item = self.listWidget.item(1)
            item.setText(_translate("MainWindow", "New Item1"))
            self.listWidget.setSortingEnabled(__sortingEnabled)
            self.label.setText(_translate("MainWindow", "当前项变化"))
            self.btnSel_ALL.setText(_translate("MainWindow", "btnSel_ALL"))
            self.btnSel_Invs.setText(_translate("MainWindow", "btnSel_Invs"))
            self.btnSelectItem.setText(_translate("MainWindow", "btnSelectItem"))
            self.tabWidget.setTabText(self.tabWidget.indexOf(self.tab), _translate("MainWindow", "QListWidget"))
            self.tabWidget.setTabText(self.tabWidget.indexOf(self.tab_2), _translate("MainWindow", "QTreeWidget"))
            self.tabWidget.setTabText(self.tabWidget.indexOf(self.tab_3), _translate("MainWindow", "QTableWidget"))
            self.toolBar.setWindowTitle(_translate("MainWindow", "toolBar"))
            self.actList_Ini.setText(_translate("MainWindow", "初始化列表"))
            self.actList_Ini.setToolTip(_translate("MainWindow", "初始化列表"))
            self.actList_Ini.setShortcut(_translate("MainWindow", "Ctrl+I"))
            self.actList_Clear.setText(_translate("MainWindow", "清除列表"))
            self.actList_Clear.setToolTip(_translate("MainWindow", "清除列表"))
            self.actList_Insert.setText(_translate("MainWindow", "插入项"))
            self.actList_Insert.setToolTip(_translate("MainWindow", "插入项"))
            self.actList_Insert.setShortcut(_translate("MainWindow", "Ctrl+S"))
            self.actList_Append.setText(_translate("MainWindow", "添加项"))
            self.actList_Append.setToolTip(_translate("MainWindow", "添加项"))
            self.actList_Append.setShortcut(_translate("MainWindow", "Ctrl+A"))
            self.actList_Delete.setText(_translate("MainWindow", "删除当前项"))
            self.actList_Delete.setToolTip(_translate("MainWindow", "删除当前项"))
            self.actList_Delete.setShortcut(_translate("MainWindow", "Del"))
            self.actSel_ALL.setText(_translate("MainWindow", "全选"))
            self.actSel_ALL.setToolTip(_translate("MainWindow", "全选"))
            self.actSel_None.setText(_translate("MainWindow", "全不选"))
            self.actSel_None.setToolTip(_translate("MainWindow", "全不选"))
            self.actSel_Invs.setText(_translate("MainWindow", "反选"))
            self.actSel_Invs.setToolTip(_translate("MainWindow", "反选"))
            self.actQuit.setText(_translate("MainWindow", "退出"))
            self.actQuit.setToolTip(_translate("MainWindow", "退出程序"))
            self.actSelPopMenu.setText(_translate("MainWindow", "项选择"))
            self.actSelPopMenu.setToolTip(_translate("MainWindow", "项选择"))
    View Code

    myMainWindow_listwidget.py

    #!/usr/bin/env python
    # _*_ coding: UTF-8 _*_
    """=================================================
    @Project -> File    : Operate-system -> myMainWindow_listwidget.py
    @IDE     : PyCharm
    @Author  : zihan
    @Date    : 2020/4/14 9:24
    @Desc    :
    ================================================="""
    
    import sys
    from PyQt5.QtWidgets import QApplication, QMainWindow, QListWidgetItem, QMenu, QToolButton
    from PyQt5.QtGui import QIcon, QCursor
    from PyQt5.QtCore import pyqtSlot, Qt
    from ui_listwidget import Ui_MainWindow
    
    
    class QmyMainWindow(QMainWindow):
        def __init__(self, parent=None):
            super().__init__(parent)
            self.ui = Ui_MainWindow()
            self.ui.setupUi(self)
    
            self.setCentralWidget(self.ui.splitter)  # 使splitter充满整个工作区
            self.__set_actions_for_button()  # ToolButton关联Action
            self.__create_selection_pop_menu()
    
        # ToolButton关联Action
        def __set_actions_for_button(self):
            self.ui.btnList_Ini.setDefaultAction(self.ui.actList_Ini)
            self.ui.btnList_Clear.setDefaultAction(self.ui.actList_Clear)
    
            self.ui.btnList_Insert.setDefaultAction(self.ui.actList_Insert)
            self.ui.btnList_Append.setDefaultAction(self.ui.actList_Append)
            self.ui.btnList_Delete.setDefaultAction(self.ui.actList_Delete)
    
            self.ui.btnSel_ALL.setDefaultAction(self.ui.actSel_ALL)
            self.ui.btnSel_None.setDefaultAction(self.ui.actSel_None)
            self.ui.btnSel_Invs.setDefaultAction(self.ui.actSel_Invs)
    
            self.ui.btnList_Ini.setToolButtonStyle(Qt.ToolButtonTextBesideIcon)
            self.ui.btnList_Clear.setToolButtonStyle(Qt.ToolButtonTextBesideIcon)
            self.ui.btnList_Insert.setToolButtonStyle(Qt.ToolButtonTextBesideIcon)
            self.ui.btnList_Append.setToolButtonStyle(Qt.ToolButtonTextBesideIcon)
            self.ui.btnList_Delete.setToolButtonStyle(Qt.ToolButtonTextBesideIcon)
    
        # 创建ToolButton按钮的下拉菜单
        def __create_selection_pop_menu(self):
            menuSelection = QMenu(self)  # 下拉菜单
            menuSelection.addAction(self.ui.actSel_ALL)
            menuSelection.addAction(self.ui.actSel_None)
            menuSelection.addAction(self.ui.actSel_Invs)
    
            # listWidget上方的btnSelectItem按钮
            self.ui.btnSelectItem.setPopupMode(QToolButton.MenuButtonPopup)
            self.ui.btnSelectItem.setToolButtonStyle(Qt.ToolButtonTextBesideIcon)
            self.ui.btnSelectItem.setDefaultAction(self.ui.actSelPopMenu)
            self.ui.btnSelectItem.setMenu(menuSelection)  # 设置下拉菜单
    
            # 工具栏上的下拉式菜单按钮
            toolBtn = QToolButton(self)
            toolBtn.setPopupMode(QToolButton.InstantPopup)
            toolBtn.setDefaultAction(self.ui.actSelPopMenu)
            toolBtn.setToolButtonStyle(Qt.ToolButtonTextUnderIcon)
            toolBtn.setMenu(menuSelection)  # 设置下拉菜单
            self.ui.toolBar.addWidget(toolBtn)
    
            # 工具栏添加分隔条和"退出"按钮
            self.ui.toolBar.addSeparator()
            self.ui.toolBar.addAction(self.ui.actQuit)
    
    
    if __name__ == "__main__":
        app = QApplication(sys.argv)  # 创建app,用QApplication类
        form = QmyMainWindow()
        form.show()
        sys.exit(app.exec_())
    View Code

    ok.

  • 相关阅读:
    呈现系统-组件间的通信方式(7)
    web项目中图标的前端处理方案
    ADO--数据访问技术
    canvas--绘制路径
    canvas--改变颜色
    canvas-在画布中画两个方块(一个空心一个实体)
    canvas--画布《第一步》
    拼图游戏【简单】
    判断字符串是否为空--string.Empty、string=""、s.length==0
    判断Char是否为数字
  • 原文地址:https://www.cnblogs.com/smart-zihan/p/12698968.html
Copyright © 2011-2022 走看看