Qt按下按钮显示按钮边框,再按一次取消按钮边框
时间: 2023-09-04 17:10:03 浏览: 123
您可以通过设置按钮的样式表来实现这个功能。首先,您需要在按钮被按下时设置按钮的边框,然后在按钮再次被按下时取消边框。
以下是一个示例代码:
```python
button_style = """
QPushButton {
border: 1px solid gray;
}
QPushButton:pressed {
border: 3px solid blue;
}
"""
button = QPushButton("My Button")
button.setStyleSheet(button_style)
```
在上面的代码中,我们定义了一个 `button_style` 样式表,其中 `QPushButton` 类型的按钮在普通状态下具有 1 像素灰色实线边框,而在被按下时具有 3 像素蓝色实线边框。然后,我们将这个样式表应用到按钮上。
当您按下按钮时,按钮的样式将自动更改,因为我们已经在样式表中定义了按钮被按下时的样式。再次按下按钮时,按钮将恢复到普通状态,并且不再具有蓝色边框。
希望这可以帮助您实现您的需求。
相关问题
python QT按钮边框
如果你想自定义 PyQt5 中按钮的边框,你可以使用 QSS(Qt Style Sheets)来实现。
以下是一个简单的例子,展示如何在 PyQt5 中设置按钮的边框:
```python
import sys
from PyQt5.QtWidgets import QApplication, QWidget, QPushButton
from PyQt5.QtCore import Qt
class Example(QWidget):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
# 创建一个按钮
btn = QPushButton('Button', self)
btn.move(50, 50)
# 设置按钮的边框样式
btn.setStyleSheet("border: 2px solid gray; border-radius: 10px; padding: 5px;")
self.setGeometry(300, 300, 300, 200)
self.setWindowTitle('Example')
self.show()
if __name__ == '__main__':
app = QApplication(sys.argv)
ex = Example()
sys.exit(app.exec_())
```
在上述代码中,我们使用了 `setStyleSheet()` 方法来设置按钮的边框样式。在这个例子中,我们设置了一个灰色的 2 像素边框,并在四个角设置了 10 像素的圆角。我们还通过 `padding` 属性设置了按钮的内边距,以使按钮中的文本与边框之间留有一定的空间。
你可以根据需要调整边框的样式和大小。
Qt 如何设置按钮边框为弧形
在 Qt 中,你可以通过设置按钮的样式表来将按钮边框设置为弧形。以下是一个示例代码:
```cpp
QPushButton* button = new QPushButton("Button");
QString styleSheet = "QPushButton {"
"border: 2px solid black;"
"border-radius: 10px;"
"padding: 5px;"
"}";
button->setStyleSheet(styleSheet);
```
在上述示例中,我们创建了一个名为 `button` 的 QPushButton 对象,并定义了一个样式表 `styleSheet`。在样式表中,我们使用 `border` 属性设置按钮的边框样式为 2px 的黑色实线边框。然后,使用 `border-radius` 属性设置按钮的边框为圆角,值为 10px。最后,使用 `padding` 属性设置按钮的内边距为 5px。
通过设置样式表,你可以自定义按钮的外观,包括边框形状、颜色和大小等。根据你的需求,可以进一步调整样式表中的属性来实现不同的效果。
阅读全文