我的PySide项目中有许多旋转框,并且我想更改其行为,因此要求用户单击该字段以更改值,然后按Enter键。我想禁用旋转框的滚轮行为。我尝试设置焦点策略,但没有生效。
def light_label_event(self,text,checked):
print("this is the pressed button's label", text)
def populate_lights(self):
for light in self.lights:
light_label = QtWidgets.QSpinBox()
light_label.setFocusPolicy(QtCore.Qt.StrongFocus)
答案 0 :(得分:2)
您也可以只覆盖现有小部件的mouseEvent。例如,如果要忽略特定旋转框中的滚动事件,则可以使用不执行任何操作的lambda函数覆盖wheelEvent:
from PyQt5 import QtWidgets
box = QtWidgets.QSpinBox()
box.wheelEvent = lambda event: None
或者,您可以使用findChildren函数更改主窗口包含的特定类型(例如QSpinBox)的所有小部件的事件,如下所示:
from PyQt5 import QtCore, QtWidgets
main = QtWidgets.QMainWindow()
'''add some QSpinboxes to main'''
opts = QtCore.Qt.FindChildrenRecursively
spinboxes = main.findChildren(QtWidgets.QSpinBox, options=opts)
for box in spinboxes:
box.wheelEvent = lambda *event: None
从理论上讲,同样的原理可以应用于其他小部件类和事件,但是除了旋转框和滚轮事件之外,我还没有对其进行过测试。
答案 1 :(得分:1)
您必须创建一个自定义SpinBox并覆盖wheelEvent方法:
from PySide2 import QtWidgets
class SpinBox(QtWidgets.QSpinBox):
def wheelEvent(self, event):
event.ignore()
if __name__ == '__main__':
import sys
app = QtWidgets.QApplication(sys.argv)
w = SpinBox()
w.show()
sys.exit(app.exec_())
答案 2 :(得分:0)
也可以将IgnoreWheelEvent
类实现为EventFilter。
此类必须实现eventFilter(QObject, QEvent)
。然后,您可以进行spinBox.installEventFilter(IngoreWheelEvent)
。
我最近用C ++实现了它。因为我不想发布可能是错误的python代码,所以这里是我的C ++实现以了解一个想法。我已经在这里的构造函数中完成过installEventFilter
的操作,这使我在实现中节省了一行。
class IgnoreWheelEventFilter : public QObject
{
Q_OBJECT
public:
IgnoreWheelEventFilter(QObject *parent) : QObject(parent) {parent->installEventFilter(this);}
protected:
bool eventFilter(QObject *watched, QEvent *event) override
{
if (event->type() == QEvent::Wheel)
{
// Ignore the event
return true;
}
return QObject::eventFilter(watched, event);
}
};
//And later in the implementation...
IgnoreWheelEventFilter *ignoreFilter = new IgnoreWheelEventFilter(ui->spinBox);
// And if not done in the constructor:
// ui->spinBox->installEventFilter(ignoreFilter);