安裝事件過濾器
『壹』 qt4 tableWidget 怎麼給每個單元格加上時間過濾器installEventFilter分數沒用我送幾個Q幣好了
Qt的事件模型一個強大的功能是一個QObject對象能夠監視發送其他QObject對象的事件,在事件到達之前對其進行處理。
假設我們有一個CustomerInfoDialog控制項,由一些QLineEdit控制項組成。我們希望使用Space鍵得到下一個QLineEdit的輸入焦點。一個最直接的方法是繼承QLineEdit重寫keyPressEvent()函數,當點擊了Space鍵時,調用focusNextChild():
void MyLineEdit::keyPressEvent(QKeyEvent *event)
{
if (event->key() == Qt::Key_Space) {
focusNextChild();
} else {
QLineEdit::keyPressEvent(event);
}
}
這個方法有一個最大的缺點:如果我們在窗體中使用了很多不同類型的控制項(QComboBox,QSpinBox等等),我們也要繼承這些控制項,重寫它們的keyPressEvent()。一個更好的解決方法是讓CustomerInfoDialog監視其子控制項的鍵盤事件,在監視代碼處實現以上功能。這就是事件過濾的方法。實現一個事件過濾包括兩個步驟:
1. 在目標對象上調用installEventFilter(),注冊監視對象。
2. 在監視對象的eventFilter()函數中處理目標對象的事件。
注冊監視對象的位置是在CustomerInfoDialog的構造函數中:
CustomerInfoDialog::CustomerInfoDialog(QWidget *parent)
: QDialog(parent)
{
...
firstNameEdit->installEventFilter(this);
lastNameEdit->installEventFilter(this);
cityEdit->installEventFilter(this);
phoneNumberEdit->installEventFilter(this);
}
事件過濾器注冊後,發送到firstNameEdit,lastNameEdit,cityEdit,phoneNumberEdit控制項的事件首先到達CustomerInfoDialog::eventFilter()函數,然後在到達最終的目的地。
下面是eventFilter()函數的代碼:
bool CustomerInfoDialog::eventFilter(QObject *target, QEvent *event)
{
if (target == firstNameEdit || target == lastNameEdit
|| target == cityEdit || target == phoneNumberEdit) {
if (event->type() == QEvent::KeyPress) {
QKeyEvent *keyEvent = static_cast(event);
if (keyEvent->key() == Qt::Key_Space) {
focusNextChild();
return true;
}
}
}
return QDialog::eventFilter(target, event);
}
首先,我們看是目標控制項是否為QLineEdit,如果事件為鍵盤事件,把QEvent轉換為QKeyEvent,確定被敲擊的鍵。如果為Space鍵,調用focusNextChild(),把焦點交給下一個控制項,返回true通知Qt已經處理了這個事件,如果返回false,Qt將會把事件傳遞給目標控制項,把一個空格字元插入到QLineEdit中。
如果目標控制項不是QLineEdit,或者事件不是Space敲擊事件,把控制權交給基類QDialog的eventFilter()。目標控制項也可以是基類QDialog正在監視的控制項。(在Qt4.1中,QDialog沒有監視的控制項,但是Qt的其他控制項類,如QScrollArea,監視一些它們的子控制項)
Qt的事件處理有5中級別:
1. 重寫控制項的事件處理函數:如重寫keyPressEvent(),mousePressEvent()和paintEvent(),這是最常用的事件處理方法,我們已經看到過很多這樣的例子了。
2. 重寫QObject::event(),在事件到達事件處理函數時處理它。在需要改變Tab鍵的慣用法時這樣做。也可以處理那些沒有特定事件處理函數的比較少見的事件類型(例如,QEvent::HoverEnter)。我們重寫event()時,必須要調用基類的event(),由基類處理我們不需要處理的那些情況。
3. 給QObject對象安裝事件過濾器:對象用installEventFilter()後,所有達到目標控制項的事件都首先到達監視對象的eventFilter()函數。如果一個對象有多個事件過濾器,過濾器按順序激活,先到達最近安裝的監視對象,最後到達最先安裝的監視對象。
4. 給QApplication安裝事件過濾器,如果qApp(唯一的QApplication對象)安裝了事件過濾器,程序中所有對象的事件都要送到eventFilter()函數中。這個方法在調試的時候非常有用,在處理非活動狀態控制項的滑鼠事件時這個方法也很常用。
5. 繼承QApplication,重寫notify()。Qt調用QApplication::nofity()來發送事件。重寫這個函數是在其他事件過濾器處理事件前得到所有事件的唯一方法。通常事件過濾器是最有用的,因為在同一時間,可以有任意數量的事件過濾器,但是notify()函數只有一個。
許多事件類型,包括滑鼠,鍵盤事件,是能夠傳播的。如果事件在到達目標對象的途中或者由目標對象處理掉,事件處理的過程會重新開始,不同的是這時的目標對象是原目標對象的父控制項。這樣從父控制項再到父控制項,知道有控制項處理這個事件或者到達了最頂級的那個控制項。
圖7.2顯示了一個鍵盤事件在一個對話框中從子控制項到父控制項的傳播過程。當用戶敲擊一個鍵盤,時間首先發送到有焦點的控制項上(這個例子中是QCheckBox)。如果QCheckBox沒有處理這個事件,Qt把事件發送到QGroupBox中,如果仍然沒有處理,則最後發送到QDialog中。
『貳』 關於Qt的事件過濾器
monitoredObj是你要監控事件的對象filterObj是你要在里邊進行處理對象名
『叄』 安裝事件過濾器後控制項隱藏了怎麼回事
不銹鋼刷式過濾器種類有:全自動不銹鋼刷式過濾器,手搖不銹鋼刷式過濾器。其主要作用就是除掉水裡的懸浮物,降低水裡的懸浮物濃度,顆粒物,降低濁度,凈化水質,減少系統污垢、菌藻、銹蝕,凈化水質等。
不銹鋼刷式過濾器採用專利技術的內部機械結構,實現了真正意義上的高壓反沖洗功能,可輕松徹底地清除濾網截留的雜質,清洗無死角,通量無衰減,保障了過濾效率和長久的使用壽命。
不銹鋼刷式過濾器通過
『肆』 qt qlineedit怎樣使用事件過濾器
自己定義類繼承qlineedit, 實現eventFilter函數
『伍』 Qt怎樣使用事件過濾器
設置事件過濾器時用設置其viewport的事件過濾實例:#include #include QTextEdit* pEdit = new QTextEdit(this);pEdit->viewport()->installEventFilter(this);bool xxx::eventFilter(QObject* o, QEvent* e){ Q_UNUSED(o); if(e->type() == QEvent::MouseButtonPress){ QMouseEvent* pMe = static_cast(e); qDebug() pos(); } return false;}
『陸』 qt事件過濾器能不能統一處理所有按鈕對象的事件
當一個事件產生時,Qt 通過實例化一個 QEvent 的合適的子類來表示它,然後通過調用 event() 函數發送給 QObject 的實回例(或者它的子答類)。
event() 函數本身並不會處理事件,根據事件類型,它將調用相應的事件處理函數,並且返回事件被接受還是被忽略。
一些事件,比如 QMouseEvent 和 QKeyEvent,來自窗口系統;有的,比如 QTimerEvent,來自於其他事件源;另外一些則來自應用程序本身。
『柒』 qt事件過濾器中為什麼同一個鍵盤事件連續觸發多次
添加個標記int flag = 0。每次接收到事件時判斷是否falg == 1,如果是就不做任何處理直接返回,否則將flag設為1並進行處理。在接收到按鍵彈起消息時再將falg重置為0.
『捌』 Qt怎樣使用事件過濾器
設置事件過濾器時用設置其viewport的事件內過濾實例:容#include #include QTextEdit* pEdit = new QTextEdit(this);pEdit->viewport()->installEventFilter(this);bool xxx::eventFilter(QObject* o, QEvent* e){ Q_UNUSED(o); if(e->type() == QEvent::MouseButtonPress){ QMouseEvent* pMe = static_cast(e); qDebug() pos(); } return false;}