gpt4 book ai didi

python - 使每个选项卡宽度相同且可扩展

转载 作者:行者123 更新时间:2023-12-01 13:30:51 25 4
gpt4 key购买 nike

我正在尝试实现类似于浏览器中的选项卡的功能。所有选项卡都必须具有相同的宽度并且可以扩展,因此当有很多选项卡时,它们需要调整大小以适应窗口(就像 Chrome 或 Firefox 所做的那样)。


问题:

如果一个选项卡的文本比其他选项卡多,则该选项卡会更大。像这样:

enter image description here

如果我产生很多标签,它总是比其他标签大。

enter image description here


我尝试过的:

我尝试添加样式表来更改宽度,但如果我将宽度更改为特定数字,选项卡将是静态的,并且不会根据选项卡的数量调整大小以适应窗口。我还尝试调整最小/最大宽度,弄乱 QSizePolicy,但没有机会。

我查看了 QT5 for C++ 的文档并在谷歌上搜索了很多,但没有地方谈论这个或任何关于这个的选项。

也许我需要在 python 中做一些计算并作为参数添加到样式表,但不确定如何做。也许我缺少一个简单的选项。


我的代码:(这是完整的代码,如果需要可以复制粘贴测试)

import sys

from PyQt5.QtCore import Qt
from PyQt5.QtWidgets import QApplication, QWidget, QPushButton, QTabWidget,\
QVBoxLayout, QHBoxLayout, QSizePolicy


class Container(QWidget):
def __init__(self, text):
super(Container, self).__init__()

self.hbox = QHBoxLayout()
self.hbox.setSpacing(0)
self.hbox.setContentsMargins(0, 0, 0, 0)
self.setLayout(self.hbox)

self.button = QPushButton(text)
self.hbox.addWidget(self.button)


class CustomWidget (QWidget):
def __init__(self, parent=None):
super(CustomWidget, self).__init__(parent)

self.button = QPushButton("Add tab")
self.button.clicked.connect(self.buttonClicked)

self.tabs = QTabWidget()
self.tabs.setTabsClosable(True)
self.tabs.setMovable(True)
self.tabs.setDocumentMode(True)
self.tabs.setElideMode(Qt.ElideRight)
self.tabs.setUsesScrollButtons(True)
self.tabs.tabCloseRequested.connect(self.closeTab)

self.tabs.addTab(Container("Very big titleeeeeeeeee"),
"Very big titleeeeeeeeeeee")
self.tabs.addTab(Container("smalltext"), "smalltext")
self.tabs.addTab(Container("smalltext2"), "smalltext2")

vbox = QVBoxLayout()
vbox.addWidget(self.button)
vbox.addWidget(self.tabs)
self.setLayout(vbox)

self.resize(600, 600)

def closeTab(self, index):
tab = self.tabs.widget(index)
tab.deleteLater()
self.tabs.removeTab(index)

def buttonClicked(self):
self.tabs.addTab(Container("smalltext2"), "smalltext2")


app = QApplication([])

app.setStyleSheet("""
QTabBar::tab {
background: lightgray;
color: black;
border: 0;
/* min-width: 100px; */
max-width: 200px;
/* width: 150px; */
height: 20px;
padding: 5px;
}

QTabBar::tab:selected {
background: gray;
color: white;
}
""")

widget = CustomWidget()
widget.show()

sys.exit(app.exec_())

其他信息:

操作系统:Windows 10
Python版本:3.6.2
PyQt版本:5.9.1

最佳答案

要设置所有选项卡的宽度,我们必须覆盖 tabSizeHint()方法,在这种情况下,我们为所有选项卡返回相同的宽度。

class TabBar(QTabBar):
def tabSizeHint(self, index):
size = QTabBar.tabSizeHint(self, index)
w = int(self.width()/self.count())
return QSize(w, size.height())

在分配这个自定义选项卡栏后,我们使用 setTabBar() QTabWidget的方法.

self.tabs = QTabWidget()
self.tabs.setTabBar(TabBar())

输出:

enter image description here

例子可以在下面的link中找到

关于python - 使每个选项卡宽度相同且可扩展,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46007131/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com