[Marble-commits] KDE/kdeedu/marble/src
Dennis Nienhüser
earthwings at gentoo.org
Sat Sep 11 13:57:23 CEST 2010
SVN commit 1174151 by nienhueser:
Extends the print dialog (X11 only, I'm afraid) with a new tab to configure Marble related print options: Toggle whether the map, the background (outer space), the legend, route summary and/or driving instructions are printed.
RB: 5254
FEATURE: 238137
FEATURE: 241551
FIXED-IN: 0.11.0 (KDE 4.6)
GUI:
M +204 -2 ControlView.cpp
M +6 -0 ControlView.h
M +3 -0 lib/CMakeLists.txt
M +4 -0 lib/MarbleLegendBrowser.cpp
M +27 -2 lib/MarbleModel.cpp
M +10 -0 lib/MarbleModel.h
M +0 -1 lib/MarbleWidget.cpp
A lib/PrintOptions.ui
A lib/PrintOptionsWidget.cpp [License: LGPL]
A lib/PrintOptionsWidget.h [License: LGPL]
M +5 -5 lib/routing/RoutingManager.cpp
--- trunk/KDE/kdeedu/marble/src/ControlView.cpp #1174150:1174151
@@ -19,13 +19,20 @@
#include <QtGui/QPrintPreviewDialog>
#include <QtGui/QPrinter>
#include <QtGui/QPainter>
+#include <QtGui/QTextDocument>
#include <QtCore/QPointer>
+#include <QtCore/QUrl>
#include "GeoSceneDocument.h"
#include "GeoSceneHead.h"
#include "MarbleWidget.h"
+#include "MarbleMap.h"
#include "MarbleModel.h"
#include "MapThemeManager.h"
+#include "PrintOptionsWidget.h"
+#include "routing/RoutingManager.h"
+#include "routing/RoutingModel.h"
+#include "routing/RouteRequest.h"
namespace Marble
{
@@ -159,10 +166,56 @@
void ControlView::printMapScreenShot( QPointer<QPrintDialog> printDialog)
{
#ifndef QT_NO_PRINTER
+ PrintOptionsWidget* printOptions = new PrintOptionsWidget( this );
+ bool const mapCoversViewport = m_marbleWidget->map()->mapCoversViewport();
+ printOptions->setBackgroundControlsEnabled( !mapCoversViewport );
+ bool hasLegend = m_marbleWidget->model()->legend() != 0;
+ printOptions->setLegendControlsEnabled( hasLegend );
+ bool hasRoute = marbleWidget()->model()->routingManager()->routingModel()->rowCount() > 0;
+ printOptions->setPrintRouteSummary( hasRoute );
+ printOptions->setPrintDrivingInstructions( hasRoute );
+ printOptions->setRouteControlsEnabled( hasRoute );
+ printDialog->setOptionTabs( QList<QWidget*>() << printOptions );
+
if (printDialog->exec() == QDialog::Accepted) {
- QPixmap mapPixmap = mapScreenShot();
- printPixmap( printDialog->printer(), mapPixmap );
+ QTextDocument document;
+ QString text = "<html><head><title>Marble Printout</title></head><body>";
+ QPalette const originalPalette = m_marbleWidget->palette();
+ bool const wasBackgroundVisible = m_marbleWidget->model()->backgroundVisible();
+ bool const hideBackground = !mapCoversViewport && !printOptions->printBackground();
+ if ( hideBackground ) {
+ // Temporarily remove the black background and layers painting on it
+ m_marbleWidget->model()->setBackgroundVisible( false );
+ m_marbleWidget->setPalette( QPalette ( Qt::white ) );
+ m_marbleWidget->repaint();
}
+
+ if ( printOptions->printMap() ) {
+ printMap( document, text, printDialog->printer() );
+ }
+
+ if ( printOptions->printLegend() ) {
+ printLegend( document, text );
+ }
+
+ if ( printOptions->printRouteSummary() ) {
+ printRouteSummary( document, text );
+ }
+
+ if ( printOptions->printDrivingInstructions() ) {
+ printDrivingInstructions( document, text );
+ }
+
+ text += "</body></html>";
+ document.setHtml( text );
+ document.print( printDialog->printer() );
+
+ if ( hideBackground ) {
+ m_marbleWidget->model()->setBackgroundVisible( wasBackgroundVisible );
+ m_marbleWidget->setPalette( originalPalette );
+ m_marbleWidget->repaint();
+ }
+ }
#endif
}
@@ -206,6 +259,155 @@
#endif
}
+void ControlView::printMap( QTextDocument &document, QString &text, QPrinter *printer )
+{
+#ifndef QT_NO_PRINTER
+ QPixmap image = mapScreenShot();
+
+ if ( m_marbleWidget->map()->mapCoversViewport() ) {
+ // Paint a black frame. Looks better.
+ QPainter painter(&image);
+ painter.setPen( Qt::black );
+ painter.drawRect( 0, 0, image.width() - 2, image.height() - 2 );
}
+ QString uri = "marble://screenshot.png";
+ document.addResource( QTextDocument::ImageResource, QUrl( uri ), QVariant( image) );
+ QString img = "<img src=\"%1\" width=\"%2\" align=\"center\">";
+ int width = qRound( printer->pageRect( QPrinter::Point ).width() );
+ text += img.arg( uri ).arg( width );
+#endif
+}
+
+void ControlView::printLegend( QTextDocument &document, QString &text )
+{
+#ifndef QT_NO_PRINTER
+ QTextDocument *legend = m_marbleWidget->model()->legend();
+ if ( legend ) {
+ legend->adjustSize();
+ QSize size = legend->size().toSize();
+ QSize imageSize = size + QSize( 4, 4 );
+ QImage image( imageSize, QImage::Format_ARGB32);
+ QPainter painter( &image );
+ painter.setRenderHint( QPainter::Antialiasing, true );
+ painter.drawRoundedRect( QRect( QPoint( 0, 0 ), size ), 5, 5 );
+ legend->drawContents( &painter );
+ document.addResource( QTextDocument::ImageResource, QUrl( "marble://legend.png" ), QVariant(image) );
+ QString img = "<p><img src=\"%1\" align=\"center\"></p>";
+ text += img.arg( "marble://legend.png" );
+ }
+#endif
+}
+
+void ControlView::printRouteSummary( QTextDocument &document, QString &text)
+{
+#ifndef QT_NO_PRINTER
+ RoutingModel* routingModel = m_marbleWidget->model()->routingManager()->routingModel();
+
+ if ( !routingModel ) {
+ return;
+ }
+
+ RouteRequest* routeRequest = m_marbleWidget->model()->routingManager()->routeRequest();
+ if ( routeRequest ) {
+ QString summary = "<h3>Route to %1: %2 %3</h3>";
+ QString destination;
+ if ( routeRequest->size() ) {
+ destination = routeRequest->name( routeRequest->size()-1 );
+ }
+
+ QString label = "<p>%1 %2</p>";
+ qreal distance = routingModel->totalDistance();
+ QString unit = distance > 1000 ? "km" : "m";
+ int precision = distance > 1000 ? 1 : 0;
+ if ( distance > 1000 ) {
+ distance /= 1000;
+ }
+ summary = summary.arg(destination).arg( distance, 0, 'f', precision ).arg( unit );
+ text += summary;
+
+ text += "<table cellpadding=\"2\">";
+ QString pixmapTemplate = "marble://viaPoint-%1.png";
+ for ( int i=0; i<routeRequest->size(); ++i ) {
+ text += "<tr><td>";
+ QPixmap pixmap = routeRequest->pixmap(i);
+ QString pixmapResource = pixmapTemplate.arg( i );
+ document.addResource(QTextDocument::ImageResource,
+ QUrl( pixmapResource ), QVariant( pixmap ) );
+ QString myimg = "<img src=\"%1\">";
+ text += myimg.arg( pixmapResource );
+ text += "</td><td>";
+ text += routeRequest->name( i );
+ text += "</td></tr>";
+ }
+ text += "</table>";
+ }
+#endif
+}
+
+void ControlView::printDrivingInstructions( QTextDocument &document, QString &text )
+{
+#ifndef QT_NO_PRINTER
+ RoutingModel* routingModel = m_marbleWidget->model()->routingManager()->routingModel();
+
+ if (!routingModel) {
+ return;
+ }
+
+ GeoDataLineString total;
+ for ( int i=0; i<routingModel->rowCount(); ++i ) {
+ QModelIndex index = routingModel->index(i, 0);
+ RoutingModel::RoutingItemType type = qVariantValue<RoutingModel::RoutingItemType>(index.data(RoutingModel::TypeRole));
+ if ( type == RoutingModel::WayPoint ) {
+ GeoDataCoordinates coordinates = qVariantValue<GeoDataCoordinates>(index.data(RoutingModel::CoordinateRole));
+ total.append(coordinates);
+ }
+ }
+
+ text += "<table cellpadding=\"4\">";
+ text += "<tr><th>No.</th><th>Distance</th><th>Instruction</th></tr>";
+ for ( int i=0, j=0; i<routingModel->rowCount(); ++i ) {
+ QModelIndex index = routingModel->index(i, 0);
+ RoutingModel::RoutingItemType type = qVariantValue<RoutingModel::RoutingItemType>( index.data( RoutingModel::TypeRole ) );
+ if ( type == RoutingModel::Instruction ) {
+ ++j;
+ GeoDataCoordinates coordinates = qVariantValue<GeoDataCoordinates>( index.data( RoutingModel::CoordinateRole ) );
+ GeoDataLineString accumulator;
+ for (int k=0; k<total.size(); ++k) {
+ accumulator << total.at(k);
+
+ if (total.at(k) == coordinates)
+ break;
+ }
+
+ if ( i%2 == 0 ) {
+ text += "<tr bgcolor=\"lightGray\"><td align=\"right\" valign=\"middle\">";
+ }
+ else {
+ text += "<tr><td align=\"right\" valign=\"middle\">";
+ }
+ text += QString::number( j );
+ text += "</td><td align=\"right\" valign=\"middle\">";
+
+ text += QString::number( accumulator.length( EARTH_RADIUS ) * METER2KM, 'f', 1 );
+ /** @todo: support localization */
+ text += " km</td><td valign=\"middle\">";
+
+ QPixmap instructionIcon = qVariantValue<QPixmap>( index.data( Qt::DecorationRole ) );
+ if ( !instructionIcon.isNull() ) {
+ QString uri = QString("marble://turnIcon%1.png").arg(i);
+ document.addResource( QTextDocument::ImageResource, QUrl( uri ), QVariant( instructionIcon ) );
+ text += QString("<img src=\"%1\">").arg(uri);
+ }
+
+ text += routingModel->data( index ).toString();
+ text += "</td></tr>";
+ }
+ }
+ text += "</table>";
+#endif
+}
+
+}
+
#include "ControlView.moc"
--- trunk/KDE/kdeedu/marble/src/ControlView.h #1174150:1174151
@@ -27,6 +27,7 @@
class QSplitter;
class QPrintDialog;
+class QTextDocument;
namespace Marble
{
@@ -79,6 +80,11 @@
void paintPrintPreview( QPrinter * printer );
private:
+ void printMap( QTextDocument &document, QString &text, QPrinter *printer );
+ void printLegend( QTextDocument &document, QString &text );
+ void printRouteSummary( QTextDocument &document, QString &text );
+ void printDrivingInstructions( QTextDocument &document, QString &text );
+
//MarbleModel *m_marbleModel;
MarbleWidget *m_marbleWidget;
MarbleControlBox *m_control;
--- trunk/KDE/kdeedu/marble/src/lib/CMakeLists.txt #1174150:1174151
@@ -201,6 +201,8 @@
BookmarkManager.cpp
BookmarkInfoDialog.cpp
NewFolderInfoDialog.cpp
+
+ PrintOptionsWidget.cpp
)
set (marblewidget_UI
@@ -227,6 +229,7 @@
DataMigrationWidget.ui
BookmarkInfoDialog.ui
NameDialog.ui
+ PrintOptions.ui
)
# FIXME: cleaner approach of src/lib/MarbleControlBox.* vs. marble.qrc
--- trunk/KDE/kdeedu/marble/src/lib/MarbleLegendBrowser.cpp #1174150:1174151
@@ -175,7 +175,11 @@
d->m_isLegendLoaded = true;
qDebug("loadLegend: Time elapsed: %d ms", t.elapsed());
+
+ if ( d->m_marbleWidget ) {
+ d->m_marbleWidget->model()->setLegend( document() );
}
+}
bool MarbleLegendBrowser::event( QEvent * event )
{
--- trunk/KDE/kdeedu/marble/src/lib/MarbleModel.cpp #1174150:1174151
@@ -108,7 +108,9 @@
m_positionTracking( 0 ),
m_planet( 0 ),
m_bookmarkManager( 0 ),
- m_routingManager( 0 )
+ m_routingManager( 0 ),
+ m_legend( 0 ),
+ m_backgroundVisible( true )
{
}
@@ -167,8 +169,9 @@
Planet *m_planet;
BookmarkManager *m_bookmarkManager;
-
RoutingManager *m_routingManager;
+ QTextDocument *m_legend;
+ bool m_backgroundVisible;
};
@@ -618,8 +621,10 @@
static_cast<GeoSceneLayer*>( d->m_mapTheme->map()->layer( themeID ) );
QStringList renderPositions;
+ if ( d->m_backgroundVisible ) {
renderPositions << "STARS" << "BEHIND_TARGET";
d->m_layerManager->renderLayers( painter, viewParams, renderPositions );
+ }
if ( redrawBackground ) {
if ( d->m_mapTheme->map()->hasTextureLayers() ) {
@@ -1165,6 +1170,26 @@
return d->m_clock->timezone();
}
+QTextDocument * MarbleModel::legend()
+{
+ return d->m_legend;
}
+void MarbleModel::setLegend( QTextDocument * legend )
+{
+ d->m_legend = legend;
+}
+
+bool MarbleModel::backgroundVisible() const
+{
+ return d->m_backgroundVisible;
+}
+
+void MarbleModel::setBackgroundVisible( bool visible )
+{
+ d->m_backgroundVisible = visible;
+}
+
+}
+
#include "MarbleModel.moc"
--- trunk/KDE/kdeedu/marble/src/lib/MarbleModel.h #1174150:1174151
@@ -41,6 +41,7 @@
class QAbstractItemModel;
class QPoint;
class QRect;
+class QTextDocument;
namespace Marble
{
@@ -311,6 +312,15 @@
* return instance of BookmarkManager
*/
BookmarkManager *bookmarkManager() const;
+
+ QTextDocument * legend();
+
+ void setLegend( QTextDocument * document );
+
+ bool backgroundVisible() const;
+
+ void setBackgroundVisible( bool visible );
+
public Q_SLOTS:
void clearVolatileTileCache();
--- trunk/KDE/kdeedu/marble/src/lib/MarbleWidget.cpp #1174150:1174151
@@ -812,7 +812,6 @@
// Create a painter that will do the painting.
GeoPainter painter( paintDevice, map()->viewport(),
map()->mapQuality(), doClip );
-
QRect dirtyRect = evt->rect();
// Draws the map like MarbleMap::paint does, but adds our customPaint in between
--- trunk/KDE/kdeedu/marble/src/lib/routing/RoutingManager.cpp #1174150:1174151
@@ -131,6 +131,11 @@
updateRoute();
}
+RouteRequest* RoutingManager::routeRequest()
+{
+ return d->m_routeRequest;
+}
+
void RoutingManager::updateRoute()
{
if ( !d->m_routeRequest ) {
@@ -190,11 +195,6 @@
return d->m_adjustNavigation;
}
-RouteRequest* RoutingManager::routeRequest()
-{
- return d->m_routeRequest;
-}
-
void RoutingManager::saveSettings() const
{
GeoWriter writer;
More information about the Marble-commits
mailing list