//比如Tab键,默认会focus到下一个组件,
//重写event方法,然后在相应的按键那return false
//如果不行用return true
bool MyButton::event(QEvent *e){
if (e->type() == QEvent::KeyPress) {
QKeyEvent *ke = static_cast<QKeyEvent *>(e);
// QKeyEvent *ke = (QKeyEvent *)(e);
if (ke->key() == Qt::Key_Tab) {
return false;
}else
if(ke->key()==Qt::Key_Up){
return false;
}else if(ke->key()==Qt::Key_Down){
return false;
}
}
return QWidget::event(e);
}
//今天又发现了一个方法,不用重写基类的event,只要改每一个画面的eventFilter
//示例 屏蔽了button_signin 和textBox_name的各一个按键
bool MyWindow::eventFilter(QObject *obj, QEvent *event)
{
if (event->type() == QEvent::KeyPress) {
QKeyEvent *keyEvent = static_cast<QKeyEvent *>(event);
if (obj == button_signin) {
if(keyEvent->key() == Qt::Key_Down)
return true;
else return false;
}else if(obj == textBox_name){
if(keyEvent->key() == Qt::Key_Up)
return true;
else return false;
}else{
return false;
}
} else {
// standard event processing
return QObject::eventFilter(obj, event);
}
}
//再在MyWindow的构造函数中
textBox_name->installEventFilter(this);
button_signin->installEventFilter(this);
今天又总结了一下:
Keypressevent的运行原理:当一个key按下,从子Widget的keyPressEvent开始运行,如对应的key有这个event则响应event,响应完不再往后执行;如没有则检查父Widget的keyPressEvent,一层层往外。这让我想到了js的事件冒泡
在画面中按上下键不能聚焦button是因为button的上下键有对应的keyPressEvent,所以就不运行画面的keyPressEvent,同样的,输入框能聚焦因为它自己没有上下键的keyPressEvent,所以运行画面的keyPressEvent。
重写Button的event可以关闭具体键的keyPressEvent,一旦关闭系统认为没这个event自然就执行父Widget的event了。
EventFilter与上面不同,它是过滤了某些事件,使某个控件不执行某个事件, 但那个控件本身是有那个事件的, 所以用了eventfilter之后button还是有自己的keyPressEvent的,当然也不会执行画面的keyPressEvent。
结论:EventFilter的功能是控制是否执行某控件的某event,重写event方法是让控件本身有没有某个event。两者互不影响。
Qt屏蔽Qwidget默认键盘按键动作方法
本文探讨了Qt中键盘事件的处理机制,包括KeyPressEvent的运行原理,即事件从子Widget开始冒泡到父Widget。通过重写特定Widget的事件方法,可以关闭特定按键的响应,而EventFilter则用于过滤某些事件,防止控件执行这些事件。总结了EventFilter与重写event方法在控制键盘事件上的区别,强调两者并不冲突。
59

被折叠的 条评论
为什么被折叠?



