QGIS API Documentation  2.7.0-Master
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
Public Types | Public Member Functions | Protected Member Functions | Protected Attributes | List of all members
QgsMapSettings Class Reference

The QgsMapSettings class contains configuration for rendering of the map. More...

#include <qgsmapsettings.h>

Public Types

enum  Flag {
  Antialiasing = 0x01, DrawEditingInfo = 0x02, ForceVectorOutput = 0x04, UseAdvancedEffects = 0x08,
  DrawLabeling = 0x10, UseRenderingOptimization = 0x20, DrawSelection = 0x40
}
 Enumeration of flags that adjust the way how map is rendered. More...
 

Public Member Functions

 QgsMapSettings ()
 
QColor backgroundColor () const
 Get the background color of the map. More...
 
const QgsDatumTransformStoredatumTransformStore () const
 
QgsDatumTransformStoredatumTransformStore ()
 
const
QgsCoordinateReferenceSystem
destinationCrs () const
 returns CRS of destination coordinate reference system More...
 
QgsRectangle extent () const
 Return geographical coordinates of the rectangle that should be rendered. More...
 
Flags flags () const
 Return combination of flags used for rendering. More...
 
QgsRectangle fullExtent () const
 returns current extent of layer set More...
 
bool hasCrsTransformEnabled () const
 returns true if projections are enabled for this layer set More...
 
bool hasValidSettings () const
 Check whether the map settings are valid and can be used for rendering. More...
 
QgsRectangle layerExtentToOutputExtent (QgsMapLayer *theLayer, QgsRectangle extent) const
 transform bounding box from layer's CRS to output CRS More...
 
QStringList layers () const
 Get list of layer IDs for map rendering The layers are stored in the reverse order of how they are rendered (layer with index 0 will be on top) More...
 
QgsPoint layerToMapCoordinates (QgsMapLayer *theLayer, QgsPoint point) const
 transform point coordinates from layer's CRS to output CRS More...
 
QgsRectangle layerToMapCoordinates (QgsMapLayer *theLayer, QgsRectangle rect) const
 transform rectangle from layer's CRS to output CRS More...
 
const QgsCoordinateTransformlayerTransform (QgsMapLayer *layer) const
 Return coordinate transform from layer's CRS to destination CRS. More...
 
QgsPoint mapToLayerCoordinates (QgsMapLayer *theLayer, QgsPoint point) const
 transform point coordinates from output CRS to layer's CRS More...
 
QgsRectangle mapToLayerCoordinates (QgsMapLayer *theLayer, QgsRectangle rect) const
 transform rectangle from output CRS to layer's CRS More...
 
const QgsMapToPixelmapToPixel () const
 
QGis::UnitType mapUnits () const
 Get units of map's geographical coordinates - used for scale calculation. More...
 
double mapUnitsPerPixel () const
 Return the distance in geographical coordinates that equals to one pixel in the map. More...
 
int outputDpi () const
 Return DPI used for conversion between real world units (e.g. More...
 
QgsRectangle outputExtentToLayerExtent (QgsMapLayer *theLayer, QgsRectangle extent) const
 transform bounding box from output CRS to layer's CRS More...
 
QImage::Format outputImageFormat () const
 format of internal QImage, default QImage::Format_ARGB32_Premultiplied More...
 
QSize outputSize () const
 Return the size of the resulting map image. More...
 
void readXML (QDomNode &theNode)
 
double scale () const
 Return the calculated scale of the map. More...
 
QColor selectionColor () const
 Get color that is used for drawing of selected vector features. More...
 
void setBackgroundColor (const QColor &color)
 Set the background color of the map. More...
 
void setCrsTransformEnabled (bool enabled)
 sets whether to use projections for this layer set More...
 
void setDestinationCrs (const QgsCoordinateReferenceSystem &crs)
 sets destination coordinate reference system More...
 
void setExtent (const QgsRectangle &rect)
 Set coordinates of the rectangle which should be rendered. More...
 
void setFlag (Flag flag, bool on=true)
 Enable or disable a particular flag (other flags are not affected) More...
 
void setFlags (Flags flags)
 Set combination of flags that will be used for rendering. More...
 
void setLayers (const QStringList &layers)
 Set list of layer IDs for map rendering. More...
 
void setMapUnits (QGis::UnitType u)
 Set units of map's geographical coordinates - used for scale calculation. More...
 
void setOutputDpi (int dpi)
 Set DPI used for conversion between real world units (e.g. mm) and pixels. More...
 
void setOutputImageFormat (QImage::Format format)
 sets format of internal QImage More...
 
void setOutputSize (const QSize &size)
 Set the size of the resulting map image. More...
 
void setSelectionColor (const QColor &color)
 Set color that is used for drawing of selected vector features. More...
 
bool testFlag (Flag flag) const
 Check whether a particular flag is enabled. More...
 
QgsRectangle visibleExtent () const
 Return the actual extent derived from requested extent that takes takes output image size into account. More...
 
void writeXML (QDomNode &theNode, QDomDocument &theDoc)
 

Protected Member Functions

void updateDerived ()
 

Protected Attributes

QColor mBackgroundColor
 
QgsDatumTransformStore mDatumTransformStore
 
QgsCoordinateReferenceSystem mDestCRS
 
int mDpi
 
QgsRectangle mExtent
 
Flags mFlags
 
QImage::Format mImageFormat
 
QStringList mLayers
 
QgsMapToPixel mMapToPixel
 
double mMapUnitsPerPixel
 
bool mProjectionsEnabled
 
double mScale
 
QgsScaleCalculator mScaleCalculator
 
QColor mSelectionColor
 
QSize mSize
 
bool mValid
 whether the actual settings are valid (set in updateDerived()) More...
 
QgsRectangle mVisibleExtent
 extent with some additional white space that matches the output aspect ratio More...
 

Detailed Description

The QgsMapSettings class contains configuration for rendering of the map.

The rendering itself is done by QgsMapRendererJob subclasses.

In order to set up QgsMapSettings instance, it is necessary to set at least few members: extent, output size and layers.

QgsMapSettings and QgsMapRendererJob (+subclasses) are intended to replace QgsMapRenderer class that existed before QGIS 2.4. The advantage of the new classes is that they separate the settings from the rendering and provide asynchronous API for map rendering.

Note
added in 2.4

Definition at line 52 of file qgsmapsettings.h.

Member Enumeration Documentation

Enumeration of flags that adjust the way how map is rendered.

Enumerator
Antialiasing 

Enable anti-aliasin for map rendering.

DrawEditingInfo 

Enable drawing of vertex markers for layers in editing mode.

ForceVectorOutput 

Vector graphics should not be cached and drawn as raster images.

UseAdvancedEffects 

Enable layer transparency and blending effects.

DrawLabeling 

Enable drawing of labels on top of the map.

UseRenderingOptimization 

Enable vector simplification and other rendering optimizations.

DrawSelection 

Whether vector selections should be shown in the rendered map.

Definition at line 112 of file qgsmapsettings.h.

Constructor & Destructor Documentation

QgsMapSettings::QgsMapSettings ( )

Definition at line 33 of file qgsmapsettings.cpp.

Member Function Documentation

QColor QgsMapSettings::backgroundColor ( ) const
inline

Get the background color of the map.

Definition at line 104 of file qgsmapsettings.h.

const QgsDatumTransformStore& QgsMapSettings::datumTransformStore ( ) const
inline

Definition at line 151 of file qgsmapsettings.h.

QgsDatumTransformStore& QgsMapSettings::datumTransformStore ( )
inline

Definition at line 152 of file qgsmapsettings.h.

const QgsCoordinateReferenceSystem & QgsMapSettings::destinationCrs ( ) const

returns CRS of destination coordinate reference system

Definition at line 210 of file qgsmapsettings.cpp.

QgsRectangle QgsMapSettings::extent ( ) const

Return geographical coordinates of the rectangle that should be rendered.

The actual visible extent used for rendering could be slightly different since the given extent may be expanded in order to fit the aspect ratio of output size. Use visibleExtent() to get the resulting extent.

Definition at line 52 of file qgsmapsettings.cpp.

QgsMapSettings::Flags QgsMapSettings::flags ( ) const

Return combination of flags used for rendering.

Definition at line 237 of file qgsmapsettings.cpp.

QgsRectangle QgsMapSettings::fullExtent ( ) const

returns current extent of layer set

Definition at line 421 of file qgsmapsettings.cpp.

bool QgsMapSettings::hasCrsTransformEnabled ( ) const

returns true if projections are enabled for this layer set

Definition at line 198 of file qgsmapsettings.cpp.

bool QgsMapSettings::hasValidSettings ( ) const

Check whether the map settings are valid and can be used for rendering.

Definition at line 253 of file qgsmapsettings.cpp.

QgsRectangle QgsMapSettings::layerExtentToOutputExtent ( QgsMapLayer theLayer,
QgsRectangle  extent 
) const

transform bounding box from layer's CRS to output CRS

See also
layerToMapCoordinates( QgsMapLayer* theLayer, QgsRectangle rect ) if you want to transform a rectangle
Returns
a bounding box (aligned rectangle) containing the transformed extent

Definition at line 284 of file qgsmapsettings.cpp.

QStringList QgsMapSettings::layers ( ) const

Get list of layer IDs for map rendering The layers are stored in the reverse order of how they are rendered (layer with index 0 will be on top)

Definition at line 183 of file qgsmapsettings.cpp.

QgsPoint QgsMapSettings::layerToMapCoordinates ( QgsMapLayer theLayer,
QgsPoint  point 
) const

transform point coordinates from layer's CRS to output CRS

Returns
the transformed point

Definition at line 336 of file qgsmapsettings.cpp.

QgsRectangle QgsMapSettings::layerToMapCoordinates ( QgsMapLayer theLayer,
QgsRectangle  rect 
) const

transform rectangle from layer's CRS to output CRS

See also
layerExtentToOutputExtent() if you want to transform a bounding box
Returns
the transformed rectangle

Definition at line 358 of file qgsmapsettings.cpp.

const QgsCoordinateTransform * QgsMapSettings::layerTransform ( QgsMapLayer layer) const

Return coordinate transform from layer's CRS to destination CRS.

Parameters
layer
Returns
transform - may be null if the transform is not needed

Definition at line 277 of file qgsmapsettings.cpp.

QgsPoint QgsMapSettings::mapToLayerCoordinates ( QgsMapLayer theLayer,
QgsPoint  point 
) const

transform point coordinates from output CRS to layer's CRS

Returns
the transformed point

Definition at line 380 of file qgsmapsettings.cpp.

QgsRectangle QgsMapSettings::mapToLayerCoordinates ( QgsMapLayer theLayer,
QgsRectangle  rect 
) const

transform rectangle from output CRS to layer's CRS

See also
outputExtentToLayerExtent() if you want to transform a bounding box
Returns
the transformed rectangle

Definition at line 402 of file qgsmapsettings.cpp.

const QgsMapToPixel& QgsMapSettings::mapToPixel ( ) const
inline

Definition at line 154 of file qgsmapsettings.h.

QGis::UnitType QgsMapSettings::mapUnits ( ) const

Get units of map's geographical coordinates - used for scale calculation.

Definition at line 247 of file qgsmapsettings.cpp.

double QgsMapSettings::mapUnitsPerPixel ( ) const

Return the distance in geographical coordinates that equals to one pixel in the map.

Definition at line 263 of file qgsmapsettings.cpp.

int QgsMapSettings::outputDpi ( ) const

Return DPI used for conversion between real world units (e.g.

mm) and pixels Default value is 96

Definition at line 170 of file qgsmapsettings.cpp.

QgsRectangle QgsMapSettings::outputExtentToLayerExtent ( QgsMapLayer theLayer,
QgsRectangle  extent 
) const

transform bounding box from output CRS to layer's CRS

See also
mapToLayerCoordinates( QgsMapLayer* theLayer,QgsRectangle rect ) if you want to transform a rectangle
Returns
a bounding box (aligned rectangle) containing the transformed extent

Definition at line 310 of file qgsmapsettings.cpp.

QImage::Format QgsMapSettings::outputImageFormat ( ) const
inline

format of internal QImage, default QImage::Format_ARGB32_Premultiplied

Definition at line 137 of file qgsmapsettings.h.

QSize QgsMapSettings::outputSize ( ) const

Return the size of the resulting map image.

Definition at line 158 of file qgsmapsettings.cpp.

void QgsMapSettings::readXML ( QDomNode &  theNode)

Definition at line 493 of file qgsmapsettings.cpp.

double QgsMapSettings::scale ( ) const

Return the calculated scale of the map.

Definition at line 268 of file qgsmapsettings.cpp.

QColor QgsMapSettings::selectionColor ( ) const
inline

Get color that is used for drawing of selected vector features.

Definition at line 109 of file qgsmapsettings.h.

void QgsMapSettings::setBackgroundColor ( const QColor &  color)
inline

Set the background color of the map.

Definition at line 102 of file qgsmapsettings.h.

void QgsMapSettings::setCrsTransformEnabled ( bool  enabled)

sets whether to use projections for this layer set

Definition at line 193 of file qgsmapsettings.cpp.

void QgsMapSettings::setDestinationCrs ( const QgsCoordinateReferenceSystem crs)

sets destination coordinate reference system

Definition at line 204 of file qgsmapsettings.cpp.

void QgsMapSettings::setExtent ( const QgsRectangle rect)

Set coordinates of the rectangle which should be rendered.

The actual visible extent used for rendering could be slightly different since the given extent may be expanded in order to fit the aspect ratio of output size. Use visibleExtent() to get the resulting extent.

Definition at line 57 of file qgsmapsettings.cpp.

void QgsMapSettings::setFlag ( QgsMapSettings::Flag  flag,
bool  on = true 
)

Enable or disable a particular flag (other flags are not affected)

Definition at line 229 of file qgsmapsettings.cpp.

void QgsMapSettings::setFlags ( Flags  flags)

Set combination of flags that will be used for rendering.

Definition at line 224 of file qgsmapsettings.cpp.

void QgsMapSettings::setLayers ( const QStringList &  layers)

Set list of layer IDs for map rendering.

The layers must be registered in QgsMapLayerRegistry. The layers are stored in the reverse order of how they are rendered (layer with index 0 will be on top)

Definition at line 188 of file qgsmapsettings.cpp.

void QgsMapSettings::setMapUnits ( QGis::UnitType  u)

Set units of map's geographical coordinates - used for scale calculation.

Definition at line 216 of file qgsmapsettings.cpp.

void QgsMapSettings::setOutputDpi ( int  dpi)

Set DPI used for conversion between real world units (e.g. mm) and pixels.

Definition at line 175 of file qgsmapsettings.cpp.

void QgsMapSettings::setOutputImageFormat ( QImage::Format  format)
inline

sets format of internal QImage

Definition at line 135 of file qgsmapsettings.h.

void QgsMapSettings::setOutputSize ( const QSize &  size)

Set the size of the resulting map image.

Definition at line 163 of file qgsmapsettings.cpp.

void QgsMapSettings::setSelectionColor ( const QColor &  color)
inline

Set color that is used for drawing of selected vector features.

Definition at line 107 of file qgsmapsettings.h.

bool QgsMapSettings::testFlag ( QgsMapSettings::Flag  flag) const

Check whether a particular flag is enabled.

Definition at line 242 of file qgsmapsettings.cpp.

void QgsMapSettings::updateDerived ( )
protected

Definition at line 65 of file qgsmapsettings.cpp.

QgsRectangle QgsMapSettings::visibleExtent ( ) const

Return the actual extent derived from requested extent that takes takes output image size into account.

Definition at line 258 of file qgsmapsettings.cpp.

void QgsMapSettings::writeXML ( QDomNode &  theNode,
QDomDocument &  theDoc 
)

Definition at line 520 of file qgsmapsettings.cpp.

Member Data Documentation

QColor QgsMapSettings::mBackgroundColor
protected

Definition at line 226 of file qgsmapsettings.h.

QgsDatumTransformStore QgsMapSettings::mDatumTransformStore
protected

Definition at line 224 of file qgsmapsettings.h.

QgsCoordinateReferenceSystem QgsMapSettings::mDestCRS
protected

Definition at line 223 of file qgsmapsettings.h.

int QgsMapSettings::mDpi
protected

Definition at line 214 of file qgsmapsettings.h.

QgsRectangle QgsMapSettings::mExtent
protected

Definition at line 218 of file qgsmapsettings.h.

Flags QgsMapSettings::mFlags
protected

Definition at line 229 of file qgsmapsettings.h.

QImage::Format QgsMapSettings::mImageFormat
protected

Definition at line 231 of file qgsmapsettings.h.

QStringList QgsMapSettings::mLayers
protected

Definition at line 220 of file qgsmapsettings.h.

QgsMapToPixel QgsMapSettings::mMapToPixel
protected

Definition at line 242 of file qgsmapsettings.h.

double QgsMapSettings::mMapUnitsPerPixel
protected

Definition at line 236 of file qgsmapsettings.h.

bool QgsMapSettings::mProjectionsEnabled
protected

Definition at line 222 of file qgsmapsettings.h.

double QgsMapSettings::mScale
protected

Definition at line 237 of file qgsmapsettings.h.

QgsScaleCalculator QgsMapSettings::mScaleCalculator
protected

Definition at line 241 of file qgsmapsettings.h.

QColor QgsMapSettings::mSelectionColor
protected

Definition at line 227 of file qgsmapsettings.h.

QSize QgsMapSettings::mSize
protected

Definition at line 216 of file qgsmapsettings.h.

bool QgsMapSettings::mValid
protected

whether the actual settings are valid (set in updateDerived())

Definition at line 234 of file qgsmapsettings.h.

QgsRectangle QgsMapSettings::mVisibleExtent
protected

extent with some additional white space that matches the output aspect ratio

Definition at line 235 of file qgsmapsettings.h.


The documentation for this class was generated from the following files: