マップを含む Web アプリがあります。マップ上のさまざまなレイヤーのオンとオフを切り替える、小さなカスタム マップ コントロールを追加しました。現在、レイヤーは 2 つしかありませんが、ほとんどのブラウザーでうまく機能します。
IE8+7 を除く。オンにすると、マップにレイヤーが表示されません。私が知る限り、マップは kmz/kml ファイルをロードしています (preserveViewport が false に設定されている場合、マップは正しい場所に移動します) が、それらは表示されません。1 つのレイヤーにはポリラインが含まれ、もう 1 つのレイヤーにはマーカーが含まれます。私が使用するコードは以下のとおりです。
function someFunction() {
//code to initialise map etc goes here...
var layers = [];
//Create 1st layer
var exchangeslayer = new google.maps.KmlLayer('http://link.to.file/exchanges.kmz'
suppressInfoWindows: true,
preserveViewport: true
});
layers.push({name: "Exchanges", layer: exchangeslayer});
//Code to create second layer
var nyclayer = new google.maps.KmlLayer('http://www.nyc.gov/html/dot/downloads/misc/cityracks.kml'
suppressInfoWindows: true,
preserveViewport: false
});
layers.push({name: "NY City Tracks", layer: nyclayer});
addCustomLayerControls(layers);
}
function addCustomLayerControls(layers) {
//there is code here that would generate the divs for the custom map control
var container; //container is a div element created via javascript
for (var i = 0; i < layers.length; i++) {
this.addLayerLabelToContainer(layers[i], container);
}
//some more code
}
function addLayerLabelToContainer(layer, container) {
var map; //Assume I get a reference to the map
//some code here to make pretty labels for the map controls...
var layerLabel; // layerLabel is a div element created via javascript
google.maps.event.addDomListener(layerLabel, 'click', function() {
if(layer.layer.map == null) {
layer.layer.setMap(map);
} else {
layer.layer.setMap(null);
}
});
}