22 #include <QRegularExpression>    34     return QStringLiteral( 
"1.3.0" );
    48       static QSet<QString> sFilter
    50         QStringLiteral( 
"REQUEST" ),
    51         QStringLiteral( 
"VERSION" ),
    52         QStringLiteral( 
"SERVICE" ),
    53         QStringLiteral( 
"LAYERS" ),
    54         QStringLiteral( 
"STYLES" ),
    55         QStringLiteral( 
"SLD_VERSION" ),
    56         QStringLiteral( 
"_DC" )
    62       for ( 
auto param : q.queryItems() )
    64         if ( sFilter.contains( param.first.toUpper() ) )
    65           q.removeAllQueryItems( param.first );
    77     if ( format.compare( QLatin1String( 
"png" ), Qt::CaseInsensitive ) == 0 ||
    78          format.compare( QLatin1String( 
"image/png" ), Qt::CaseInsensitive ) == 0 )
    82     else if ( format.compare( QLatin1String( 
"jpg " ), Qt::CaseInsensitive ) == 0  ||
    83               format.compare( QLatin1String( 
"image/jpeg" ), Qt::CaseInsensitive ) == 0 )
    90       QRegularExpression modeExpr = QRegularExpression( QStringLiteral( 
"image/png\\s*;\\s*mode=([^;]+)" ),
    91                                     QRegularExpression::CaseInsensitiveOption );
    93       QRegularExpressionMatch match = modeExpr.match( format );
    94       QString mode = match.captured( 1 );
    95       if ( mode.compare( QLatin1String( 
"16bit" ), Qt::CaseInsensitive ) == 0 )
    97       if ( mode.compare( QLatin1String( 
"8bit" ), Qt::CaseInsensitive ) == 0 )
    99       if ( mode.compare( QLatin1String( 
"1bit" ), Qt::CaseInsensitive ) == 0 )
   109     layersList = parameters.value( QStringLiteral( 
"LAYER" ) ).split( 
',', QString::SkipEmptyParts );
   110     layersList = layersList + parameters.value( QStringLiteral( 
"LAYERS" ) ).split( 
',', QString::SkipEmptyParts );
   111     stylesList = parameters.value( QStringLiteral( 
"STYLE" ) ).split( 
',', QString::SkipEmptyParts );
   112     stylesList = stylesList + parameters.value( QStringLiteral( 
"STYLES" ) ).split( 
',', QString::SkipEmptyParts );
   124     switch ( outputFormat )
   128         contentType = 
"image/png";
   133         QVector<QRgb> colorTable;
   138         QImage img256 = img.convertToFormat( QImage::Format_ARGB32 );
   140         result = img256.convertToFormat( QImage::Format_Indexed8, colorTable,
   141                                          Qt::ColorOnly | Qt::ThresholdDither |
   142                                          Qt::ThresholdAlphaDither | Qt::NoOpaqueDetection );
   144       contentType = 
"image/png";
   148         result = img.convertToFormat( QImage::Format_ARGB4444_Premultiplied );
   149         contentType = 
"image/png";
   153         result = img.convertToFormat( QImage::Format_Mono,
   154                                       Qt::MonoOnly | Qt::ThresholdDither |
   155                                       Qt::ThresholdAlphaDither | Qt::NoOpaqueDetection );
   156         contentType = 
"image/png";
   161         contentType = 
"image/jpeg";
   170     if ( outputFormat != 
UNKN )
   172       response.
setHeader( 
"Content-Type", contentType );
   173       if ( saveFormat == 
"JPEG" )
   175         result.save( response.
io(), qPrintable( saveFormat ), imageQuality );
   179         result.save( response.
io(), qPrintable( saveFormat ) );
   185                                  QString( 
"Output format '%1' is not supported in the GetMap request" ).arg( formatStr ) );
   191     QStringList lst = bboxStr.split( 
',' );
   192     if ( lst.count() != 4 )
   197     for ( 
int i = 0; i < 4; i++ )
   199       lst[i].replace( 
' ', 
'+' );
   200       d[i] = lst[i].toDouble( &ok );
 
virtual void setHeader(const QString &key, const QString &value)=0
Set Header entry Add Header entry to the response Note that it is usually an error to set Header afte...
A rectangle specified with double values. 
SERVER_EXPORT QString wmsServiceUrl(const QgsProject &project)
Returns the WMS service url defined in a QGIS project. 
QUrl originalUrl() const 
Returns the request url as seen by the web server, by default this is equal to the url seen by QGIS s...
Exception class for WMS service exceptions. 
void writeImage(QgsServerResponse &response, QImage &img, const QString &formatStr, int imageQuality)
Write image response. 
QgsRectangle parseBbox(const QString &bboxStr)
Parse bbox parameter. 
static void logMessage(const QString &message, const QString &tag=QString(), Qgis::MessageLevel level=Qgis::Warning, bool notifyUser=true)
Adds a message to the log instance (and creates it if necessary). 
QString ImplementationVersion()
Returns the highest version supported by this implementation. 
Reads and writes project states. 
void readLayersAndStyles(const QgsServerRequest::Parameters ¶meters, QStringList &layersList, QStringList &stylesList)
Reads the layers and style lists from the parameters LAYERS and STYLES. 
Median cut implementation. 
void medianCut(QVector< QRgb > &colorTable, int nColors, const QImage &inputImage)
Median cut implementation used when reducing RGB colors to palletized colors. 
QgsServerRequest Class defining request interface passed to services QgsService::executeRequest() met...
virtual QIODevice * io()=0
Returns the underlying QIODevice. 
QUrl serviceUrl(const QgsServerRequest &request, const QgsProject *project)
Returns WMS service URL. 
ImageOutputFormat
Supported image output format. 
QgsServerResponse Class defining response interface passed to services QgsService::executeRequest() m...
ImageOutputFormat parseImageFormat(const QString &format)
Parse image format parameter. 
QMap< QString, QString > Parameters