Map double click zoom reviewed.
authorJussi Laitinen <jupe@l3l7588.ixonos.local>
Wed, 23 Jun 2010 09:32:26 +0000 (12:32 +0300)
committerJussi Laitinen <jupe@l3l7588.ixonos.local>
Wed, 23 Jun 2010 09:32:26 +0000 (12:32 +0300)
Reviewed by: Marko Niemelä

src/map/mapcommon.h
src/map/mapview.cpp
src/map/mapview.h

index 374c850..f2f8b3d 100644 (file)
@@ -87,7 +87,7 @@ const int PRESS_MANHATTAN_LENGTH = 30;   ///< Friend/group item press manhattan
 */
 const int OWN_LOCATION_ICON_Z_LEVEL = FRIEND_LOCATION_ICON_Z_LEVEL + 1;
 
-const qreal ZOOM_TIME = 250; ///< Length of the zoom effect (ms)
+const qreal ZOOM_TIME = 350; ///< Length of the zoom effect (ms)
 
 const qreal MAX_LATITUDE = 85.05112877980659237802;  ///< Maximum latitude value
 const qreal MIN_LATITUDE = -MAX_LATITUDE; ///< Minimum latitude value
index c142f88..4bde6c3 100644 (file)
@@ -40,7 +40,8 @@ const int KINETIC_SCROLL_TIME_MS = 750;
 const qreal KINETIC_SPEED_TO_DISTANCE_FACTOR = 0.15 * sqrt(KINETIC_SCROLL_TIME_MS / MS_PER_S);
 
 MapView::MapView(QWidget *parent)
-    : QGraphicsView(parent)
+    : QGraphicsView(parent),
+      m_doubleTapZoomRunning(false)
 {
     qDebug() << __PRETTY_FUNCTION__;
 
@@ -50,14 +51,15 @@ MapView::MapView(QWidget *parent)
     m_zoomAnimation = new QPropertyAnimation(this, "viewScale", this);
     connect(m_zoomAnimation, SIGNAL(finished()),
         this, SIGNAL(viewZoomFinished()));
-
     setOptimizationFlag(QGraphicsView::DontAdjustForAntialiasing);
 
     m_scroller = &MapScroller::getInstance();
 
-    m_groupAnimation = new QParallelAnimationGroup(this);
-    m_groupAnimation->addAnimation(m_scroller);
-    m_groupAnimation->addAnimation(m_zoomAnimation);
+    m_scrollAndZoomAnimation = new QParallelAnimationGroup();
+    m_scrollAndZoomAnimation->addAnimation(m_scroller);
+    m_scrollAndZoomAnimation->addAnimation(m_zoomAnimation);
+    connect(m_scrollAndZoomAnimation, SIGNAL(finished()),
+            this, SLOT(doubleTapZoomFinished()));
 }
 
 void MapView::centerToSceneCoordinates(QPoint sceneCoordinate)
@@ -67,35 +69,48 @@ void MapView::centerToSceneCoordinates(QPoint sceneCoordinate)
     centerOn(sceneCoordinate);
 }
 
+void MapView::doubleTapZoomFinished()
+{
+    qDebug() << __PRETTY_FUNCTION__;
+
+    m_doubleTapZoomRunning = false;
+    emit zoomIn();
+}
+
 void MapView::mouseDoubleClickEvent(QMouseEvent *event)
 {
-    QPoint pressPos = mapToScene(event->pos()).toPoint();
-    QPoint centerPos = mapToScene(width() / 2 - 1, height() / 2 - 1).toPoint();
-    QPoint zoomPoint = centerPos - ((centerPos - pressPos) / 2);
+    qDebug() << __PRETTY_FUNCTION__;
 
-    m_groupAnimation->stop();
+    if (m_zoomLevel + 1 <= MAX_MAP_ZOOM_LEVEL) {
+        QPoint pressPosition = mapToScene(event->pos()).toPoint();
+        QPoint viewCenterPosition = mapToScene(width() / 2 - 1, height() / 2 - 1).toPoint();
+        QPoint zoomPosition = viewCenterPosition - ((viewCenterPosition - pressPosition) / 2);
 
-    m_scroller->setEasingCurve(QEasingCurve::OutCirc);
-    m_scroller->setDuration(KINETIC_SCROLL_TIME_MS);
-    m_scroller->setStartValue(m_scenePosition);
-    m_scroller->setEndValue(zoomPoint);
+        m_scrollAndZoomAnimation->stop();
+        m_doubleTapZoomRunning = true;
 
-    m_zoomAnimation->setEasingCurve(QEasingCurve::OutCirc);
-    m_zoomAnimation->setDuration(KINETIC_SCROLL_TIME_MS);
-    m_zoomAnimation->setStartValue(viewScale());
-    m_zoomAnimation->setEndValue(pow(2, ++m_zoomLevel - MAX_MAP_ZOOM_LEVEL));
+        m_scroller->setEasingCurve(QEasingCurve::Linear);
+        m_scroller->setDuration(ZOOM_TIME);
+        m_scroller->setStartValue(m_scenePosition);
+        m_scroller->setEndValue(zoomPosition);
 
+        m_zoomAnimation->setEasingCurve(QEasingCurve::InQuad);
+        m_zoomAnimation->setDuration(ZOOM_TIME);
+        m_zoomAnimation->setStartValue(viewScale());
+        m_zoomAnimation->setEndValue(pow(2, m_zoomLevel+1 - MAX_MAP_ZOOM_LEVEL));
 
-    m_groupAnimation->start();
+        m_scrollAndZoomAnimation->start();
+    }
 }
 
 void MapView::mouseMoveEvent(QMouseEvent *event)
 {
-    m_scenePosition += m_mouseLastScenePosition - mapToScene(event->pos()).toPoint();
+    qDebug() << __PRETTY_FUNCTION__;
 
-    qWarning() << __PRETTY_FUNCTION__;
+    if (m_doubleTapZoomRunning)
+        return;
 
-    qDebug() << __PRETTY_FUNCTION__ << "m_scenePosition:" << m_scenePosition;
+    m_scenePosition += m_mouseLastScenePosition - mapToScene(event->pos()).toPoint();
 
     if (m_index >= VALUES)
         m_index = 0;
@@ -113,9 +128,11 @@ void MapView::mouseMoveEvent(QMouseEvent *event)
 
 void MapView::mousePressEvent(QMouseEvent *event)
 {
-    qWarning() << __PRETTY_FUNCTION__;
     qDebug() << __PRETTY_FUNCTION__;
 
+    if (m_doubleTapZoomRunning)
+        return;
+
     m_time.start();
 
     m_scroller->stop();
@@ -137,6 +154,9 @@ void MapView::mouseReleaseEvent(QMouseEvent *event)
 {
     qDebug() << __PRETTY_FUNCTION__;
 
+    if (m_doubleTapZoomRunning)
+        return;
+
     int elapsed = m_time.elapsed();
 
     QGraphicsView::mouseReleaseEvent(event);
@@ -191,8 +211,9 @@ void MapView::setZoomLevel(int zoomLevel)
 
     m_zoomLevel = zoomLevel;
 
-    if (m_zoomAnimation && (m_zoomAnimation->state() == QAbstractAnimation::Stopped)) {
+    if (m_zoomAnimation) {
         m_zoomAnimation->stop();
+        m_zoomAnimation->setEasingCurve(QEasingCurve::InQuad);
         m_zoomAnimation->setDuration(ZOOM_TIME);
         m_zoomAnimation->setStartValue(viewScale());
         m_zoomAnimation->setEndValue(pow(2, zoomLevel - MAX_MAP_ZOOM_LEVEL));
@@ -207,3 +228,11 @@ qreal MapView::viewScale()
 
     return transform().m11();
 }
+
+MapView::~MapView()
+{
+    qDebug() << __PRETTY_FUNCTION__;
+
+    m_scrollAndZoomAnimation->removeAnimation(m_scroller);
+    delete m_scrollAndZoomAnimation;
+}
index e857c98..381b923 100644 (file)
@@ -58,6 +58,14 @@ public:
     */
     MapView(QWidget *parent = 0);
 
+    /**
+    * @brief Destructor.
+    *
+    * Takes MapScroller animation from double click zoom animation group and
+    * deletes animation group.
+    */
+    ~MapView();
+
 /*******************************************************************************
  * BASE CLASS INHERITED AND REIMPLEMENTED MEMBER FUNCTIONS
  ******************************************************************************/
@@ -133,6 +141,14 @@ public slots:
     */
     void setZoomLevel(int zoomLevel);
 
+private slots:
+    /**
+    * @brief Double tap zoom finished.
+    *
+    * Disables double tap zoom flag and emits zoomIn signal.
+    */
+    void doubleTapZoomFinished();
+
 private:
     /**
     * @brief Set new view scale
@@ -173,12 +189,17 @@ signals:
     */
     void viewZoomFinished();
 
+    /**
+    * @brief Signal for informing that double click zoom is finished
+    */
     void zoomIn();
 
 /*******************************************************************************
  * DATA MEMBERS
  ******************************************************************************/
 private:
+    bool m_doubleTapZoomRunning;         ///< Double tap zoom running flag
+
     int m_dragTime[VALUES];               ///< Table of mouse event durations
     int m_index;                          ///< Index of mouse event values tables
     int m_zoomLevel;                      ///< Current zoom level
@@ -188,14 +209,12 @@ private:
     QPoint m_mouseLastViewPosition;       ///< Previous mouse event position in the view
     QPoint m_scenePosition;               ///< New center position
 
+    QParallelAnimationGroup *m_scrollAndZoomAnimation;  ///< Double click zoom animation
     QPropertyAnimation *m_zoomAnimation;  ///< Zoom animation
-    QParallelAnimationGroup *m_groupAnimation;
 
     QTime m_time;                         ///< Elapsed times in mouse events
 
     MapScroller *m_scroller;              ///< Kinetic scroller
-
-    QParallelAnimationGroup *m_group;
 };
 
 #endif // MAPVIEW_H