Skip to content

Commit

Permalink
Raster renderer: fix so that raster in projected CRS is not rendered …
Browse files Browse the repository at this point in the history
…in geographic CRS if the extent exceeds -180,-90,180,90 (fixes #14229)
  • Loading branch information
rouault committed Nov 14, 2017
1 parent 71a4bed commit eefcb31
Showing 1 changed file with 20 additions and 5 deletions.
25 changes: 20 additions & 5 deletions src/core/raster/qgsrasterlayerrenderer.cpp
Expand Up @@ -52,14 +52,29 @@ QgsRasterLayerRenderer::QgsRasterLayerRenderer( QgsRasterLayer* layer, QgsRender
if ( rendererContext.coordinateTransform() ) if ( rendererContext.coordinateTransform() )
{ {
QgsDebugMsgLevel( "coordinateTransform set -> project extents.", 4 ); QgsDebugMsgLevel( "coordinateTransform set -> project extents.", 4 );
try if ( rendererContext.extent().xMinimum() == -DBL_MAX &&
rendererContext.extent().yMinimum() == -DBL_MAX &&
rendererContext.extent().xMaximum() == DBL_MAX &&
rendererContext.extent().yMaximum() == DBL_MAX )
{ {
myProjectedViewExtent = rendererContext.coordinateTransform()->transformBoundingBox( rendererContext.extent() ); // We get in this situation if the view CRS is geographical and the
// extent goes beyond -180,-90,180,90. To avoid reprojection issues to the
// layer CRS, then this dummy extent is returned by QgsMapRendererJob::reprojectToLayerExtent()
// Don't try to reproject it now to view extent as this would return
// a null rectangle.
myProjectedViewExtent = rendererContext.extent();
} }
catch ( QgsCsException &cs ) else
{ {
QgsMessageLog::logMessage( QObject::tr( "Could not reproject view extent: %1" ).arg( cs.what() ), QObject::tr( "Raster" ) ); try
myProjectedViewExtent.setMinimal(); {
myProjectedViewExtent = rendererContext.coordinateTransform()->transformBoundingBox( rendererContext.extent() );
}
catch ( QgsCsException &cs )
{
QgsMessageLog::logMessage( QObject::tr( "Could not reproject view extent: %1" ).arg( cs.what() ), QObject::tr( "Raster" ) );
myProjectedViewExtent.setMinimal();
}
} }


try try
Expand Down

0 comments on commit eefcb31

Please sign in to comment.