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

Torsten Rahn tackat at kde.org
Tue Jul 21 03:46:02 CEST 2009


SVN commit 1000208 by rahn:

- Forward port of r1000199 and r1000190.



 M  +1 -1      HttpDownloadManager.cpp  
 M  +1 -0      MarbleRunnerManager.cpp  
 M  +91 -2     Projections/AbstractProjection.cpp  
 M  +7 -0      Projections/AbstractProjection_p.h  
 M  +15 -3     geodata/data/GeoDataLineString.cpp  
 M  +12 -2     geodata/data/GeoDataLinearRing.cpp  
 M  +1 -0      runners/OnfRunner.cpp  


--- trunk/KDE/kdeedu/marble/src/lib/HttpDownloadManager.cpp #1000207:1000208
@@ -152,7 +152,7 @@
     iEnd = m_activatedJobList.end();
     for (; i != iEnd; ++i ) {
         if ( job->destinationFileName() == (*i)->destinationFileName() ) {
-            qDebug() << "Download rejected: It's being downloaded already.";
+            qDebug() << "Download rejected: It's being downloaded already:" << job->destinationFileName();
             (*i)->setInitiatorId( job->initiatorId() );
             return false;
         }
--- trunk/KDE/kdeedu/marble/src/lib/MarbleRunnerManager.cpp #1000207:1000208
@@ -89,6 +89,7 @@
 void MarbleRunnerManager::slotRunnerFinished( MarbleAbstractRunner* runner, QVector<GeoDataPlacemark> result )
 {
     m_runners.removeOne(runner);
+    runner->deleteLater();
     qDebug() << "Runner finished, active runners: " << m_runners.size();
     qDebug() << "Runner reports" << result.size() << "results";
     if( result.isEmpty() )
--- trunk/KDE/kdeedu/marble/src/lib/Projections/AbstractProjection.cpp #1000207:1000208
@@ -131,7 +131,6 @@
         return false;
     }
 
-
     QVector<GeoDataLineString*> lineStrings;
 
     if (
@@ -139,7 +138,6 @@
          ( lineString.latLonAltBox().crossesDateLine() )
        ) {
         // We correct for Poles and DateLines:
-
         lineStrings = lineString.toRangeCorrected();
 
         foreach ( GeoDataLineString * itLineString, lineStrings ) {
@@ -351,9 +349,100 @@
         delete polygon; // Clean up "unused" empty polygon instances
     }
 
+    d->repeatPolygons( viewport, polygons );
+
     return polygons.isEmpty();
 }
 
+
+void AbstractProjectionPrivate::repeatPolygons( const ViewportParams *viewport,
+                                                QVector<QPolygonF *> &polygons ) {
+    if ( !q->repeatX() ) {
+        // The projection doesn't allow repeats in direction of the x-axis
+        return;
+    }
+    
+    bool globeHidesPoint = false;
+
+    qreal xEast = 0;
+    qreal xWest = 0;
+    qreal y = 0;
+
+    // Choose a latitude that is inside the viewport.
+    qreal centerLatitude = viewport->viewLatLonAltBox().center().latitude();
+    
+    GeoDataCoordinates westCoords( -M_PI, centerLatitude );
+    GeoDataCoordinates eastCoords( +M_PI, centerLatitude );
+
+    q->screenCoordinates( westCoords, viewport, xWest, y, globeHidesPoint );
+    q->screenCoordinates( eastCoords, viewport, xEast, y, globeHidesPoint );
+
+    if ( xWest <= 0 && xEast >= viewport->width() - 1 ) {
+//        qDebug() << "No repeats";
+        return;
+    }
+
+    qreal repeatXInterval = xEast - xWest;
+
+    qreal repeatsLeft  = 0;
+    qreal repeatsRight = 0;
+
+    if ( xWest > 0 ) {
+        repeatsLeft = (int)( xWest / repeatXInterval ) + 1;
+    }
+    if ( xEast < viewport->width() ) {
+        repeatsRight = (int)( ( viewport->width() - xEast ) / repeatXInterval ) + 1;
+    }
+
+    QVector<QPolygonF *> repeatedPolygons;
+    QVector<QPolygonF *> translatedPolygons;
+
+    qreal xOffset = 0;
+    qreal it = repeatsLeft;
+    
+    while ( it > 0 ) {
+        xOffset = -it * repeatXInterval;
+        translatePolygons( polygons, translatedPolygons, xOffset );
+        repeatedPolygons << translatedPolygons;
+        translatedPolygons.clear();
+        --it;
+    }
+
+    repeatedPolygons << polygons;
+
+    it = 1;
+
+    while ( it <= repeatsRight ) {
+        xOffset = +it * repeatXInterval;
+        translatePolygons( polygons, translatedPolygons, xOffset );
+        repeatedPolygons << translatedPolygons;
+        translatedPolygons.clear();
+        ++it;
+    }
+
+    polygons = repeatedPolygons;
+
+//    qDebug() << Q_FUNC_INFO << "Coordinates: " << xWest << xEast
+//             << "Repeats: " << repeatsLeft << repeatsRight;
+}
+
+void AbstractProjectionPrivate::translatePolygons( const QVector<QPolygonF *> &polygons,
+                                                   QVector<QPolygonF *> &translatedPolygons,
+                                                   qreal xOffset ) {
+//    qDebug() << "Translation: " << xOffset;
+
+    QVector<QPolygonF *>::const_iterator itPolygon = polygons.constBegin();
+    QVector<QPolygonF *>::const_iterator itEnd = polygons.constEnd();
+    
+    for( ; itPolygon != itEnd; ++itPolygon ) {
+        QPolygonF * polygon = new QPolygonF;
+        *polygon = **itPolygon;
+        polygon->translate( xOffset, 0 );
+        translatedPolygons.append( polygon );
+    }
+}
+
+
 void AbstractProjectionPrivate::manageHorizonCrossing( bool globeHidesPoint,
                                                 const GeoDataCoordinates& horizonCoords,
                                                 bool& horizonPair,
--- trunk/KDE/kdeedu/marble/src/lib/Projections/AbstractProjection_p.h #1000207:1000208
@@ -49,6 +49,13 @@
                                     const GeoDataCoordinates &currentCoords,
                                     int count, const ViewportParams *viewport,
                                     TessellationFlags f = 0 );
+
+    void repeatPolygons( const ViewportParams *viewport,
+                         QVector<QPolygonF *> &polygons );
+
+    void translatePolygons( const QVector<QPolygonF *> &polygons,
+                            QVector<QPolygonF *> &translatedPolygons,
+                            qreal xOffset );
 };
 
 } // namespace Marble
--- trunk/KDE/kdeedu/marble/src/lib/geodata/data/GeoDataLineString.cpp #1000207:1000208
@@ -279,6 +279,8 @@
     qreal lon;
     qreal lat;
 
+    // FIXME: Think about how we can avoid unnecessary copies
+    //        if the linestring stays the same.
     for( QVector<GeoDataCoordinates>::const_iterator itCoords
           = p()->m_vector.constBegin();
          itCoords != p()->m_vector.constEnd();
@@ -301,11 +303,21 @@
 
         qDeleteAll( p()->m_rangeCorrected ); // This shouldn't be needed
 
-        GeoDataLineString poleCorrected = toPoleCorrected();
-
+        GeoDataLineString poleCorrected;
+        
+        if ( latLonAltBox().crossesDateLine() )
+        {
+            GeoDataLineString normalizedLineString = toNormalized();
+            poleCorrected = normalizedLineString.toPoleCorrected();
+            p()->m_rangeCorrected = poleCorrected.toDateLineCorrected();
+        }
+        else {
+            poleCorrected = toPoleCorrected();
+        }
+        
         p()->m_rangeCorrected = poleCorrected.toDateLineCorrected();
     }
-    
+
     return p()->m_rangeCorrected;
 }
 
--- trunk/KDE/kdeedu/marble/src/lib/geodata/data/GeoDataLinearRing.cpp #1000207:1000208
@@ -49,10 +49,20 @@
 {
     if ( p()->m_dirtyRange ) {
 
-        qDeleteAll( p()->m_rangeCorrected );
+        qDeleteAll( p()->m_rangeCorrected ); // This shouldn't be needed
 
-        GeoDataLinearRing poleCorrected = toPoleCorrected();
+        GeoDataLinearRing poleCorrected;
 
+        if ( latLonAltBox().crossesDateLine() )
+        {
+            GeoDataLinearRing normalizedLineString = toNormalized();
+            poleCorrected = normalizedLineString.toPoleCorrected();
+            p()->m_rangeCorrected = poleCorrected.toDateLineCorrected();
+        }
+        else {
+            poleCorrected = toPoleCorrected();
+        }
+
         p()->m_rangeCorrected = poleCorrected.toDateLineCorrected();
     }
 
--- trunk/KDE/kdeedu/marble/src/lib/runners/OnfRunner.cpp #1000207:1000208
@@ -125,6 +125,7 @@
         it->setVisualCategory( category() );
     }
     emit runnerFinished( this, placemarks );
+    delete results;
     return;
 }
 


More information about the Marble-commits mailing list