Qtのコントロール - マウス

提供:MochiuWiki : SUSE, EC, PCB
2021年2月13日 (土) 19:48時点におけるWiki (トーク | 投稿記録)による版 (ページの作成:「== 概要 == Qtにおいて、マウスイベントを処理する手順を記載する。<br> <br><br> == サンプルコード == QWidgetまたはその派生クラス…」)
(差分) ← 古い版 | 最新版 (差分) | 新しい版 → (差分)
ナビゲーションに移動 検索に移動

概要

Qtにおいて、マウスイベントを処理する手順を記載する。


サンプルコード

QWidgetまたはその派生クラスにおいて、マウスイベントが発生する時、シグナルが発行されるのではなく、コールバックが呼び出される。

以下の例では、マウスイベントの各コールバックを示している。

mouseMoveEventイベントハンドラは、マウスのいずれかのボタンが押下した時に呼び出される。
このイベントは、mouseTrackingプロパティで制御されており、初期値はfalseである。

もし、マウスを移動させずにmouseMoveEventイベントハンドラを発生させる場合は、setMouseTracking(true)を呼び出す。

 // ボタンを押下した時のコールバック
 void MainWindow::mousePressEvent(QMouseEvent *pEvent)
 {
    if( pEvent->button() == Qt::LeftButton)
    //if(pEvent->buttons() & Qt::LeftButton)  // 複数のボタンを押下する場合
    {  // マウスの左ボタンを押下した場合
 
    }
    else if(pEvent->button() == Qt::RightButton)
    {  // マウスの右ボタンを押下した場合
    }
    else if(pEvent->button() == Qt::MiddleButton)
    {  // マウスの中ボタンを押下した場合
    }
 
    // マウスのボタンが押下された位置を取得する
    QPoint pntLastPos = pEvent->pos();
 }
 
 // マウスのいずれかのボタンを離した場合のコールバック
 void MainWindow::mosueReleaseEvent(QMouseEvent *pEvent)
 {
 }
 
 // マウスが移動した場合のコールバック
 void MainWindow::mouseMoveEvent(QMouseEvent *pEvent)
 {
 }
 
 // マウスホイールを回した場合(引数の型がQWheelEvent)
 void MainWindow::wheelEvent(QWheelEvent *pEvent)
 {
    // マウスホイールの前方 : 正の値
    // マウスホイールの後方 : 負の値
    // QWheelEventクラスのdeltaメソッドの値 : マウスホイールを回した角度の8倍の値
    // 標準的なマウスでは1ステップ15度のため、8 * 15 = 120で除算する
    double dSteps = (double)pEvent->delta() / 120.0;
 }