34 if ( !p || !mIterator || !viewPort || !theQgsMapToPixel )
56 &block, topLeftCol, topLeftRow ) )
69 if ( printer && printer->
outputFormat() == QPrinter::PdfFormat )
74 QRgb transparentBlack = qRgba( 0, 0, 0, 0 );
75 QRgb transparentWhite = qRgba( 255, 255, 255, 0 );
76 for (
int x = 0; x < img.
width(); x++ )
78 for (
int y = 0; y < img.
height(); y++ )
80 if ( img.
pixel( x, y ) == transparentBlack )
82 img.
setPixel( x, y, transparentWhite );
88 drawImage( p, viewPort, img, topLeftCol, topLeftRow, theQgsMapToPixel );
96 if ( !p || !viewPort )
111 if ( theQgsMapToPixel )
113 int w = theQgsMapToPixel->
mapWidth();
139 double nw = br.
width() * 0.5;
140 double nh = br.
height() * 0.5;
144 nw = br.
width() * 0.5;
void drawImage(QPainter *p, QgsRasterViewPort *viewPort, const QImage &img, int topLeftCol, int topLeftRow, const QgsMapToPixel *mapToPixel=nullptr) const
Draws raster part.
Iterator for sequentially processing raster cells.
void setRenderHint(RenderHint hint, bool on)
void startRasterRead(int bandNumber, int nCols, int nRows, const QgsRectangle &extent)
Start reading of raster band.
void setPixel(int x, int y, uint index_or_rgb)
int mWidth
Width, number of columns to be rendered.
void drawLine(const QLineF &line)
double y() const
Get the y value of the point.
double mapRotation() const
Return current map rotation in degrees.
double ANALYSIS_EXPORT max(double x, double y)
Returns the maximum of two doubles or the first argument if both are equal.
void draw(QPainter *p, QgsRasterViewPort *viewPort, const QgsMapToPixel *theQgsMapToPixel)
Perform transforms between map coordinates and device coordinates.
QRgb pixel(int x, int y) const
int mapWidth() const
Return current map width in pixels The information is only known if setRotation was used...
int mapHeight() const
Return current map height in pixels.
#define QgsDebugMsgLevel(str, level)
void drawRoundedRect(const QRectF &rect, qreal xRadius, qreal yRadius, Qt::SizeMode mode)
QPaintDevice * device() const
QgsRasterDrawer(QgsRasterIterator *iterator)
void setBrush(const QBrush &brush)
bool readNextRasterPart(int bandNumber, int &nCols, int &nRows, QgsRasterBlock **block, int &topLeftCol, int &topLeftRow)
Fetches next part of raster data, caller takes ownership of the block and caller should delete the bl...
QImage image() const
Get image if type is color.
void drawImage(const QRectF &target, const QImage &image, const QRectF &source, QFlags< Qt::ImageConversionFlag > flags)
int mHeight
Distance in map units from bottom edge to top edge for the part of the raster that is to be rendered...
void translate(const QPointF &offset)
QgsPoint mTopLeftPoint
Coordinate (in output device coordinate system) of top left corner of the part of the raster that is ...
This class provides details of the viewable area that a raster will be rendered into.
double x() const
Get the x value of the point.
QgsRectangle mDrawnExtent
Intersection of current map extent and layer extent.