[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