Qt 屏蔽Qwidget的默认键盘按键动作

//比如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按下,从子WidgetkeyPressEvent开始运行,如对应的key有这个event则响应event,响应完不再往后执行;如没有则检查父WidgetkeyPressEvent,一层层往外。这让我想到了js的事件冒泡

在画面中按上下键不能聚焦button是因为button的上下键有对应的keyPressEvent,所以就不运行画面的keyPressEvent,同样的,输入框能聚焦因为它自己没有上下键的keyPressEvent,所以运行画面的keyPressEvent

重写Buttonevent可以关闭具体键的keyPressEvent,一旦关闭系统认为没这个event自然就执行父Widgetevent了。

EventFilter与上面不同,它是过滤了某些事件,使某个控件不执行某个事件, 但那个控件本身是有那个事件的, 所以用了eventfilter之后button还是有自己的keyPressEvent的,当然也不会执行画面的keyPressEvent

结论:EventFilter的功能是控制是否执行某控件的某event,重写event方法是让控件本身有没有某个event两者互不影响。

 

你可能感兴趣的:(widget)