[Marble-commits] branches/KDE/4.5/kdeedu/marble/src/lib

Torsten Rahn tackat at kde.org
Wed Aug 25 07:56:38 CEST 2010


SVN commit 1167631 by rahn:

Forward port of SVN commit 1167172 by nienhueser:

Replace the mng animation with an in-memory animation very similar to
the oxygen busy cursor (two white balls rotating around each other).
Provides a more consistent look and should fix missing animations where
mng support is not there (windows, maemo).

Tested a few times with various cases



 M  +0 -1      libmarble.qrc  
 M  +17 -8     routing/RoutingInputWidget.cpp  
 M  +6 -0      routing/RoutingInputWidget.h  
 M  +43 -6     routing/RoutingWidget.cpp  


--- branches/KDE/4.5/kdeedu/marble/src/lib/libmarble.qrc #1167630:1167631
@@ -3,7 +3,6 @@
     <file>../../data/bitmaps/routing_remove.png</file>
     <file>../../data/bitmaps/routing_pick.png</file>
     <file>../../data/bitmaps/routing_step.png</file>
-    <file>../../data/bitmaps/progress.mng</file>
     <file>../../data/bitmaps/cursor_bc.xpm</file>
     <file>../../data/bitmaps/cursor_bl.xpm</file>
     <file>../../data/bitmaps/cursor_br.xpm</file>
--- branches/KDE/4.5/kdeedu/marble/src/lib/routing/RoutingInputWidget.cpp #1167630:1167631
@@ -23,7 +23,6 @@
 #include <QtGui/QIcon>
 #include <QtGui/QLineEdit>
 #include <QtGui/QPushButton>
-#include <QtGui/QMovie>
 #include <QtNetwork/QNetworkAccessManager>
 #include <QtNetwork/QNetworkReply>
 #include <QtXml/QDomDocument>
@@ -46,8 +45,6 @@
 
     MarblePlacemarkModel *m_placemarkModel;
 
-    QMovie m_progress;
-
     QTimer m_progressTimer;
 
     RouteSkeleton *m_route;
@@ -60,6 +57,10 @@
 
     bool m_workOffline;
 
+    QVector<QIcon> m_progressAnimation;
+
+    int m_currentFrame;
+
     /** Constructor */
     RoutingInputWidgetPrivate( RouteSkeleton *skeleton, int index, QWidget *parent );
 
@@ -69,9 +70,9 @@
 
 RoutingInputWidgetPrivate::RoutingInputWidgetPrivate( RouteSkeleton *skeleton, int index, QWidget *parent ) :
         m_lineEdit( 0 ), m_runnerManager( new MarbleRunnerManager( parent ) ),
-        m_placemarkModel( 0 ), m_progress( ":/data/bitmaps/progress.mng" ),
-        m_route( skeleton ), m_index( index ), m_manager( new QNetworkAccessManager( parent ) ),
-        m_workOffline( false )
+        m_placemarkModel( 0 ), m_route( skeleton ), m_index( index ),
+        m_manager( new QNetworkAccessManager( parent ) ), m_workOffline( false ),
+        m_currentFrame( 0 )
 {
     m_stateButton = new QPushButton( parent );
     m_stateButton->setToolTip(QObject::tr( "Center Map here" ) );
@@ -218,6 +219,7 @@
     } else {
         d->m_pickButton->setVisible( false );
         d->m_stateButton->setVisible( true );
+        updateProgress();
         d->m_progressTimer.start();
         d->m_runnerManager->newText( text );
     }
@@ -252,10 +254,12 @@
 
 void RoutingInputWidget::updateProgress()
 {
-    d->m_progress.jumpToNextFrame();
-    QPixmap frame = d->m_progress.currentPixmap();
+    if ( !d->m_progressAnimation.isEmpty() ) {
+        d->m_currentFrame = ( d->m_currentFrame + 1 ) % d->m_progressAnimation.size();
+        QIcon frame = d->m_progressAnimation[d->m_currentFrame];
     d->m_stateButton->setIcon( frame );
 }
+}
 
 void RoutingInputWidget::finishSearch()
 {
@@ -339,6 +343,11 @@
     emit targetValidityChanged( false );
 }
 
+void RoutingInputWidget::setProgressAnimation( const QVector<QIcon> &animation )
+{
+    d->m_progressAnimation = animation;
+}
+
 } // namespace Marble
 
 #include "RoutingInputWidget.moc"
--- branches/KDE/4.5/kdeedu/marble/src/lib/routing/RoutingInputWidget.h #1167630:1167631
@@ -80,6 +80,12 @@
       */
     void clear();
 
+    /**
+      * Set the progress animation to use. Each icon in the vector is displayed
+      * sequentially to create the animation, the animation loops endlessly.
+      */
+    void setProgressAnimation( const QVector<QIcon> &animation );
+
 public Q_SLOTS:
     /**
       * Search for placemarks matching the current input text. Does nothing
--- branches/KDE/4.5/kdeedu/marble/src/lib/routing/RoutingWidget.cpp #1167630:1167631
@@ -27,7 +27,7 @@
 #include <QtCore/QTimer>
 #include <QtGui/QFileDialog>
 #include <QtGui/QSortFilterProxyModel>
-#include <QtGui/QMovie>
+#include <QtGui/QPainter>
 
 #include "ui_RoutingWidget.h"
 
@@ -59,10 +59,12 @@
 
     bool m_workOffline;
 
-    QMovie m_progress;
-
     QTimer m_progressTimer;
 
+    QVector<QIcon> m_progressAnimation;
+
+    int m_currentFrame;
+
     /** Constructor */
     RoutingWidgetPrivate();
 
@@ -81,14 +83,18 @@
       * a runner search result or the current route
       */
     void setActiveInput( RoutingInputWidget* widget );
+
+private:
+    void createProgressAnimation();
 };
 
 RoutingWidgetPrivate::RoutingWidgetPrivate() :
         m_widget( 0 ), m_routingManager( 0 ), m_routingLayer( 0 ),
         m_activeInput( 0 ), m_inputRequest( 0 ), m_routingProxyModel( 0 ),
         m_routeSkeleton( 0 ), m_zoomRouteAfterDownload( false ),
-        m_workOffline( false ), m_progress( ":/data/bitmaps/progress.mng" )
+        m_workOffline( false ), m_currentFrame( 0 )
 {
+    createProgressAnimation();
     m_progressTimer.setInterval( 100 );
 }
 
@@ -137,6 +143,33 @@
     m_routingLayer->synchronizeWith( m_routingProxyModel, m_ui.directionsListView->selectionModel() );
 }
 
+void RoutingWidgetPrivate::createProgressAnimation()
+{
+    // Size parameters
+    int const iconSize = 16;
+    qreal const h = iconSize / 2.0; // Half of the icon size
+    qreal const q = h / 2.0; // Quarter of the icon size
+    qreal const d = 7.5; // Circle diameter
+    qreal const r = d / 2.0; // Circle radius
+
+    // Canvas parameters
+    QImage canvas( iconSize, iconSize, QImage::Format_ARGB32 );
+    QPainter painter( &canvas );
+    painter.setRenderHint( QPainter::Antialiasing, true );
+    painter.setPen( QColor ( Qt::gray ) );
+    painter.setBrush( QColor( Qt::white ) );
+
+    // Create all frames
+    for( double t = 0.0; t < 2 * M_PI; t += M_PI / 8.0 ) {
+        canvas.fill( Qt::transparent );
+        QRectF firstCircle( h - r + q * cos( t ), h - r + q * sin( t ), d, d );
+        QRectF secondCircle( h - r + q * cos( t + M_PI ), h - r + q * sin( t + M_PI ), d, d );
+        painter.drawEllipse( firstCircle );
+        painter.drawEllipse( secondCircle );
+        m_progressAnimation.push_back( QIcon( QPixmap::fromImage( canvas ) ) );
+    }
+}
+
 RoutingWidget::RoutingWidget( MarbleWidget *marbleWidget, QWidget *parent ) :
         QWidget( parent ), d( new RoutingWidgetPrivate )
 {
@@ -323,6 +356,7 @@
 {
     if ( index >= 0 && index <= d->m_inputWidgets.size() ) {
         RoutingInputWidget *input = new RoutingInputWidget( d->m_routeSkeleton, index, this );
+        input->setProgressAnimation( d->m_progressAnimation );
         input->setWorkOffline( d->m_workOffline );
         d->m_inputWidgets.insert( index, input );
         connect( input, SIGNAL( searchFinished( RoutingInputWidget* ) ),
@@ -412,6 +446,7 @@
     d->m_routingLayer->setRouteDirty( state == RoutingManager::Downloading );
 
     if ( state == RoutingManager::Downloading ) {
+        updateProgress();
         d->m_progressTimer.start();
     } else {
         d->m_progressTimer.stop();
@@ -492,10 +527,12 @@
 
 void RoutingWidget::updateProgress()
 {
-    d->m_progress.jumpToNextFrame();
-    QPixmap frame = d->m_progress.currentPixmap();
+    if ( !d->m_progressAnimation.isEmpty() ) {
+        d->m_currentFrame = ( d->m_currentFrame + 1 ) % d->m_progressAnimation.size();
+        QIcon frame = d->m_progressAnimation[d->m_currentFrame];
     d->m_ui.searchButton->setIcon( frame );
 }
+}
 
 } // namespace Marble
 


More information about the Marble-commits mailing list