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

Bernhard Beschow bbeschow at cs.tu-berlin.de
Wed Jan 19 17:45:21 CET 2011


SVN commit 1215778 by beschow:

don't crash in equirectangular projection when the map doesn't cover the whole view

 M  +8 -8      AbstractScanlineTextureMapper.cpp  
 M  +8 -8      AbstractScanlineTextureMapper.h  
 M  +0 -2      EquirectScanlineTextureMapper.cpp  
 M  +0 -2      MercatorScanlineTextureMapper.cpp  
 M  +0 -2      SphericalScanlineTextureMapper.cpp  
 M  +0 -2      TileScalingTextureMapper.cpp  


--- branches/KDE/4.6/kdeedu/marble/src/lib/AbstractScanlineTextureMapper.cpp #1215777:1215778
@@ -29,8 +29,6 @@
       m_maxGlobalY( 0 ),
       m_prevLat( 0.0 ),
       m_prevLon( 0.0 ),
-      m_toTileCoordinatesLon( 0.0 ),
-      m_toTileCoordinatesLat( 0.0 ),
       m_interlaced( false ),
       m_tileLoader( tileLoader ),
       m_tilePosX( 0 ),
@@ -39,6 +37,8 @@
       m_tileSize( tileLoader->tileSize() ),  // cache tile size
       m_tile( 0 ),
       m_previousRadius( 0 ),
+      m_toTileCoordinatesLon( 0.0 ),
+      m_toTileCoordinatesLat( 0.0 ),
       m_tileLevel( 0 ),
       m_globalWidth( 0 ),
       m_globalHeight( 0 ),
@@ -91,8 +91,8 @@
     // the center to the upper left corner and subtract the tile position 
     // in that coordinate system. In total this equals a coordinate 
     // transformation to tile coordinates.
-    m_toTileCoordinatesLon = (qreal)(m_globalWidth / 2 - m_tilePosX);
-    m_toTileCoordinatesLat = (qreal)(m_globalHeight / 2 - m_tilePosY);
+    m_toTileCoordinatesLon = (qreal)(0.5 * m_globalWidth - m_tilePosX);
+    m_toTileCoordinatesLat = (qreal)(0.5 * m_globalHeight - m_tilePosY);
 
     if ( changedTileLevel ) {
         m_tileLoader->flush();
@@ -501,11 +501,11 @@
     // ( origin upper left, measured in pixels )
 
     m_tilePosX = tileCol * m_tileSize.width();
-    m_toTileCoordinatesLon = (qreal)(m_globalWidth / 2 - m_tilePosX);
+    m_toTileCoordinatesLon = (qreal)(0.5 * m_globalWidth - m_tilePosX);
     posX = lon - m_tilePosX;
 
     m_tilePosY = tileRow * m_tileSize.height();
-    m_toTileCoordinatesLat = (qreal)(m_globalHeight / 2 - m_tilePosY);
+    m_toTileCoordinatesLat = (qreal)(0.5 * m_globalHeight - m_tilePosY);
     posY = lat - m_tilePosY;
 }
 
@@ -541,11 +541,11 @@
     // ( origin upper left, measured in pixels )
 
     m_tilePosX = tileCol * m_tileSize.width();
-    m_toTileCoordinatesLon = (qreal)(m_globalWidth / 2 - m_tilePosX);
+    m_toTileCoordinatesLon = (qreal)(0.5 * m_globalWidth - m_tilePosX);
     posX = lon - m_tilePosX;
 
     m_tilePosY = tileRow * m_tileSize.height();
-    m_toTileCoordinatesLat = (qreal)(m_globalHeight / 2 - m_tilePosY);
+    m_toTileCoordinatesLat = (qreal)(0.5 * m_globalHeight - m_tilePosY);
     posY = lat - m_tilePosY;
 }
 
--- branches/KDE/4.6/kdeedu/marble/src/lib/AbstractScanlineTextureMapper.h #1215777:1215778
@@ -105,14 +105,6 @@
     qreal  m_prevLat;
     qreal  m_prevLon;
 
-    // Coordinate transformations:
-
-    // Converts global texture coordinates 
-    // ( with origin in center, measured in pixel) 
-    // to tile coordinates ( measured in pixel )
-    qreal  m_toTileCoordinatesLon;
-    qreal  m_toTileCoordinatesLat;
-
     bool m_interlaced;
 
     StackedTileLoader *m_tileLoader;
@@ -131,6 +123,14 @@
     StackedTile *m_tile;
     int         m_previousRadius;
 
+    // Coordinate transformations:
+
+    // Converts global texture coordinates 
+    // ( with origin in center, measured in pixel) 
+    // to tile coordinates ( measured in pixel )
+    qreal  m_toTileCoordinatesLon;
+    qreal  m_toTileCoordinatesLat;
+
     int         m_tileLevel;
     int         m_globalWidth;
     int         m_globalHeight;
--- branches/KDE/4.6/kdeedu/marble/src/lib/EquirectScanlineTextureMapper.cpp #1215777:1215778
@@ -81,8 +81,6 @@
 
     m_tilePosX = 65535;
     m_tilePosY = 65535;
-    m_toTileCoordinatesLon = (qreal)(globalWidth() / 2 - m_tilePosX);
-    m_toTileCoordinatesLat = (qreal)(globalHeight() / 2 - m_tilePosY);
 
     // Calculate how many degrees are being represented per pixel.
     const float rad2Pixel = (float)( 2 * radius ) / M_PI;
--- branches/KDE/4.6/kdeedu/marble/src/lib/MercatorScanlineTextureMapper.cpp #1215777:1215778
@@ -85,8 +85,6 @@
 
     m_tilePosX = 65535;
     m_tilePosY = 65535;
-    m_toTileCoordinatesLon = (qreal)(globalWidth() / 2 - m_tilePosX);
-    m_toTileCoordinatesLat = (qreal)(globalHeight() / 2 - m_tilePosY);
 
     // Calculate how many degrees are being represented per pixel.
     const float rad2Pixel = (float)( 2 * radius ) / M_PI;
--- branches/KDE/4.6/kdeedu/marble/src/lib/SphericalScanlineTextureMapper.cpp #1215777:1215778
@@ -87,8 +87,6 @@
 
     m_tilePosX = 65535;
     m_tilePosY = 65535;
-    m_toTileCoordinatesLon = (qreal)(globalWidth() / 2 - m_tilePosX);
-    m_toTileCoordinatesLat = (qreal)(globalHeight() / 2 - m_tilePosY);
 
     // Reset backend
     m_tileLoader->resetTilehash();
--- branches/KDE/4.6/kdeedu/marble/src/lib/TileScalingTextureMapper.cpp #1215777:1215778
@@ -83,8 +83,6 @@
 
     m_tilePosX = 65535;
     m_tilePosY = 65535;
-    m_toTileCoordinatesLon = (qreal)(globalWidth() / 2 - m_tilePosX);
-    m_toTileCoordinatesLat = (qreal)(globalHeight() / 2 - m_tilePosY);
 
     // Reset backend
     m_tileLoader->resetTilehash();


More information about the Marble-commits mailing list