30QgsTerrainTextureGenerator::QgsTerrainTextureGenerator( 
const Qgs3DMapSettings &map )
 
   33  , mTextureSize( QSize( mMap.mapTileResolution(), mMap.mapTileResolution() ) )
 
   37int QgsTerrainTextureGenerator::render( 
const QgsRectangle &extent, QgsChunkNodeId tileId, 
const QString &debugText )
 
   40  mapSettings.setExtent( extent );
 
   41  QSize size = QSize( mTextureSize );
 
   49      if ( clippedExtent.
height() > clippedExtent.
width() )
 
   50        size.setWidth( std::round( size.width() * clippedExtent.
width() / clippedExtent.
height() ) );
 
   51      else if ( clippedExtent.
height() < clippedExtent.
width() )
 
   52        size.setHeight( std::round( size.height() * clippedExtent.
height() / clippedExtent.
width() ) );
 
   54    mapSettings.setExtent( clippedExtent );
 
   56  mapSettings.setOutputSize( size );
 
   58  QgsEventTracing::addEvent( QgsEventTracing::AsyncBegin, QStringLiteral( 
"3D" ), QStringLiteral( 
"Texture" ), tileId.text() );
 
   64  jobData.jobId = ++mLastJobId;
 
   65  jobData.tileId = tileId;
 
   67  jobData.extent = extent;
 
   68  jobData.debugText = debugText;
 
   70  mJobs.insert( job, jobData ); 
 
   77void QgsTerrainTextureGenerator::cancelJob( 
int jobId )
 
   79  for ( 
const JobData &jd : std::as_const( mJobs ) )
 
   81    if ( jd.jobId == jobId )
 
   84      jd.job->cancelWithoutBlocking();
 
   86      jd.job->deleteLater();
 
   87      mJobs.remove( jd.job );
 
   91  Q_ASSERT( 
false && 
"requested job ID does not exist!" );
 
   94void QgsTerrainTextureGenerator::waitForFinished()
 
   96  for ( 
auto it = mJobs.keyBegin(); it != mJobs.keyEnd(); it++ )
 
   98  QVector<QgsMapRendererSequentialJob *> toBeDeleted;
 
   99  for ( 
auto it = mJobs.constBegin(); it != mJobs.constEnd(); it++ )
 
  103    JobData jobData = it.value();
 
  104    toBeDeleted.push_back( mapJob );
 
  108    if ( mMap.showTerrainTilesInfo() )
 
  113      p.setBackgroundMode( Qt::OpaqueMode );
 
  114      QFont font = p.font();
 
  115      font.setPixelSize( std::max( 30, mMap.mapTileResolution() / 6 ) );
 
  117      p.drawRect( 0, 0, img.width() - 1, img.height() - 1 );
 
  118      p.drawText( img.rect(), jobData.debugText, QTextOption( Qt::AlignCenter ) );
 
  123    emit tileReady( jobData.jobId, img );
 
  128    mJobs.remove( mapJob );
 
  129    mapJob->deleteLater();
 
  133void QgsTerrainTextureGenerator::onRenderingFinished()
 
  137  Q_ASSERT( mJobs.contains( mapJob ) );
 
  138  JobData jobData = mJobs.value( mapJob );
 
  142  if ( mMap.showTerrainTilesInfo() )
 
  147    p.setBackgroundMode( Qt::OpaqueMode );
 
  148    QFont font = p.font();
 
  149    font.setPixelSize( std::max( 30, mMap.mapTileResolution() / 6 ) );
 
  151    p.drawRect( 0, 0, img.width() - 1, img.height() - 1 );
 
  152    p.drawText( img.rect(), jobData.debugText, QTextOption( Qt::AlignCenter ) );
 
  156  mapJob->deleteLater();
 
  157  mJobs.remove( mapJob );
 
  161  QgsEventTracing::addEvent( QgsEventTracing::AsyncEnd, QStringLiteral( 
"3D" ), QStringLiteral( 
"Texture" ), jobData.tileId.text() );
 
  164  emit tileReady( jobData.jobId, img );
 
  180  QList<QgsMapLayer *> layers;
 
  182  QString mapThemeName = mMap.terrainMapTheme();
 
  183  if ( mapThemeName.isEmpty() || !mapThemes || !mapThemes->
hasMapTheme( mapThemeName ) )
 
  185    layers = mMap.layers();
 
  192  layers.erase( std::remove_if( layers.begin(),
 
  194  []( 
const QgsMapLayer * layer ) { return layer->renderer3D(); } ),
 
@ DrawLabeling
Enable drawing of labels on top of the map.
 
@ Render3DMap
Render is for a 3D map.
 
Base class for all map layer types.
 
void finished()
emitted when asynchronous rendering is finished (or canceled).
 
void start()
Start the rendering job and immediately return.
 
Job implementation that renders everything sequentially in one thread.
 
QImage renderedImage() override
Gets a preview/resulting image.
 
void waitForFinished() override
Block until the job has finished.
 
The QgsMapSettings class contains configuration for rendering of the map.
 
void setLayers(const QList< QgsMapLayer * > &layers)
Sets the list of layers to render in the map.
 
void setRendererUsage(Qgis::RendererUsage rendererUsage)
Sets the rendering usage.
 
void setLayerStyleOverrides(const QMap< QString, QString > &overrides)
Sets the map of map layer style overrides (key: layer ID, value: style name) where a different style ...
 
void setTransformContext(const QgsCoordinateTransformContext &context)
Sets the coordinate transform context, which stores various information regarding which datum transfo...
 
void setPathResolver(const QgsPathResolver &resolver)
Sets the path resolver for conversion between relative and absolute paths during rendering operations...
 
void setOutputSize(QSize size)
Sets the size of the resulting map image, in pixels.
 
void setBackgroundColor(const QColor &color)
Sets the background color of the map.
 
void setFlag(Qgis::MapSettingsFlag flag, bool on=true)
Enable or disable a particular flag (other flags are not affected)
 
void setDestinationCrs(const QgsCoordinateReferenceSystem &crs)
Sets the destination crs (coordinate reference system) for the map render.
 
Container class that allows storage of map themes consisting of visible map layers and layer styles.
 
bool hasMapTheme(const QString &name) const
Returns whether a map theme with a matching name exists.
 
QList< QgsMapLayer * > mapThemeVisibleLayers(const QString &name) const
Returns the list of layers that are visible for the specified map theme.
 
QMap< QString, QString > mapThemeStyleOverrides(const QString &name)
Gets layer style overrides (for QgsMapSettings) of the visible layers for given map theme.
 
A rectangle specified with double values.
 
double width() const
Returns the width of the rectangle.
 
double height() const
Returns the height of the rectangle.
 
QgsRectangle intersect(const QgsRectangle &rect) const
Returns the intersection with the given rectangle.
 
@ Flat
The whole terrain is flat area.
 
bool qgsDoubleNear(double a, double b, double epsilon=4 *std::numeric_limits< double >::epsilon())
Compare two doubles (but allow some difference)