QGIS API Documentation  3.8.0-Zanzibar (11aff65)
qgsrasterfilewritertask.h
Go to the documentation of this file.
1 /***************************************************************************
2  qgsrasterfilewritertask.h
3  -------------------------
4  begin : April 2017
5  copyright : (C) 2017 by Nyall Dawson
6  email : nyall dot dawson at gmail dot com
7  ***************************************************************************/
8 
9 /***************************************************************************
10  * *
11  * This program is free software; you can redistribute it and/or modify *
12  * it under the terms of the GNU General Public License as published by *
13  * the Free Software Foundation; either version 2 of the License, or *
14  * (at your option) any later version. *
15  * *
16  ***************************************************************************/
17 
18 #ifndef QGSRASTERFILEWRITERTASK_H
19 #define QGSRASTERFILEWRITERTASK_H
20 
21 #include "qgis_core.h"
22 #include "qgstaskmanager.h"
23 #include "qgsrasterfilewriter.h"
25 #include "qgsrasterinterface.h"
26 #include "qgsrasterpipe.h"
27 
38 class CORE_EXPORT QgsRasterFileWriterTask : public QgsTask
39 {
40  Q_OBJECT
41 
42  public:
43 
51  Q_DECL_DEPRECATED QgsRasterFileWriterTask( const QgsRasterFileWriter &writer, QgsRasterPipe *pipe SIP_TRANSFER,
52  int columns, int rows,
53  const QgsRectangle &outputExtent,
55 
56 
64  QgsRasterFileWriterTask( const QgsRasterFileWriter &writer, QgsRasterPipe *pipe SIP_TRANSFER,
65  int columns, int rows,
66  const QgsRectangle &outputExtent,
68  const QgsCoordinateTransformContext &transformContext
69  );
70 
71  void cancel() override;
72 
73  signals:
74 
79  void writeComplete( const QString &outputUrl );
80 
85  void errorOccurred( int error );
86 
87  protected:
88 
89  bool run() override;
90  void finished( bool result ) override;
91 
92  private:
93 
94  QgsRasterFileWriter mWriter;
95  int mRows = 0;
96  int mColumns = 0;
97  QgsRectangle mExtent;
99  std::unique_ptr< QgsRasterPipe > mPipe;
100 
101  QString mDestFileName;
102 
103  std::unique_ptr< QgsRasterBlockFeedback > mFeedback;
104 
106 
107  QgsCoordinateTransformContext mTransformContext;
108 
109 };
110 
111 #endif //QGSRASTERFILEWRITERTASK_H
QgsTask task which performs a QgsRasterFileWriter layer saving operation as a background task...
A rectangle specified with double values.
Definition: qgsrectangle.h:41
Base class for processing modules.
Definition: qgsrasterpipe.h:46
const QgsCoordinateReferenceSystem & crs
Abstract base class for long running background tasks.
#define SIP_TRANSFER
Definition: qgis_sip.h:36
Contains information about the context in which a coordinate transform is executed.
#define SIP_DEPRECATED
Definition: qgis_sip.h:99
virtual void cancel()
Notifies the task that it should terminate.
This class represents a coordinate reference system (CRS).
virtual void finished(bool result)
If the task is managed by a QgsTaskManager, this will be called after the task has finished (whether ...
virtual bool run()=0
Performs the task&#39;s operation.
The raster file writer which allows you to save a raster to a new file.