簡體   English   中英

允許選擇國家/地區並僅放大到國家/地區級別

[英]Allow selection of country & zoom in only to country level

我想使用谷歌地圖,但只能在國家/地區級別使用,即我想在單個窗口中顯示整個世界地圖,並且用戶應該可以在單擊國家/地區時選擇任何國家,也應該可以顯示一些彈出窗口。想獲取從JS中選擇的國家/地區的值。 請指導我。 我沒有對此谷歌,但沒有完整的信息。

結合以下兩個示例:

  1. 放大至國家
  2. 可點擊的世界地圖

點擊放大到國家

var map=null;
var geocoder = null;
var kmlLayer = null;
var infoWindow = new google.maps.InfoWindow(); // InfoWindow

function openIW(layerEvt) {
  if (layerEvt.row) {
    var content = layerEvt.row['admin'].value;
  } else if (layerEvt.featureData) {
    var content = layerEvt.featureData.name;
  }
  document.getElementById('info').innerHTML = "you clicked on:<br>"+content;
  findAddress(content);
}

function initialize() {
  geocoder = new google.maps.Geocoder();
  var chicago = new google.maps.LatLng(36.4278,-15.9);
  var myOptions = {
    zoom: 2,
    center: chicago,
    mapTypeId: google.maps.MapTypeId.ROADMAP
  }

  map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);

  google.maps.event.addListener(map, "click", function() {
    document.getElementById('info').innerHTML = "";
  });


  kmlLayer = new google.maps.KmlLayer('http://www.geocodezip.com/geoxml3_test/world_countries_kml.xml', {preserveViewport: true, suppressInfoWindows: true} );
  kmlLayer.setMap(map);

  google.maps.event.addListener(kmlLayer, 'click', openIW);

}    

function findAddress(address) {
  if ((address != '') && geocoder) {
    geocoder.geocode( { 'address': address}, function(results, status) {
      if (status == google.maps.GeocoderStatus.OK) {
         if (results && results[0] && results[0].geometry && results[0].geometry.viewport) 
           map.fitBounds(results[0].geometry.viewport);
         } else {
           alert("No results found");
         }
      } else {
        alert("Geocode was not successful for the following reason: " + status);
      }
    });
  }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM