bool WWidget::event(QEvent* e) { if (e->type() == QEvent::ToolTip) { updateTooltip(); } else if (isEnabled()) { switch(e->type()) { case QEvent::TouchBegin: case QEvent::TouchUpdate: case QEvent::TouchEnd: { QTouchEvent* touchEvent = dynamic_cast<QTouchEvent*>(e); if (touchEvent->deviceType() != QTouchEvent::TouchScreen) { break; } // fake a mouse event! QEvent::Type eventType = QEvent::None; switch (touchEvent->type()) { case QEvent::TouchBegin: eventType = QEvent::MouseButtonPress; if (touchIsRightButton()) { // touch is right click m_activeTouchButton = Qt::RightButton; } else { m_activeTouchButton = Qt::LeftButton; } break; case QEvent::TouchUpdate: eventType = QEvent::MouseMove; break; case QEvent::TouchEnd: eventType = QEvent::MouseButtonRelease; break; default: DEBUG_ASSERT(false); break; } const QTouchEvent::TouchPoint &touchPoint = touchEvent->touchPoints().first(); QMouseEvent mouseEvent(eventType, touchPoint.pos().toPoint(), touchPoint.screenPos().toPoint(), m_activeTouchButton, // Button that causes the event Qt::NoButton, // Not used, so no need to fake a proper value. touchEvent->modifiers()); return QWidget::event(&mouseEvent); } default: break; } } return QWidget::event(e); }
bool KisToolProxy::forwardEvent(ActionState state, KisTool::ToolAction action, QEvent *event, QEvent *originalEvent, QTabletEvent *lastTabletEvent, const QPoint &canvasOriginWorkaround) { bool retval = true; QTabletEvent *tabletEvent = dynamic_cast<QTabletEvent*>(event); QTouchEvent *touchEvent = dynamic_cast<QTouchEvent*>(event); QMouseEvent *mouseEvent = dynamic_cast<QMouseEvent*>(event); if (tabletEvent) { QPointF docPoint = tabletToDocument(tabletEvent->hiResGlobalPos(), canvasOriginWorkaround); tabletEvent->accept(); this->tabletEvent(tabletEvent, docPoint); forwardToTool(state, action, tabletEvent, docPoint); retval = tabletEvent->isAccepted(); } else if (touchEvent) { if (state == END && touchEvent->type() != QEvent::TouchEnd) { //Fake a touch end if we are "upgrading" a single-touch gesture to a multi-touch gesture. QTouchEvent fakeEvent(QEvent::TouchEnd, touchEvent->deviceType(), touchEvent->modifiers(), touchEvent->touchPointStates(), touchEvent->touchPoints()); this->touchEvent(&fakeEvent); } else { this->touchEvent(touchEvent); } } else if (mouseEvent) { if (lastTabletEvent) { QPointF docPoint = tabletToDocument(lastTabletEvent->hiResGlobalPos(), canvasOriginWorkaround); lastTabletEvent->accept(); this->tabletEvent(lastTabletEvent, docPoint); forwardToTool(state, action, lastTabletEvent, docPoint); retval = lastTabletEvent->isAccepted(); } else { QPointF docPoint = widgetToDocument(mouseEvent->posF()); mouseEvent->accept(); if (mouseEvent->type() == QEvent::MouseButtonPress) { mousePressEvent(mouseEvent, docPoint); } else if (mouseEvent->type() == QEvent::MouseButtonDblClick) { mouseDoubleClickEvent(mouseEvent, docPoint); } else if (mouseEvent->type() == QEvent::MouseButtonRelease) { mouseReleaseEvent(mouseEvent, docPoint); } else if (mouseEvent->type() == QEvent::MouseMove) { mouseMoveEvent(mouseEvent, docPoint); } forwardToTool(state, action, originalEvent, docPoint); retval = mouseEvent->isAccepted(); } } else if(event->type() == QEvent::KeyPress) { QKeyEvent* kevent = static_cast<QKeyEvent*>(event); keyPressEvent(kevent); } else if(event->type() == QEvent::KeyRelease) { QKeyEvent* kevent = static_cast<QKeyEvent*>(event); keyReleaseEvent(kevent); } return retval; }
bool QtCanvas::event(QEvent *event) { switch (event->type()) { case QEvent::TouchBegin: case QEvent::TouchUpdate: case QEvent::TouchEnd: { QTouchEvent* touchEvent = static_cast<QTouchEvent*>(event); QList<QTouchEvent::TouchPoint> touchPoints = touchEvent->touchPoints(); event->accept(); qint8 deviceType = touchEvent->deviceType(); std::deque<tgt::TouchPoint> tps; int states = 0; foreach (const QTouchEvent::TouchPoint &p, touchPoints) { int id = p.id(); tgt::vec2 pos(p.pos().x(), p.pos().y()); int state = p.state(); bool primary = p.isPrimary(); states = states | state; tgt::TouchPoint tp; tp.setId(id); tp.setPos(pos); tp.setState((tgt::TouchPoint::State)state); tp.setPrimary(primary); tps.push_back(tp); } tgt::TouchEvent * te = new tgt::TouchEvent(tgt::Event::MODIFIER_NONE, (tgt::TouchPoint::State)states, (tgt::TouchEvent::DeviceType)deviceType, tps); eventHandler_->broadcast(te); break; } default: return QGLWidget::event(event); }
bool QIGraphicsView::event(QEvent *pEvent) { /* Handle known event types: */ switch (pEvent->type()) { case QEvent::TouchBegin: { /* Parse the touch event: */ QTouchEvent *pTouchEvent = static_cast<QTouchEvent*>(pEvent); AssertPtrReturn(pTouchEvent, QGraphicsView::event(pEvent)); /* For touch-screen event we have something special: */ if (pTouchEvent->deviceType() == QTouchEvent::TouchScreen) { /* Remember where the scrolling was started: */ m_iVerticalScrollBarPosition = verticalScrollBar()->value(); /* Allow further touch events: */ pEvent->accept(); /* Mark event handled: */ return true; } break; } case QEvent::TouchUpdate: { /* Parse the touch-event: */ QTouchEvent *pTouchEvent = static_cast<QTouchEvent*>(pEvent); AssertPtrReturn(pTouchEvent, QGraphicsView::event(pEvent)); /* For touch-screen event we have something special: */ if (pTouchEvent->deviceType() == QTouchEvent::TouchScreen) { /* Determine vertical shift (inverted): */ const QTouchEvent::TouchPoint point = pTouchEvent->touchPoints().first(); const int iShift = (int)(point.startPos().y() - point.pos().y()); /* Calculate new scroll-bar value according calculated shift: */ int iNewScrollBarValue = m_iVerticalScrollBarPosition + iShift; /* Make sure new scroll-bar value is within the minimum/maximum bounds: */ iNewScrollBarValue = qMax(verticalScrollBar()->minimum(), iNewScrollBarValue); iNewScrollBarValue = qMin(verticalScrollBar()->maximum(), iNewScrollBarValue); /* Apply calculated scroll-bar shift finally: */ verticalScrollBar()->setValue(iNewScrollBarValue); /* Mark event handled: */ return true; } break; } case QEvent::TouchEnd: { /* Parse the touch event: */ QTouchEvent *pTouchEvent = static_cast<QTouchEvent*>(pEvent); AssertPtrReturn(pTouchEvent, QGraphicsView::event(pEvent)); /* For touch-screen event we have something special: */ if (pTouchEvent->deviceType() == QTouchEvent::TouchScreen) { /* Reset the scrolling start position: */ m_iVerticalScrollBarPosition = 0; /* Mark event handled: */ return true; } break; } default: break; } /* Call to base-class: */ return QGraphicsView::event(pEvent); }
bool MixxxApplication::notify(QObject* target, QEvent* event) { switch (event->type()) { case QEvent::TouchBegin: case QEvent::TouchUpdate: case QEvent::TouchEnd: { QTouchEvent* touchEvent = static_cast<QTouchEvent*>(event); QList<QTouchEvent::TouchPoint> touchPoints = touchEvent->touchPoints(); QEvent::Type eventType = QEvent::None; Qt::MouseButtons buttons = Qt::NoButton; QWidget* fakeMouseWidget = NULL; bool baseReturn; //qDebug() << "&" << touchEvent->type() << target; if (touchEvent->deviceType() != QTouchEvent::TouchScreen) { break; } switch (event->type()) { case QEvent::TouchBegin: // try to deliver as touch event baseReturn = QApplication::notify(target, event); if (dynamic_cast<MixxxMainWindow*>(touchEvent->widget())) { // the touchEvent has fallen trough to the MixxxMainWindow, because there // was no touch enabled widget found. // Now we resent this event and all following events for this touch point // as Mouse events. eventType = QEvent::MouseButtonPress; if (touchIsRightButton()) { // touch is right click m_activeTouchButton = Qt::RightButton; buttons = Qt::RightButton; } else { m_activeTouchButton = Qt::LeftButton; buttons = Qt::LeftButton; } m_fakeMouseSourcePointId = touchPoints.first().id(); m_fakeMouseWidget = dynamic_cast<QWidget*>(target); fakeMouseWidget = m_fakeMouseWidget; break; } return baseReturn; case QEvent::TouchUpdate: if (m_fakeMouseWidget) { eventType = QEvent::MouseMove; buttons = m_activeTouchButton; fakeMouseWidget = m_fakeMouseWidget; break; } return QApplication::notify(target, event); case QEvent::TouchEnd: if (m_fakeMouseWidget) { eventType = QEvent::MouseButtonRelease; m_fakeMouseSourcePointId = touchPoints.first().id(); fakeMouseWidget = m_fakeMouseWidget; m_fakeMouseWidget = NULL; break; } return QApplication::notify(target, event); default: return QApplication::notify(target, event); } for (int i = 0; i < touchPoints.count(); ++i) { const QTouchEvent::TouchPoint& touchPoint = touchPoints.at(i); if (touchPoint.id() == m_fakeMouseSourcePointId) { QMouseEvent mouseEvent(eventType, fakeMouseWidget->mapFromGlobal(touchPoint.screenPos().toPoint()), touchPoint.screenPos().toPoint(), m_activeTouchButton, // Button that causes the event buttons, touchEvent->modifiers()); //qDebug() << "#" << mouseEvent.type() << mouseEvent.button() << mouseEvent.buttons() << mouseEvent.pos() << mouseEvent.globalPos(); //if (m_fakeMouseWidget->focusPolicy() & Qt::ClickFocus) { // fakeMouseWidget->setFocus(); //} QApplication::notify(fakeMouseWidget, &mouseEvent); return true; } } //qDebug() << "return false"; return false; break; } case QEvent::MouseButtonRelease: { bool ret = QApplication::notify(target, event); if (m_fakeMouseWidget) { // It may happen the faked mouse event was grabbed by a non touch window. // eg.: if we have started to drag by touch. // In this case X11 generates a MouseButtonRelease instead of a TouchPointReleased Event. // QApplication still tracks the Touch point and prevent touch to other widgets // So we need to fake the Touch release event as well to clean up // QApplicationPrivate::widgetForTouchPointId and QApplicationPrivate::appCurrentTouchPoints; m_fakeMouseWidget = NULL; // Disable MouseButtonRelease fake QList<QTouchEvent::TouchPoint> touchPoints; QTouchEvent::TouchPoint tp; tp.setId(m_fakeMouseSourcePointId); tp.setState(Qt::TouchPointReleased); touchPoints.append(tp); qt_translateRawTouchEvent(NULL, QTouchEvent::TouchScreen, touchPoints); } return ret; } default: break; } // No touch event bool ret = QApplication::notify(target, event); return ret; }