Merge branch 'master' of https://vcs.maemo.org/git/situare
[situare] / src / map / mapview.cpp
index ee68274..baaafe1 100644 (file)
@@ -3,6 +3,7 @@
    Copyright (C) 2010  Ixonos Plc. Authors:
 
        Sami Rämö - sami.ramo@ixonos.com
+       Pekka Nissinen - pekka.nissinen@ixonos.com
 
    Situare is free software; you can redistribute it and/or
    modify it under the terms of the GNU General Public License
 #include <QDebug>
 #include <QMouseEvent>
 
-#ifndef Q_WS_MAEMO_5
-    #include <QGLWidget>
-#endif // Q_WS_MAEMO_5
-
 #include "mapcommon.h"
 #include "mapview.h"
 
 MapView::MapView(QWidget *parent)
     : QGraphicsView(parent)
-    , m_timerID(NULL)
 {
-/**
-  * Use OpenGL for desktop to gain some performance in map view.
-  * OpenGL can't be used in scratchbox.
-  */
-#ifndef Q_WS_MAEMO_5
-    setViewport(new QGLWidget(QGLFormat(QGL::DoubleBuffer)));
-#endif // !Q_WS_MAEMO_5
+    qDebug() << __PRETTY_FUNCTION__;
 
     setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
     setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
+
+    m_zoomAnimation = new QPropertyAnimation(this, "viewScale", this);
+    connect(m_zoomAnimation, SIGNAL(finished()), this, SIGNAL(viewZoomFinished()));
 }
 
 void MapView::setZoomLevel(int zoomLevel)
 {
-    m_zoomTargetScale = pow(2, zoomLevel - MAX_MAP_ZOOM_LEVEL);
-    m_zoomScaleDelta = (m_zoomTargetScale - currentScale()) / (ZOOM_FPS * (ZOOM_TIME / 1000));
+    qDebug() << __PRETTY_FUNCTION__;
 
-    if (m_timerID)
-        killTimer(m_timerID);
+    if (m_zoomAnimation) {
+        m_zoomAnimation->stop();
+        m_zoomAnimation->setDuration(ZOOM_TIME);
+        m_zoomAnimation->setStartValue(viewScale());
+        m_zoomAnimation->setEndValue(pow(2, zoomLevel - MAX_MAP_ZOOM_LEVEL));
 
-    m_timerID = startTimer(1000/ZOOM_FPS);
+        m_zoomAnimation->start();
+    }
 }
 
-void MapView::timerEvent(QTimerEvent *event)
+qreal MapView::viewScale()
 {
-    if (event->timerId() == m_timerID) {
-        qreal scaleFactor = currentScale();
-
-//        qDebug() << __PRETTY_FUNCTION__
-//                 << "abs(m_zoomTargetScale - scaleFactor)" << fabs(m_zoomTargetScale - scaleFactor)
-//                 << "abs(m_zoomScaleDelta)" << fabs(m_zoomScaleDelta);
-
-        if (fabs(m_zoomTargetScale - scaleFactor) <= fabs(m_zoomScaleDelta)) {
-            scaleFactor = m_zoomTargetScale;
-            killTimer(event->timerId());
-        }
-        else {
-            scaleFactor += m_zoomScaleDelta;
-        }
-
-//        qDebug() << __PRETTY_FUNCTION__ << "currentScale:" << currentScale()
-//                                        << "m_zoomScaleDelta" << m_zoomScaleDelta
-//                                        << "scaleFactor:" << scaleFactor;
-
-        QTransform transform;
-        transform.scale(scaleFactor, scaleFactor);
-        setTransform(transform);
-       emit viewContentChanged(mapToScene(viewport()->x(), viewport()->y()).toPoint());
-    }
+    qDebug() << __PRETTY_FUNCTION__;
+
+    return transform().m11();
 }
 
-qreal MapView::currentScale()
+void MapView::setViewScale(qreal viewScale)
 {
-    QTransform currentTransform = transform();
-    return currentTransform.m11();
+    qDebug() << __PRETTY_FUNCTION__;
+
+    QTransform transform;
+    transform.scale(viewScale, viewScale);
+    setTransform(transform);
+    emit viewContentChanged(mapToScene(viewport()->x(), viewport()->y()).toPoint());
 }
 
 void MapView::mouseMoveEvent(QMouseEvent *event)
 {
     m_scenePosition += m_mousePosition - mapToScene(event->pos()).toPoint();
 
+    qDebug() << __PRETTY_FUNCTION__ << "m_scenePosition:" << m_scenePosition;
+
     emit viewScrolled(m_scenePosition);
-//    qDebug() << __PRETTY_FUNCTION__ << "m_scenePosition:" << m_scenePosition;
 
     m_mousePosition = mapToScene(event->pos()).toPoint();
     emit viewContentChanged(mapToScene(viewport()->x(), viewport()->y()).toPoint());
@@ -105,7 +85,9 @@ void MapView::mouseMoveEvent(QMouseEvent *event)
 
 void MapView::mousePressEvent(QMouseEvent *event)
 {
-    QGraphicsView::mousePressEvent(event);
+    qDebug() << __PRETTY_FUNCTION__;
+
+    QGraphicsView::mousePressEvent(event); // Temporary solution
 
     m_mousePosition = mapToScene(event->pos()).toPoint();
     m_scenePosition = mapToScene(width() / 2 - 1, height() / 2 - 1).toPoint();
@@ -113,13 +95,24 @@ void MapView::mousePressEvent(QMouseEvent *event)
 
 void MapView::centerToSceneCoordinates(QPoint sceneCoordinate)
 {
-//    qDebug() << __PRETTY_FUNCTION__ << "sceneCoordinate" << sceneCoordinate;
+    qDebug() << __PRETTY_FUNCTION__ << "sceneCoordinate" << sceneCoordinate;
+
     centerOn(sceneCoordinate);
 }
 
 void MapView::resizeEvent(QResizeEvent *event)
 {
-//    qDebug() << "Resize event: " << event->size();
+    qDebug() << __PRETTY_FUNCTION__ << "Resize:" << event->size();
+
     emit viewResized(event->size());
+    emit viewResizedNewSize(viewport()->width(), viewport()->height());
+    emit viewContentChanged(mapToScene(viewport()->x(), viewport()->y()).toPoint());
+}
+
+void MapView::showEvent(QShowEvent *event)
+{
+    qDebug() << __PRETTY_FUNCTION__;
+
+    QGraphicsView::showEvent(event);
     emit viewContentChanged(mapToScene(viewport()->x(), viewport()->y()).toPoint());
 }