亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? qgswmsprovider.cpp

?? 一個非常好的GIS開源新版本
?? CPP
?? 第 1 頁 / 共 5 頁
字號:
/***************************************************************************  qgswmsprovider.cpp  -  QGIS Data provider for                          OGC Web Map Service layers                             -------------------    begin                : 17 Mar, 2005    copyright            : (C) 2005 by Brendan Morley    email                : morb at ozemail dot com dot au ***************************************************************************//*************************************************************************** *                                                                         * *   This program is free software; you can redistribute it and/or modify  * *   it under the terms of the GNU General Public License as published by  * *   the Free Software Foundation; either version 2 of the License, or     * *   (at your option) any later version.                                   * *                                                                         * ***************************************************************************//* $Id: qgswmsprovider.cpp 7349 2007-11-07 14:18:34Z jef $ */#include "qgslogger.h"#include "qgswmsprovider.h"#include <math.h>#include "qgscoordinatetransform.h"#include "qgsrect.h"#include "qgsspatialrefsys.h"#include "qgshttptransaction.h"#include <QUrl>#include <QImage>#include <QSet>#ifdef _MSC_VER#include <float.h>#define isfinite(x) _finite(x)#endif#ifdef QGISDEBUG#include <QFile>#endifstatic QString WMS_KEY = "wms";static QString WMS_DESCRIPTION = "OGC Web Map Service version 1.3 data provider";static QString DEFAULT_LATLON_CRS = "CRS:84";QgsWmsProvider::QgsWmsProvider(QString const & uri)  : QgsRasterDataProvider(uri),    httpuri(uri),    mHttpProxyHost(0),    mHttpProxyPort(80),    mHttpProxyUser(0),    mHttpProxyPass(0),    httpcapabilitiesresponse(0),    imageCrs(DEFAULT_LATLON_CRS),    cachedImage(0),    cachedViewExtent(0),    cachedPixelWidth(0),    cachedPixelHeight(0),    mCoordinateTransform(0),    extentDirty(TRUE),    mGetFeatureInfoUrlBase(0){  QgsDebugMsg("QgsWmsProvider: constructing with uri '" + uri + "'.");  // assume this is a valid layer until we determine otherwise  valid = true;  // URL can be in 3 forms:  // 1) http://xxx.xxx.xx/yyy/yyy  // 2) http://xxx.xxx.xx/yyy/yyy?  // 3) http://xxx.xxx.xx/yyy/yyy?zzz=www  // Prepare the URI so that we can later simply append param=value  baseUrl = httpuri;  if ( !(baseUrl.contains("?")) )   {    baseUrl.append("?");  }  else if (           (baseUrl.right(1) != "?" )           &&           (baseUrl.right(1) != "&" )          )  {    baseUrl.append("&");  }  QgsDebugMsg("baseUrl = " + baseUrl );//  getServerCapabilities();  //httpuri = "http://www.ga.gov.au/bin/getmap.pl?dataset=national&Service=WMS&Version=1.1.0&Request=GetMap&"  //      "BBox=130,-40,160,-10&SRS=EPSG:4326&Width=400&Height=400&Layers=railways&Format=image/png";  //httpuri = "http://www.ga.gov.au/bin/getmap.pl?dataset=national&";        /*  // 302-redirects to:          uri = "http://www.ga.gov.au/bin/mapserv40?"        "map=/public/http/www/docs/map/national/national.map&"        "map_logo_status=off&map_coast_status=off&Service=WMS&Version=1.1.0&"        "Request=GetMap&BBox=130,-40,160,-10&SRS=EPSG:4326&Width=800&"        "Height=800&Layers=railways&Format=image/png";*/  //  downloadMapURI(uri);  QgsDebugMsg("QgsWmsProvider: exiting constructor.");}QgsWmsProvider::~QgsWmsProvider(){  QgsDebugMsg("QgsWmsProvider: deconstructing.");  // Dispose of any cached image as created by draw()  if (cachedImage)  {    delete cachedImage;  }  if (mCoordinateTransform)  {    delete mCoordinateTransform;  }}QString QgsWmsProvider::proxyHost() const{  return mHttpProxyHost;}int QgsWmsProvider::proxyPort() const{  return mHttpProxyPort;}QString QgsWmsProvider::proxyUser() const{  return mHttpProxyUser;}QString QgsWmsProvider::proxyPass() const{  return mHttpProxyPass;}bool QgsWmsProvider::setProxy(QString const & host,                                          int port,                              QString const & user,                              QString const & pass){  mHttpProxyHost = host;  mHttpProxyPort = port;  mHttpProxyUser = user;  mHttpProxyPass = pass;  return TRUE;}bool QgsWmsProvider::supportedLayers(std::vector<QgsWmsLayerProperty> & layers){  QgsDebugMsg("Entering.");  // Allow the provider to collect the capabilities first.  if (!retrieveServerCapabilities())  {    return FALSE;  }  layers = layersSupported;  QgsDebugMsg("Exiting.");  return TRUE;}QSet<QString> QgsWmsProvider::supportedCrsForLayers(QStringList const & layers){  QSet<QString> crsCandidates;  QStringList::const_iterator i;  for (i = layers.constBegin(); i != layers.constEnd(); ++i)  {    std::vector<QString> crsVector = crsForLayer[*i];    QSet<QString>    crsSet;    // convert std::vector to std::set for set comparisons    for (uint j = 0; j < crsVector.size(); j++)    {      crsSet.insert( crsVector[j] );    }    // first time through?    if ( i == layers.constBegin() )    {      // do initial population of set      crsCandidates = crsSet;    }    else    {      // do lowest common denominator (set intersection)      crsCandidates.intersect(crsSet);    }  }  return crsCandidates;}size_t QgsWmsProvider::layerCount() const{    return 1;                   // XXX properly return actual number of layers} // QgsWmsProvider::layerCount()void QgsWmsProvider::addLayers(QStringList const &  layers,                               QStringList const &  styles){  QgsDebugMsg("Entering with layer list of " + layers.join(", ")              + " and style list of " + styles.join(", ") );  // TODO: Make activeSubLayers a std::map in order to avoid duplicates  activeSubLayers += layers;  activeSubStyles += styles;  // Set the visibility of these new layers on by default  for ( QStringList::const_iterator it  = layers.begin();         it != layers.end();         ++it )   {    activeSubLayerVisibility[*it] = TRUE;     QgsDebugMsg("set visibility of layer '" + (*it) + "' to TRUE.");  }  // now that the layers have changed, the extent will as well.  extentDirty = TRUE;  QgsDebugMsg("Exiting.");}      void QgsWmsProvider::setLayerOrder(QStringList const &  layers){  QgsDebugMsg("Entering.");    activeSubLayers = layers;    QgsDebugMsg("Exiting.");}void QgsWmsProvider::setSubLayerVisibility(QString const & name, bool vis){  activeSubLayerVisibility[name] = vis;}QString QgsWmsProvider::imageEncoding() const{  return imageMimeType;}void QgsWmsProvider::setImageEncoding(QString const & mimeType){  QgsDebugMsg("Setting image encoding to " + mimeType + ".")  imageMimeType = mimeType;}void QgsWmsProvider::setImageCrs(QString const & crs){  QgsDebugMsg("Setting image CRS to " + crs + ".");  if (      (crs != imageCrs)      &&      (! crs.isEmpty() )     )  {    // delete old coordinate transform as it is no longer valid    if (mCoordinateTransform)    {      delete mCoordinateTransform;    }    extentDirty = TRUE;    imageCrs = crs;  }}QImage* QgsWmsProvider::draw(QgsRect  const & viewExtent, int pixelWidth, int pixelHeight){  QgsDebugMsg("Entering.");  QgsDebugMsg("pixelWidth = "  + QString(pixelWidth) );  QgsDebugMsg("pixelHeight = "  + QString(pixelHeight) );#ifdef QGISDEBUG  QgsLogger::debug<QgsRect>("viewExtent: ", viewExtent, __FILE__, __FUNCTION__, __LINE__);#endif  // Can we reuse the previously cached image?  if (      (cachedImage) &&      (cachedViewExtent == viewExtent) &&      (cachedPixelWidth == pixelWidth) &&      (cachedPixelHeight == pixelHeight)     )  {    return cachedImage;  }  // Bounding box in WMS format  QString bbox;  // Warning: does not work with scientific notation  bbox = QString("%1,%2,%3,%4").          arg(viewExtent.xMin(),0,'f').          arg(viewExtent.yMin(),0,'f').          arg(viewExtent.xMax(),0,'f').          arg(viewExtent.yMax(),0,'f');            // Width in WMS format  QString width;  width = width.setNum(pixelWidth);  // Height in WMS format  QString height;  height = height.setNum(pixelHeight);    // Calculate active layers that are also visible.  QgsDebugMsg("Active layer list of "  + activeSubLayers.join(", ")	      + " and style list of "  + activeSubStyles.join(", ") );  QStringList visibleLayers = QStringList();  QStringList visibleStyles = QStringList();  QStringList::Iterator it2  = activeSubStyles.begin();   for ( QStringList::Iterator it  = activeSubLayers.begin();                               it != activeSubLayers.end();                             ++it )   {    if (TRUE == activeSubLayerVisibility.find( *it )->second)    {      visibleLayers += *it;      visibleStyles += *it2;    }    ++it2;  }  QgsDebugMsg("Visible layer list of " + visibleLayers.join(", ")	      + " and style list of "  + visibleStyles.join(", ") );  QString layers = QUrl::toPercentEncoding(visibleLayers.join(","));  QString styles = QUrl::toPercentEncoding(visibleStyles.join(","));  // compose the URL query string for the WMS server.  QString url = baseUrl;  url += "SERVICE=WMS";  url += "&";  url += "VERSION=" + mCapabilities.version;  url += "&";  url += "REQUEST=GetMap";  url += "&";  url += "BBOX=" + bbox;  url += "&";  url += "SRS=" + imageCrs;  url += "&";  url += "WIDTH=" + width;  url += "&";  url += "HEIGHT=" + height;  url += "&";  url += "LAYERS=" + layers;  url += "&";  url += "STYLES=" + styles;  url += "&";  url += "FORMAT=" + imageMimeType;  if(!imageMimeType.contains("jpeg", Qt::CaseInsensitive) && !imageMimeType.contains("jpg", Qt::CaseInsensitive)) //MH: jpeg does not support transparency and some servers complain if jpg and transparent=true    {      url += "&";      url += "TRANSPARENT=TRUE";    }  qWarning(url);  // cache some details for if the user wants to do an identifyAsHtml() later  mGetFeatureInfoUrlBase = baseUrl;  mGetFeatureInfoUrlBase += "SERVICE=WMS";  mGetFeatureInfoUrlBase += "&";  mGetFeatureInfoUrlBase += "VERSION=" + mCapabilities.version;  mGetFeatureInfoUrlBase += "&";  mGetFeatureInfoUrlBase += "REQUEST=GetFeatureInfo";  mGetFeatureInfoUrlBase += "&";  mGetFeatureInfoUrlBase += "BBOX=" + bbox;  mGetFeatureInfoUrlBase += "&";  mGetFeatureInfoUrlBase += "SRS=" + imageCrs;  mGetFeatureInfoUrlBase += "&";  mGetFeatureInfoUrlBase += "WIDTH=" + width;  mGetFeatureInfoUrlBase += "&";  mGetFeatureInfoUrlBase += "HEIGHT=" + height;  mGetFeatureInfoUrlBase += "&";  mGetFeatureInfoUrlBase += "LAYERS=" + layers;  mGetFeatureInfoUrlBase += "&";  mGetFeatureInfoUrlBase += "STYLES=" + styles;  mGetFeatureInfoUrlBase += "&";  mGetFeatureInfoUrlBase += "FORMAT=" + imageMimeType;  if(!imageMimeType.contains("jpeg", Qt::CaseInsensitive) && !imageMimeType.contains("jpg", Qt::CaseInsensitive))    {      mGetFeatureInfoUrlBase += "&";      mGetFeatureInfoUrlBase += "TRANSPARENT=TRUE";    }  QByteArray imagesource;  imagesource = retrieveUrl(url);  if (imagesource.isEmpty())  {    return 0;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕成人网| 中文字幕在线一区| 99麻豆久久久国产精品免费优播| 亚洲一区二区三区在线看| 精品国产123| 欧美日韩国产精选| 成人激情免费网站| 韩国成人精品a∨在线观看| 洋洋成人永久网站入口| 国产精品免费aⅴ片在线观看| 91精品国产综合久久精品app | ㊣最新国产の精品bt伙计久久| 69成人精品免费视频| 91麻豆国产福利精品| 国产成人午夜99999| 黄一区二区三区| 日韩精彩视频在线观看| 亚洲综合网站在线观看| 国产精品久久三区| 久久人人爽人人爽| 精品久久久久久无| 欧美一区二区三区爱爱| 欧美日韩视频在线第一区| 欧洲激情一区二区| 91视频免费看| av午夜一区麻豆| 高潮精品一区videoshd| 国产精品一区免费视频| 国产在线精品免费| 久久电影网站中文字幕| 日本中文字幕一区二区视频| 性感美女久久精品| 一区二区三区四区视频精品免费 | 亚洲精品福利视频网站| ●精品国产综合乱码久久久久| 国产日韩欧美精品综合| 国产日韩欧美精品综合| 国产午夜精品一区二区三区四区 | 中文字幕中文字幕在线一区| 中文字幕免费不卡| 国产精品久久久一区麻豆最新章节| 国产欧美日韩一区二区三区在线观看| 精品国产一区二区三区久久久蜜月| 制服.丝袜.亚洲.另类.中文| 欧美一级久久久久久久大片| 日韩精品一区二区三区蜜臀| 精品国产乱码久久久久久蜜臀 | 亚洲国产日韩a在线播放| 亚洲曰韩产成在线| 天堂久久久久va久久久久| 日韩av电影一区| 国产在线精品免费av| 国产东北露脸精品视频| 成人av网站在线观看免费| 91美女在线视频| 欧美日韩视频在线第一区| 日韩午夜av一区| 久久综合久久99| 中文字幕av不卡| 一区二区在线观看视频| 婷婷丁香久久五月婷婷| 精品伊人久久久久7777人| 国产精品一二三区在线| 99国产欧美久久久精品| 欧美日韩国产美女| 2023国产精品| 国产精品另类一区| 亚洲永久精品国产| 99re热视频精品| 91蝌蚪porny成人天涯| 欧美日本国产视频| 精品成人免费观看| 中文字幕一区二区日韩精品绯色| 亚洲午夜久久久| 国内精品视频一区二区三区八戒| 成人av在线网站| 欧美精品国产精品| 久久精品视频网| 亚洲精品水蜜桃| 乱中年女人伦av一区二区| 国产99一区视频免费| 欧美探花视频资源| 久久久亚洲综合| 亚洲高清一区二区三区| 国产精品一区在线观看你懂的| 一本色道**综合亚洲精品蜜桃冫| 精品美女一区二区| 亚洲一区二区综合| 国产精品亚洲第一区在线暖暖韩国| 99精品在线观看视频| 欧美一级片在线观看| 中文字幕字幕中文在线中不卡视频| 亚洲444eee在线观看| 不卡欧美aaaaa| 欧美一卡2卡3卡4卡| 亚洲人成伊人成综合网小说| 久久66热re国产| 欧美日韩国产高清一区| 国产精品久久久久久久久快鸭 | 高清免费成人av| 欧美一区二区视频在线观看2022| 亚洲色图清纯唯美| 狠狠色丁香婷婷综合久久片| 欧美性受xxxx| 国产精品福利一区| 国产又粗又猛又爽又黄91精品| 欧美麻豆精品久久久久久| 亚洲视频一区二区在线观看| 国产不卡视频在线播放| 日韩欧美久久一区| 亚洲成人自拍偷拍| 色美美综合视频| 1024国产精品| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 日韩电影在线观看网站| 91免费版pro下载短视频| 国产精品入口麻豆九色| 国产一区二区三区四区在线观看| 欧美精品丝袜中出| 亚洲午夜影视影院在线观看| 色婷婷久久久亚洲一区二区三区 | 欧美激情一区二区三区| 九九国产精品视频| 精品国产一区二区三区忘忧草| 日本va欧美va欧美va精品| 欧美放荡的少妇| 亚洲成人激情社区| 欧美影院一区二区三区| 一区二区三区不卡视频在线观看 | 久久久久一区二区三区四区| 久久99精品国产.久久久久| 欧美探花视频资源| 亚洲成人av一区二区| 欧美日韩一区二区不卡| 午夜激情久久久| 欧美精品视频www在线观看| 婷婷六月综合亚洲| 欧美一级欧美三级在线观看| 美洲天堂一区二卡三卡四卡视频| 亚洲视频在线一区二区| 91麻豆swag| 亚洲国产中文字幕| 欧美一区二区三区白人| 精品亚洲免费视频| 久久精品视频免费| 成人精品高清在线| 国产精品第四页| 91麻豆蜜桃一区二区三区| 亚洲一区av在线| 欧美日本乱大交xxxxx| 免费人成精品欧美精品| 久久先锋影音av鲁色资源网| 成人网在线播放| 亚洲精品网站在线观看| 欧美精品久久天天躁| 久草在线在线精品观看| 国产日韩av一区二区| 91丨porny丨户外露出| 亚洲最新在线观看| 日韩欧美电影一二三| 国产盗摄女厕一区二区三区| 亚洲欧洲日韩av| 欧美日韩mp4| 国产精品 欧美精品| 亚洲三级电影全部在线观看高清| 欧美性大战久久久久久久| 日本午夜精品视频在线观看 | 国产成人精品亚洲777人妖 | 精品99一区二区| av电影在线观看一区| 视频一区二区不卡| 久久嫩草精品久久久精品| 色8久久精品久久久久久蜜| 丝袜美腿亚洲综合| 久久久久久久久伊人| 91搞黄在线观看| 国产一区免费电影| 亚洲精品久久久蜜桃| 26uuu亚洲综合色欧美| 91麻豆.com| 国产毛片精品视频| 亚洲在线视频一区| 久久久久久久久久美女| 欧美亚洲免费在线一区| 国产高清无密码一区二区三区| 亚洲最新在线观看| 国产精品沙发午睡系列990531| 欧美色成人综合| 成人h动漫精品一区二| 青青国产91久久久久久| 日韩一区欧美一区| 精品国产免费人成电影在线观看四季| 91丨九色porny丨蝌蚪| 国产麻豆精品在线观看| 亚洲大片在线观看| 亚洲人成小说网站色在线| 精品播放一区二区| 欧美一区二区黄色| 在线看国产一区| 99久久久国产精品免费蜜臀|