西西軟件園多重安全檢測下載網(wǎng)站、值得信賴的軟件下載站!
軟件
軟件
文章
搜索

首頁編程開發(fā)其它知識 → 架設(shè)地圖圖片緩存服務(wù)器解決GoogleMap地圖圖片請求數(shù)據(jù)限制

架設(shè)地圖圖片緩存服務(wù)器解決GoogleMap地圖圖片請求數(shù)據(jù)限制

相關(guān)軟件相關(guān)文章發(fā)表評論 來源:liongis時間:2011/12/11 2:04:04字體大。A-A+

作者:liongis點擊:116次評論:0次標(biāo)簽: GoogleMap

  • 類型:修改器(游戲工具)大小:16.2M語言:中文 評分:2.5
  • 標(biāo)簽:
立即下載

最近GoogleMap對于通過API訪問的地圖服務(wù)的請求不再是完全免費,用戶每日每個API最多可以生成25000個地圖下載任務(wù),對于地圖圖片則限制在2500張。這會對很多使用Google Map API開發(fā)的應(yīng)用程序有很大的影響,特別是在國內(nèi)。也到不少朋友的尋問,完全突破的方式還沒有,想了一種變通的方式來解決。

這個辦法就是在我們的客戶端和Google Map地圖服務(wù)器之間架設(shè)一臺地圖圖片緩存服務(wù)器,把需要的地圖,先緩存在地圖圖片緩存服務(wù)器上,客戶端請求時,先從緩存服務(wù)器上去獲取,如果沒有,再從Google Map地圖服務(wù)器上獲取,保存在本地,再從本地返回給客戶端,這樣就可以減少對Google Map地圖圖片服務(wù)器的請求次數(shù)。

當(dāng)然,這種方法在開始的時候,請求量仍然會很大,不過到后面,數(shù)量就會越來越少。

大概流程如下:

流程已經(jīng)很簡單了,中間實現(xiàn)的方式也不復(fù)雜,只要能實現(xiàn)上面的功能,使用哪個平臺不重要,下面是前端自己定義地圖類型的方式:

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 5 <title>Google Maps JavaScript API v3 Example: Image MapTypes</title>
 6 <link href="mapfiles/css/default.css" rel="stylesheet" type="text/css" />
 7 <script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=false"></script> 
 8 <script>  
 9 function LocalMapType() {}
10   
11   LocalMapType.prototype.tileSize = new google.maps.Size(256, 256);
12   LocalMapType.prototype.maxZoom = 15;
13   LocalMapType.prototype.minZoom = 8;
14   LocalMapType.prototype.name = "本地地圖";
15   LocalMapType.prototype.alt = "顯示本地地圖數(shù)據(jù)";
16   LocalMapType.prototype.getTile = function(coord, zoom, ownerDocument) {
17 var img = ownerDocument.createElement("img");
18       img.style.width = this.tileSize.width + "px";
19       img.style.height = this.tileSize.height + "px";
20       img.onerror = function(){
21         img.src = "c:\\Map\\nomap.png";
22       }
23       
24 //var strURL = "C:\\Map\\Google_Hybrid\\" + zoom + "\\" + coord.x + "\\" + coord.y + ".png";
25 var strURL = "http://localhost:8080/gettitle/gettitle.png?x=" + coord.x + "&y=" + coord.y + "&z=" + zoom; 
26       img.src = strURL;
27 return img;
28   };
29     
30 var localMapType = new LocalMapType();
31  
32 function initialize() {
33 var myLatlng = new google.maps.LatLng(36.867078, 119.286772);
34 var myOptions = {
35       center: myLatlng,
36       zoom: 11,
37       streetViewControl: false,
38       mapTypeControlOptions: {
39             mapTypeIds: ["local"]
40         }
41     };
42  
43 var map = new google.maps.Map(document.getElementById("map_canvas"),
44         myOptions);
45 
46     map.mapTypes.set('local', localMapType);
47     map.setMapTypeId('local');
48   }
49  
50 </script>
51 </head>
52 <body onload="initialize()">
53   <div id="map_canvas" style="width: 640px; height: 480px;"></div>
54 </body>
55 </html>

    相關(guān)評論

    閱讀本文后您有什么感想? 已有人給出評價!

    • 8 喜歡喜歡
    • 3 頂
    • 1 難過難過
    • 5 囧
    • 3 圍觀圍觀
    • 2 無聊無聊

    熱門評論

    最新評論

    發(fā)表評論 查看所有評論(0)

    昵稱:
    表情: 高興 可 汗 我不要 害羞 好 下下下 送花 屎 親親
    字?jǐn)?shù): 0/500 (您的評論需要經(jīng)過審核才能顯示)