Qt事件處理(五)


  Qt處理事件的第五種方式:"繼承QApplication並重新實現notify()函數"。Qt調用QApplication來發送一個事件,重新實現notify()函數是在事件過濾器得到所有事件之前獲得它們的唯一方法。事件過濾器使用更為便利。因為可以同時有多個事件過濾器。而notify()函數只有一個。

  重新實現的QApplication類MyApplication的頭文件myapplication.h如下:

#ifndef MYAPPLICATION_H
#define MYAPPLICATION_H

#include <QApplication>
#include <QEvent>

class MyApplication : public QApplication
{
public:
    MyApplication(int & argc, char ** argv);

public:
    bool notify(QObject *receiver, QEvent *e);
};

#endif

  myapplication.cpp文件如下:

#include "myapplication.h"
#include <QMouseEvent>

MyApplication::MyApplication(int & argc, char ** argv) : QApplication(argc, argv)
{
}

 bool MyApplication::notify(QObject *receiver, QEvent *e)
 {
     //屏蔽MouseButtonPress、MouseButtonRelease和MouseMove事件
     if (e->type() == QEvent::MouseButtonPress || e->type() == QEvent::MouseButtonRelease || e->type() == QEvent::MouseMove)
     {
        return true;
     }
     return QApplication::notify(receiver, e);
 }

  mainwindow.h文件如下:

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QtGui/QMainWindow>
#include <QPushButton>
#include <QMouseEvent>

class MainWindow : public QMainWindow
{
    Q_OBJECT
    
public:
    MainWindow(QWidget *parent = 0);
    ~MainWindow();
protected:
    bool eventFilter(QObject *obj, QEvent *e);
private:
    QPushButton *button;
};

#endif

  mainwindow.cpp文件如下:

#include "mainwindow.h"

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
{
    button = new QPushButton;
    this->setCentralWidget(button);
}

MainWindow::~MainWindow()
{

}

bool MainWindow::eventFilter(QObject *obj, QEvent *e)
{
    if (obj == button)         //響應button的MouseButtonPress和MouseButtonRelease事件
    {
        if (e->type() == QEvent::MouseButtonPress)
        {
            QMouseEvent *event = static_cast<QMouseEvent*> (e);
            button->setText(QString("Press: %1, %2").arg(QString::number(event->x()), QString::number(event->y())));
            return true;
        }
        else if (e->type() == QEvent::MouseButtonRelease)
        {
            QMouseEvent *event = static_cast<QMouseEvent*> (e);
            button->setText(QString("Release: %1, %2").arg(QString::number(event->x()), QString::number(event->y())));
            return true;
        }
        else
        {
            return false;
        }
    }

    return QMainWindow::eventFilter(obj, e);
}

  main.cpp文件如下:

#include <QtGui/QApplication>
#include <QtCore/QTextCodec>
#include "mainwindow.h"
#include "myapplication.h"

int main(int argc, char *argv[])
{
    MyApplication a(argc, argv);
    QTextCodec::setCodecForTr(QTextCodec::codecForName("gb18030"));
    MainWindow mainwindow;
    a.installEventFilter(&mainwindow);  //為QApplication注冊過濾器
    mainwindow.setWindowTitle(QObject::tr("繼承QApplication並重新實現notify()函數"));
    mainwindow.resize(400, 200);
    mainwindow.show();

    return a.exec();
}

  運行程序,可以發現button不管是點擊、釋放還是拖動鼠標,都不會顯示任何文本。因為我們已經子類化QApplication,事件在到達QApplication的事件過濾器之前,會先到達QApplication的notify()函數,我們已經在子類化的MyApplication中屏蔽了MouseButtonPress、MouseButtonRelease事件。所以為MyApplication對象注冊的事件過濾器不起作用。程序運行界面為:

             

  Qt事件系列(完)! 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM