QGIS API Documentation
3.20.0-Odense (decaadbb31)
|
Raster renderer pipe that applies colors to a raster. More...
#include <qgsrasterrenderer.h>
Public Member Functions | |
QgsRasterRenderer (const QgsRasterRenderer &)=delete | |
QgsRasterRenderer cannot be copied. Use clone() instead. More... | |
QgsRasterRenderer (QgsRasterInterface *input=nullptr, const QString &type=QString()) | |
Constructor for QgsRasterRenderer. More... | |
~QgsRasterRenderer () override | |
virtual bool | accept (QgsStyleEntityVisitorInterface *visitor) const |
Accepts the specified symbology visitor, causing it to visit all symbols associated with the renderer. More... | |
int | alphaBand () const |
int | bandCount () const override |
Gets number of bands. More... | |
QgsRasterBlock * | block (int bandNo, const QgsRectangle &extent, int width, int height, QgsRasterBlockFeedback *feedback=nullptr) override=0 |
Read block of data using given extent and size. More... | |
QgsRasterRenderer * | clone () const override=0 |
Clone itself, create deep copy. More... | |
void | copyCommonProperties (const QgsRasterRenderer *other, bool copyMinMaxOrigin=true) |
Copies common properties like opacity / transparency data from other renderer. More... | |
virtual QList< QgsLayerTreeModelLegendNode * > | createLegendNodes (QgsLayerTreeLayer *nodeLayer) |
Creates a set of legend nodes representing the renderer. More... | |
Qgis::DataType | dataType (int bandNo) const override |
Returns data type for the band specified by number. More... | |
virtual QList< QPair< QString, QColor > > | legendSymbologyItems () const |
Returns symbology items if provided by renderer. More... | |
const QgsRasterMinMaxOrigin & | minMaxOrigin () const |
Returns const reference to origin of min/max values. More... | |
QColor | nodataColor () const |
Returns the color to use for shading nodata pixels. More... | |
double | opacity () const |
Returns the opacity for the renderer, where opacity is a value between 0 (totally transparent) and 1.0 (fully opaque). More... | |
const QgsRasterRenderer & | operator= (const QgsRasterRenderer &)=delete |
QgsRasterRenderer cannot be copied. Use clone() instead. More... | |
const QgsRasterTransparency * | rasterTransparency () const |
void | readXml (const QDomElement &rendererElem) override |
Sets base class members from xml. Usually called from create() methods of subclasses. More... | |
void | setAlphaBand (int band) |
bool | setInput (QgsRasterInterface *input) override |
Set input. More... | |
void | setMinMaxOrigin (const QgsRasterMinMaxOrigin &origin) |
Sets origin of min/max values. More... | |
void | setNodataColor (const QColor &color) |
Sets the color to use for shading nodata pixels. More... | |
void | setOpacity (double opacity) |
Sets the opacity for the renderer, where opacity is a value between 0 (totally transparent) and 1.0 (fully opaque). More... | |
void | setRasterTransparency (QgsRasterTransparency *t) |
virtual void | toSld (QDomDocument &doc, QDomElement &element, const QVariantMap &props=QVariantMap()) const |
Used from subclasses to create SLD Rule elements following SLD v1.0 specs. More... | |
virtual QString | type () const |
virtual QList< int > | usesBands () const |
Returns a list of band numbers used by the renderer. More... | |
bool | usesTransparency () const |
Public Member Functions inherited from QgsRasterInterface | |
QgsRasterInterface (QgsRasterInterface *input=nullptr) | |
virtual | ~QgsRasterInterface ()=default |
virtual QgsRasterBandStats | bandStatistics (int bandNo, int stats=QgsRasterBandStats::All, const QgsRectangle &extent=QgsRectangle(), int sampleSize=0, QgsRasterBlockFeedback *feedback=nullptr) |
Returns the band statistics. More... | |
virtual int | capabilities () const |
Returns a bitmask containing the supported capabilities. More... | |
QString | capabilitiesString () const |
Returns the raster interface capabilities in friendly format. More... | |
virtual QString | colorInterpretationName (int bandNumber) const |
Returns the name of the color interpretation for the specified bandNumber. More... | |
virtual void | cumulativeCut (int bandNo, double lowerCount, double upperCount, double &lowerValue, double &upperValue, const QgsRectangle &extent=QgsRectangle(), int sampleSize=0) |
Find values for cumulative pixel count cut. More... | |
int | dataTypeSize (int bandNo) const |
Returns the size (in bytes) for the data type for the specified band. More... | |
QString | displayBandName (int bandNumber) const |
Generates a friendly, descriptive name for the specified bandNumber. More... | |
virtual QgsRectangle | extent () const |
Gets the extent of the interface. More... | |
virtual QString | generateBandName (int bandNumber) const |
helper function to create zero padded band names More... | |
virtual bool | hasHistogram (int bandNo, int binCount, double minimum=std::numeric_limits< double >::quiet_NaN(), double maximum=std::numeric_limits< double >::quiet_NaN(), const QgsRectangle &extent=QgsRectangle(), int sampleSize=0, bool includeOutOfRange=false) |
Returns true if histogram is available (cached, already calculated) More... | |
virtual bool | hasStatistics (int bandNo, int stats=QgsRasterBandStats::All, const QgsRectangle &extent=QgsRectangle(), int sampleSize=0) |
Returns true if histogram is available (cached, already calculated). More... | |
virtual QgsRasterHistogram | histogram (int bandNo, int binCount=0, double minimum=std::numeric_limits< double >::quiet_NaN(), double maximum=std::numeric_limits< double >::quiet_NaN(), const QgsRectangle &extent=QgsRectangle(), int sampleSize=0, bool includeOutOfRange=false, QgsRasterBlockFeedback *feedback=nullptr) |
Returns a band histogram. More... | |
virtual QgsRasterInterface * | input () const |
Current input. More... | |
virtual bool | on () const |
Returns whether the interface is on or off. More... | |
virtual void | setOn (bool on) |
Sets whether the interface is on or off. More... | |
virtual Qgis::DataType | sourceDataType (int bandNo) const |
Returns source data type for the band specified by number, source data type may be shorter than dataType. More... | |
virtual QgsRasterInterface * | sourceInput () |
Gets source / raw input, the first in pipe, usually provider. More... | |
virtual const QgsRasterInterface * | sourceInput () const |
Gets source / raw input, the first in pipe, usually provider. More... | |
virtual void | writeXml (QDomDocument &doc, QDomElement &parentElem) const |
Write base class members to xml. More... | |
virtual int | xBlockSize () const |
Gets block size. More... | |
virtual int | xSize () const |
Gets raster size. More... | |
virtual int | yBlockSize () const |
virtual int | ySize () const |
Static Public Attributes | |
static const QRgb | NODATA_COLOR = qRgba( 0, 0, 0, 0 ) |
Protected Member Functions | |
void | _writeXml (QDomDocument &doc, QDomElement &rasterRendererElem) const |
Write upper class info into rasterrenderer element (called by writeXml method of subclasses) More... | |
QRgb | renderColorForNodataPixel () const |
Returns the color for the renderer to use to represent nodata pixels. More... | |
Protected Member Functions inherited from QgsRasterInterface | |
void | initHistogram (QgsRasterHistogram &histogram, int bandNo, int binCount, double minimum=std::numeric_limits< double >::quiet_NaN(), double maximum=std::numeric_limits< double >::quiet_NaN(), const QgsRectangle &boundingBox=QgsRectangle(), int sampleSize=0, bool includeOutOfRange=false) |
Fill in histogram defaults if not specified. More... | |
void | initStatistics (QgsRasterBandStats &statistics, int bandNo, int stats=QgsRasterBandStats::All, const QgsRectangle &boundingBox=QgsRectangle(), int binCount=0) |
Fill in statistics defaults if not specified. More... | |
Protected Attributes | |
int | mAlphaBand = -1 |
Read alpha value from band. More... | |
QgsRasterMinMaxOrigin | mMinMaxOrigin |
Origin of min/max values. More... | |
double | mOpacity = 1.0 |
Global alpha value (0-1) More... | |
QgsRasterTransparency * | mRasterTransparency = nullptr |
Raster transparency per color or value. Overwrites global alpha value. More... | |
QString | mType |
Protected Attributes inherited from QgsRasterInterface | |
QList< QgsRasterHistogram > | mHistograms |
List of cached histograms, all bands mixed. More... | |
QgsRasterInterface * | mInput = nullptr |
bool | mOn = true |
QList< QgsRasterBandStats > | mStatistics |
List of cached statistics, all bands mixed. More... | |
Additional Inherited Members | |
Public Types inherited from QgsRasterInterface | |
enum | Capability { NoCapabilities = 0 , Size = 1 << 1 , Create = 1 << 2 , Remove = 1 << 3 , BuildPyramids = 1 << 4 , Identify = 1 << 5 , IdentifyValue = 1 << 6 , IdentifyText = 1 << 7 , IdentifyHtml = 1 << 8 , IdentifyFeature = 1 << 9 , Prefetch = 1 << 10 } |
If you add to this, please also add to capabilitiesString() More... | |
Raster renderer pipe that applies colors to a raster.
Definition at line 40 of file qgsrasterrenderer.h.
QgsRasterRenderer::QgsRasterRenderer | ( | QgsRasterInterface * | input = nullptr , |
const QString & | type = QString() |
||
) |
Constructor for QgsRasterRenderer.
Definition at line 33 of file qgsrasterrenderer.cpp.
|
override |
Definition at line 39 of file qgsrasterrenderer.cpp.
|
delete |
QgsRasterRenderer cannot be copied. Use clone() instead.
|
protected |
Write upper class info into rasterrenderer element (called by writeXml method of subclasses)
Definition at line 138 of file qgsrasterrenderer.cpp.
|
virtual |
Accepts the specified symbology visitor, causing it to visit all symbols associated with the renderer.
Returns true
if the visitor should continue visiting other objects, or false
if visiting should be canceled.
Reimplemented in QgsSingleBandPseudoColorRenderer, and QgsPalettedRasterRenderer.
Definition at line 223 of file qgsrasterrenderer.cpp.
|
inline |
Definition at line 119 of file qgsrasterrenderer.h.
|
overridevirtual |
Gets number of bands.
Implements QgsRasterInterface.
Definition at line 44 of file qgsrasterrenderer.cpp.
|
overridepure virtual |
Read block of data using given extent and size.
Returns pointer to data. Caller is responsible to free the memory returned.
bandNo | band number |
extent | extent of block |
width | pixel width of block |
height | pixel height of block |
feedback | optional raster feedback object for cancellation/preview. Added in QGIS 3.0. |
Implements QgsRasterInterface.
Implemented in QgsSingleBandPseudoColorRenderer, QgsSingleBandGrayRenderer, QgsSingleBandColorDataRenderer, QgsRasterContourRenderer, QgsPalettedRasterRenderer, QgsMultiBandColorRenderer, and QgsHillshadeRenderer.
|
overridepure virtual |
Clone itself, create deep copy.
Implements QgsRasterInterface.
Implemented in QgsSingleBandPseudoColorRenderer, QgsSingleBandGrayRenderer, QgsSingleBandColorDataRenderer, QgsRasterContourRenderer, QgsPalettedRasterRenderer, QgsMultiBandColorRenderer, and QgsHillshadeRenderer.
void QgsRasterRenderer::copyCommonProperties | ( | const QgsRasterRenderer * | other, |
bool | copyMinMaxOrigin = true |
||
) |
Copies common properties like opacity / transparency data from other renderer.
Useful when cloning renderers.
Definition at line 196 of file qgsrasterrenderer.cpp.
|
virtual |
Creates a set of legend nodes representing the renderer.
The default implementation calls legendSymbologyItems() and creates corresponding legend nodes for each returned symbology item.
Subclasses can override this to return more legend nodes which better represent the renderer.
Reimplemented in QgsSingleBandPseudoColorRenderer, QgsSingleBandGrayRenderer, QgsRasterContourRenderer, QgsPalettedRasterRenderer, and QgsMultiBandColorRenderer.
Definition at line 110 of file qgsrasterrenderer.cpp.
|
overridevirtual |
Returns data type for the band specified by number.
Implements QgsRasterInterface.
Definition at line 53 of file qgsrasterrenderer.cpp.
|
virtual |
Returns symbology items if provided by renderer.
Reimplemented in QgsSingleBandPseudoColorRenderer, QgsSingleBandGrayRenderer, and QgsPalettedRasterRenderer.
Definition at line 105 of file qgsrasterrenderer.cpp.
|
inline |
Returns const reference to origin of min/max values.
Definition at line 154 of file qgsrasterrenderer.h.
|
inline |
Returns the color to use for shading nodata pixels.
If the returned value is an invalid color then the default transparent rendering of nodata values will be used.
Definition at line 102 of file qgsrasterrenderer.h.
|
inline |
Returns the opacity for the renderer, where opacity is a value between 0 (totally transparent) and 1.0 (fully opaque).
Definition at line 90 of file qgsrasterrenderer.h.
|
delete |
QgsRasterRenderer cannot be copied. Use clone() instead.
|
inline |
Definition at line 116 of file qgsrasterrenderer.h.
|
overridevirtual |
Sets base class members from xml. Usually called from create() methods of subclasses.
Reimplemented from QgsRasterInterface.
Definition at line 168 of file qgsrasterrenderer.cpp.
|
protected |
Returns the color for the renderer to use to represent nodata pixels.
Subclasses should use this rather then nodataColor() to determine the color to use for nodata pixels during an actual rendering operation.
Definition at line 160 of file qgsrasterrenderer.cpp.
|
inline |
Definition at line 118 of file qgsrasterrenderer.h.
|
overridevirtual |
Set input.
Returns true
if set correctly, false
if cannot use that input
Reimplemented from QgsRasterInterface.
Reimplemented in QgsSingleBandColorDataRenderer.
Definition at line 64 of file qgsrasterrenderer.cpp.
|
inline |
Sets origin of min/max values.
Definition at line 157 of file qgsrasterrenderer.h.
|
inline |
Sets the color to use for shading nodata pixels.
If color is an invalid color then the default transparent rendering of nodata values will be used.
Definition at line 113 of file qgsrasterrenderer.h.
|
inline |
Sets the opacity for the renderer, where opacity is a value between 0 (totally transparent) and 1.0 (fully opaque).
Definition at line 83 of file qgsrasterrenderer.h.
void QgsRasterRenderer::setRasterTransparency | ( | QgsRasterTransparency * | t | ) |
Definition at line 99 of file qgsrasterrenderer.cpp.
|
virtual |
Used from subclasses to create SLD Rule elements following SLD v1.0 specs.
Reimplemented in QgsSingleBandPseudoColorRenderer, QgsSingleBandGrayRenderer, QgsPalettedRasterRenderer, QgsMultiBandColorRenderer, and QgsHillshadeRenderer.
Definition at line 209 of file qgsrasterrenderer.cpp.
|
inlinevirtual |
Definition at line 66 of file qgsrasterrenderer.h.
|
inlinevirtual |
Returns a list of band numbers used by the renderer.
Reimplemented in QgsSingleBandPseudoColorRenderer, QgsSingleBandGrayRenderer, QgsSingleBandColorDataRenderer, QgsRasterContourRenderer, QgsPalettedRasterRenderer, QgsMultiBandColorRenderer, and QgsHillshadeRenderer.
Definition at line 151 of file qgsrasterrenderer.h.
bool QgsRasterRenderer::usesTransparency | ( | ) | const |
Definition at line 90 of file qgsrasterrenderer.cpp.
|
protected |
Read alpha value from band.
Is combined with value from raster transparency / global alpha value. Default: -1 (not set)
Definition at line 192 of file qgsrasterrenderer.h.
|
protected |
Origin of min/max values.
Definition at line 195 of file qgsrasterrenderer.h.
|
protected |
Global alpha value (0-1)
Definition at line 184 of file qgsrasterrenderer.h.
|
protected |
Raster transparency per color or value. Overwrites global alpha value.
Definition at line 186 of file qgsrasterrenderer.h.
|
protected |
Definition at line 181 of file qgsrasterrenderer.h.
|
static |
Definition at line 47 of file qgsrasterrenderer.h.