posts - 41,  comments - 90,  trackbacks - 0
            2010年12月6日

          Android老大哥安迪魯賓近日在發布2.3姜餅系統和Nexus S的時候曾演示了最新版本的Google Maps 5.0手機地圖,最大的變化就是采用了全3D地圖。

          在新版手機地圖中,矢量圖將替換原本的2D畫面為用戶呈現出全新的3D界面,用戶可以自由的轉動和縮放。此外用戶還將會獲得離線地圖瀏覽功能,不用在瀏覽地圖時保持在線狀態。

          Google現在在其官方手機頻道又放出了一段用Nexus S運行新版Maps應用的全功能演示,這款軟件將會隨Nexus S上市,之后提供其他設備更新,但是對手機硬件有一定的要求,新款800MHz至1GHz處理器且配有專用圖形核心的手機才能支持3D視圖。



          原文見驅動之家
          http://news.mydrivers.com/1/181/181818.htm
          posted @ 2010-12-12 21:54 天狼 閱讀(614) | 評論 (1)編輯 收藏
          天地圖官方網站提供的二次開發文檔和例子過于簡單,很多關鍵信息沒有給予說明,例如給出了WFS服務接口,卻沒有提供詳細的開發文檔。
          不過這并不影響我們的使用,因為OGC WFS規范包含元數據查詢命令,通過發送getCapabilities請求,我們可以得知服務器提供哪些WFS服務。

          獲取WFS服務器元數據
          http://search.tianditu.com/wfs?request=getCapabilities
          返回信息如下:
          <WFS_Capabilities version="1.0.0" xsi:schemaLocation="http://www.opengis.net/wfs http://schemas.opengeospatial.net//wfs/1.0.0/WFS-capabilities.xsd">
          <Service>
          <Name>GeoGlobe WFS</Name>
          <Title>GeoGlobe網絡要素服務器</Title>
          <Abstract>武大吉奧信息技術有限公司GeoGlobe網絡要素服務器</Abstract>
          <KeywordList/>
          <OnlineResource>http://search.tianditu.com:80/wfs</OnlineResource>
          </Service>
          <Capability>
          <Request>
          <GetCapabilities>
          <DCPType>
          <HTTP>
          <Get onlineResource="http://search.tianditu.com:80/wfs"/>
          </HTTP>
          </DCPType>
          </GetCapabilities>
          <GetFeature>
          <ResultFormat>
          <GML2/>
          </ResultFormat>
          <DCPType>
          <HTTP>
          <Get onlineResource="http://search.tianditu.com:80/wfs"/>
          <Post onlineResource="http://search.tianditu.com:80/wfs"/>
          </HTTP>
          </DCPType>
          </GetFeature>
          <DescribeFeatureType>
          <SchemaDescriptionLanguage>
          <XMLSCHEMA/>
          </SchemaDescriptionLanguage>
          <DCPType>
          <HTTP>
          <Get onlineResource="http://search.tianditu.com:80/wfs"/>
          </HTTP>
          </DCPType>
          </DescribeFeatureType>
          </Request>
          <VendorSpecificCapabilities/>
          </Capability>
          <FeatureTypeList>
          <Operations>
          <Query/>
          </Operations>
          <FeatureType>
          <Name>DOMAIN_POI_NEW</Name>
          <Title>DOMAIN_POI_NEW</Title>
          <Abstract>DOMAIN_POI_NEW</Abstract>
          <Keywords>DOMAIN_POI_NEW</Keywords>
          <SRS>EPSG:4326</SRS>
          <LatLongBoundingBox minx="-180.0" miny="-90.0" maxx="180.0" maxy="90.0"/>
          </FeatureType>
          <FeatureType>
          <Name>iso19112:SI_Gazetteer</Name>
          <Title>iso19112:SI_Gazetteer</Title>
          <SRS>EPSG:4326</SRS>
          <LatLongBoundingBox minx="-180.0" miny="-90.0" maxx="180.0" maxy="90.0"/>
          </FeatureType>
          </FeatureTypeList>
          <ogc:Filter_Capabilities>
          <ogc:Spatial_Capabilities>
          <ogc:Spatial_Operators>
          <ogc:BBOX/>
          <ogc:Equals/>
          <ogc:Disjoint/>
          <ogc:Intersect/>
          <ogc:Touches/>
          <ogc:Crosses/>
          <ogc:Within/>
          <ogc:Contains/>
          <ogc:Overlaps/>
          <ogc:Beyond/>
          </ogc:Spatial_Operators>
          </ogc:Spatial_Capabilities>
          <ogc:Scalar_Capabilities>
          <ogc:Logical_Operators/>
          <ogc:Comparison_Operators>
          <ogc:Simple_Comparisons/>
          <ogc:Like/>
          <ogc:Between/>
          </ogc:Comparison_Operators>
          </ogc:Scalar_Capabilities>
          </ogc:Filter_Capabilities>
          </WFS_Capabilities>

          返回信息包含了WFS服務器的開發單位(武大吉奧),WFS圖層的名稱(DOMAIN_POI_NEW和iso19112:SI_Gazetteer),支持的邏輯操作符和空間操作符。

          繼續測試
          http://search.tianditu.com/wfs?request=GetFeature&version=1.0.0&typeName=DOMAIN_POI_NEW&BBOX=105.99,29.99,106,30
          返回
          <wfs:FeatureCollection xsi:schemaLocation="http://www.opengis.net/wfs WFS_Basic.xsd http://www.geostart.com.cn/geoglobe describe.xsd">
          <gml:boundedBy>
          <gml:Box>
          <gml:coordinates>-180.0,-90.0 180.0,90.0</gml:coordinates>
          </gml:Box>
          </gml:boundedBy>
          <gml:featureMember>
          <DOMAIN_POI_NEW>
          <OID>6764930</OID>
          <Geometry>
          <gml:Point srsName="-1">
          <gml:coordinates>105.999183,29.995258</gml:coordinates>
          </gml:Point>
          </Geometry>
          <DOMAINNAME>梅子村</DOMAINNAME>
          <DOMAINCODE>1CHN50022400000130172</DOMAINCODE>
          <NLEVEL>16</NLEVEL>
          <X>105.999183</X>
          <Y>29.995258</Y>
          <COLDATE/>
          <NAMETIME/>
          <ENDTIME/>
          <CLASSID/>
          <STANDARDNAME>亞洲中國重慶市銅梁縣梅子村</STANDARDNAME>
          <TELEPHONE/>
          <ADDRESS/>
          <KIND>BB80</KIND>
          <ZIPCODE/>
          <ADMINCODE>500224</ADMINCODE>
          <POI_ID>5000000130172</POI_ID>
          <PID/>
          <DATATYPE>chinapoi</DATATYPE>
          <FENAME/>
          <locationType>
          <SI_LocationType>
          <name>DOMAIN_POI_NEW</name>
          </SI_LocationType>
          </locationType>
          </DOMAIN_POI_NEW>
          </gml:featureMember>
          </wfs:FeatureCollection>

          分析返回的GML數據,可知DOMAIN_POI_NEW是地名圖層,包含名稱、代碼、類別碼等屬性字段。

          將圖層改為iso19112:SI_Gazetteer,沒有返回任何信息,google ISO19112,得到如下解釋:
          DIN EN ISO 19112-2005 地理信息.通過地理標識符的空間定位 標準號: DIN EN ISO 19112-2005 標準名稱: 地理信息.通過地理標識符的空間定位

          得到以上信息后,我們嘗試使用Openlayers獲取,即全國地名數據庫。

          通過URL(GET方式)訪問“天地圖”WFS服務,可以使用OpenLayers.Request.GET類,示例代碼如下:
             //使用FEATUREID查詢

             new OpenLayers.Request.GET( {
                  url : "http://search.tianditu.com/wfs?request=GetFeature",
                  params: {
                      typeName: "DOMAIN_POI_NEW",
                      FEATUREID: "DOMAIN_POI_NEW.6649356"
                  },
                  callback : handler
              });


             //使用BBOX查詢

              new OpenLayers.Request.GET( {
                  url : "http://search.tianditu.com/wfs?request=GetFeature",
                  params: {
                      typeName: "DOMAIN_POI_NEW",
                      BBOX: "105.99,29.99,106,30"  //map.getExtent().toBBOX()
                  },
                  callback : handler
              });


          說明:
          url WFS服務器地址,必須加上?request=GetFeature
          typeName 圖層名稱
          FEATUREID WFS的圖元ID,采用標準格式: [圖層名].[OID編號]
          BBOX 指定區域查詢,注意不要設置過大,否則瀏覽器可能失去響應。

          通過POST方式訪問“天地圖”WFS服務,可以使用OpenLayers.Request.POST類,示例代碼如下:

              var xmlPara = "<?xml version='1.0' encoding='UTF-8'?>"
                      + "<wfs:GetFeature maxFeatures='100' service='WFS' version='1.0.0' "
                      + "xmlns:wfs='http://www.opengis.net/wfs' "
                      + "xmlns:gml='http://www.opengis.net/gml' "
                      + "xmlns:ogc='http://www.opengis.net/ogc' "
                      + "xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' "
                      + "xsi:schemaLocation='http://www.opengis.net/wfs http://schemas.opengis.net/wfs/1.0.0/wfs.xsd'>"
                      + "<wfs:Query typeName='iso19112:SI_Gazetteer' srsName='EPSG:4326'>"
                      + "<ogc:Filter xmlns:ogc='http://www.opengis.net/ogc'>"
                      + "<ogc:And><ogc:PropertyIsLike wildCard='*' singleChar='.' escape='!'>"
                      + "<ogc:PropertyName>STANDARDNAME</ogc:PropertyName>"
                      + "<ogc:Literal>*解放碑*</ogc:Literal>"
                      + "</ogc:PropertyIsLike></ogc:And></ogc:Filter>"
                      + "</wfs:Query></wfs:GetFeature>";
              
              var request = OpenLayers.Request.POST( {
                  url : "http://search.tianditu.com/wfs?",
                  data : xmlPara,
                  callback : handler
              });
          };

          說明:

          url WFS服務器地址

          data WFS請求正文,返回的GML由回調函數handler處理

          handler負責處理服務端返回的GML數據,也就是矢量化的地圖數據,根據應用需求編寫代碼,獲取feature的通用代碼如下:
          var g = new OpenLayers.Format.GML();
          var features = g.read(req.responseText);
          for ( var i = 0; i < features.length; ++i) {
             var feature = features[i];
             var geometry = feature.geometry;
             var attributes = feature.attributes;
          }

          定義過濾條件時請使用STANDARDNAME字段,不要使用DOMAINNAME字段,前者應該有索引支持,而后者沒有,查詢速度差別很大。

          經過測試,typeName="DOMAIN_POI_NEW"和typeName="iso19112:SI_Gazetteer"都能返回結果。由于缺少官方文檔說明,不知道這兩個圖層有何區別。

          嘗試使用OpenLayers.Protocol.WFS無法訪問“天地圖”WFS服務,服務器返回: 請求參數[REQUEST]的值為空或不正確。

          提醒: 使用POST查詢時,頁面文件或代碼文件務必保存為utf-8編碼,如果使用gbk、gb2312編碼,漢字地名會變成亂碼,導致javascript代碼錯誤。

          posted @ 2010-12-10 16:22 天狼 閱讀(5969) | 評論 (3)編輯 收藏
          國家測繪局2010年10月21日正式發布中國公眾版國家地理信息公共服務平臺“天地圖”,作為中國境內數據資源最全的地理信息服務網站,“天地圖”將為公眾提供權威、可信、統一的地理信息資源。

          “天地圖”公開開放了地圖數據服務接口,第三方使用者可以直接通過互聯網獲取地圖數據,無需授權認證,在公眾服務信息公開方面可以說是一次非常大的進步。
          “天地圖”的在線服務數據近10TB,以下是“天地圖”提供的在線地理信息數據資源:

          數據類型

          數據源

          級別

          服務地址

          線劃地圖

          全球1:100萬地理底圖

          2-10

          http://tile0.tianditu.com/services/A0512_EMap

          http://tile0.tianditu.com/services/AB0512_Anno

          全國1:25萬公開版數字地形圖

          11-12

          http://tile0.tianditu.com/services/B0627_EMap1112

          全國車載導航

          13-18

          http://tile0.tianditu.com/services/siwei0608

          衛星影像

          全球250米衛星影像 (MODIS)

          2-7

          http://tile0.tianditu.com/services/sbsm0210

          全國15米衛星影像 (ETM)

          8-10

          全國2.5米衛星影像 (P5)

          11-14

          http://tile0.tianditu.com/services/e11

          http://tile0.tianditu.com/services/e12
          http://tile0.tianditu.com/services/e13
          http://tile0.tianditu.com/services/eastdawnall

          地級城市0.6米衛星影像

           (QuickBirdWorldView I、WorldView II)

          15-18

          http://tile0.tianditu.com/services/sbsm1518

          數字高程模型

          全球90X90米數字高程模型

           

          http://tile0.tianditu.com/services/J07098

          地名地址

          全球1:100萬地名地址

           

          http://search.tianditu.com/wfs

          全國1:25萬地名地址


          全國車載導航地名地址


          除地名地址數據使用OGC WFS協議發布外,其他數據全部采用基于OGC WMS-C協議的分級瓦片形式發布,工作原理類似于谷歌地圖和OSM(OpenStreetMap)。

          類似谷歌地圖,“天地圖”為互聯網開發人員提供了二次開發API(武大吉奧開發的GeoGlobe二維地圖API)。

          通過分析GeoGlobe API代碼,發現它源自Openlayers,大部分代碼除了把Openlayers換成GeoSurf外,沒有任何變化。不知道Openlayers項目組就此作何感想。
          正因為如此,我們可以參考OpenLayers.Layer.TileCache和OpenLayers.Layer.XYZ類,編寫一個專用于讀取“天地圖”的TDTLayer類,使Openlayers能夠直接訪問“天地圖”的在線地圖數據。

          “天地圖”采用256×256像素,png格式的地圖瓦片文件,讀取單個文件需要四個參數:T、X、Y、L
          T=瓦片(Tile)名稱,X=瓦片橫向編碼,Y=瓦片縱向編碼,L=瓦片級別
          這個是一個完整的請求示例:http://tile0.tianditu.com/DataServer?T=AB0512_Anno&X=50&Y=12&L=6

          天地圖”地理信息數據資源列表將地圖瓦片分為16級(L=2-18),其中L=2級比例尺最小,對應全球地圖。
          L=2級只有8個瓦片文件,分別是

           X= 0 1 2 3 0 1 2 3
           Y= 0 0 0 0 1 1 1 1
          L=3級有32個瓦片文件,分別是:
           X= 0-7
           Y= 0-3
          L=4級有128個瓦片文件,分別是:
           X= 0-15
           Y= 0-7
          其余各級以此類推,每級的瓦片文件數比前一級增加4倍,其中線劃地圖10級以上,衛星地圖8級以上只提供中國境內的數據,沒有覆蓋全球。

          查看
          GeoGlobe API主代碼GeoSurfJSAPI.js文件(相當于Openlayers.js,可以了解X(x_num)、Y(y_num)、L(level)的生成方法,偽代碼如下:
          level=getLevelForResolution(map.getResolution()); //計算瓦片級別
          coef=TopTileSize.w/Math.pow(2,level); //中間系數
          x_num=this.pyramid.topTileFromX<this.pyramid.topTileToX?Math.round((bounds.left-this.pyramid.topTileFromX)/coef):Math.round((this.pyramid.topTileFromX-bounds.right)/coef);
          y_num=this.pyramid.topTileFromY<this.pyramid.topTileToY?Math.round((bounds.bottom-this.pyramid.topTileFromY)/coef):Math.round((this.pyramid.topTileFromY-bounds.top)/coef);
          根據當前分辨率計算地圖瓦片級別
          function getLevelForResolution(res){
          var ratio=map.getMaxResolution()/res;
          if(ratio<1)return 0;
          for(var level=0;ratio/2>=1;)
          {level++;ratio/=2;}
          return level;
          }

          經過簡單測試,“天地圖”和谷歌地圖在數據上差別不大,二次開發方面借助于強大的Openlayers地圖客戶端引擎不會弱于Google Map API,唯獨在速度上與谷歌地圖存在較大差距,特別是地圖放大到13級-18級時,延遲變得非常明顯,有時甚至無法顯示。
          使用Firebug跟蹤運行發現,大約1/3的地圖瓦片請求超時,導致客戶端讀取失敗。
          “天地圖”目前還處于測試階段,希望相關單位繼續改進和提升服務器端性能,快速穩定的響應大量客戶端發出的并發請求。
          測試中發現,“天地圖”開放的地圖數據服務接口從tile0.tianditu.com一直到tile7.tianditu.com。依次ping 這8個服務接口,tile1到tile7的響應速度相對較快。修改客戶端js代碼,將瓦片地圖請求平均發送給tile0到tile7 八個服務接口,可以有效加快地圖顯示速度。“天地圖”提供的GeoSurfJSAPI.js中已經包含相關代碼,通過給Layer的mirrorUrl屬性賦值,可以均衡讀取指定的多個服務接口,代碼如下:
                                  var layer3 = new GeoSurf.Layer.GlobeTile("siwei0608", "http://tile6.tianditu.com/services/siwei0608", {
                                          transitionEffect: "resize",
                                          topLevel: 13,
                                          bottomLevel: 18,
                                          maxExtent: new GeoSurf.Bounds(100, 27, 110, 34),
                                          mirrorUrls: [
                                              "http://tile1.tianditu.com/services/siwei0608",
                                              "http://tile2.tianditu.com/services/siwei0608",
                                              "http://tile3.tianditu.com/services/siwei0608",
                                              "http://tile4.tianditu.com/services/siwei0608",
                                              "http://tile5.tianditu.com/services/siwei0608",
                                              "http://tile6.tianditu.com/services/siwei0608"
                                          ]
                                      });

          客戶端使用上述讀取策略后,即便放大到17-18級,整幅地圖也能夠完全顯示,速度有明顯的提升。


          posted @ 2010-12-06 14:06 天狼 閱讀(8618) | 評論 (5)編輯 收藏
          主站蜘蛛池模板: 三明市| 同德县| 营山县| 北辰区| 泰来县| 凤冈县| 文登市| 象州县| 霍林郭勒市| 西青区| 卢氏县| 大竹县| 卓尼县| 宜兰市| 措美县| 定西市| 布拖县| 大埔区| 昭觉县| 武隆县| 镇江市| 邓州市| 芜湖市| 洪洞县| 横山县| 资兴市| 平顺县| 绥江县| 定陶县| 满城县| 儋州市| 抚远县| 延边| 嘉定区| 华坪县| 科技| 宁德市| 广汉市| 蓬安县| 安塞县| 沙雅县|