Rem*_*ure 7 javascript google-maps polygon kml knockout.js
我创建了一个Knockout绑定,能够使用谷歌地图切换KML图层,但解决方案似乎有点慢,"闪烁".如何避免在每个切换上重新创建地图和图层?
可在此处找到正在运行的演示
var ViewModel = function () {
var self = this;
self.mapOptions = {
center: new google.maps.LatLng(60.390791, 5.306396),
zoom: 2
};
self.levels = [{
text: "Type 1",
countries: ko.observableArray([
'https://dl.dropbox.com/u/2873968/countries-kml/afghanistan.kml',
'https://dl.dropbox.com/u/2873968/countries-kml/algeria.kml',
'https://dl.dropbox.com/u/2873968/countries-kml/bahrain.kml',
'https://dl.dropbox.com/u/2873968/countries-kml/burundi.kml',
'https://dl.dropbox.com/u/2873968/countries-kml/ca_republic.kml',
'https://dl.dropbox.com/u/2873968/countries-kml/cameroon.kml',
'https://dl.dropbox.com/u/2873968/countries-kml/chad.kml',
'https://dl.dropbox.com/u/2873968/countries-kml/colombia.kml',
'https://dl.dropbox.com/u/2873968/countries-kml/dr_congo.kml']),
isVisible: ko.observable(false)
}, {
text: "Type 2",
countries: ko.observableArray([
'https://dl.dropbox.com/u/2873968/countries-kml/russia.kml',
'https://dl.dropbox.com/u/2873968/countries-kml/sudan.kml',
'https://dl.dropbox.com/u/2873968/countries-kml/syria.kml',
'https://dl.dropbox.com/u/2873968/countries-kml/thailand.kml',
'https://dl.dropbox.com/u/2873968/countries-kml/venezuela.kml',
'https://dl.dropbox.com/u/2873968/countries-kml/yemen.kml',
'https://dl.dropbox.com/u/2873968/countries-kml/zimbabwe.kml']),
isVisible: ko.observable(true)
}];
};
ko.bindingHandlers.KML = {
update: function (element, valueAccessor) {
var data = ko.utils.unwrapObservable(valueAccessor()),
mapOptions = ko.utils.unwrapObservable(data.mapOptions) || {},
levels = ko.utils.unwrapObservable(data.levels) || [],
map = new google.maps.Map(element, mapOptions);
for (var i = 0; i < levels.length; i++) {
var level = levels[i],
isVisible = level.isVisible(),
text = level.text,
countries = ko.utils.unwrapObservable(level.countries) || [];
for (var y = 0; y < countries.length; y++) {
var country = countries[y],
layer = new google.maps.KmlLayer(country, {
map: map,
preserveViewport: true
});
if (isVisible) {
layer.setMap(map);
} else {
layer.setMap(null);
}
}
}
}
};
ko.applyBindings(new ViewModel());
Run Code Online (Sandbox Code Playgroud)
首先要做的至少是使用init回调。
ko.bindingHandlers.KML = {
init: function (element, valueAccessor) {
var data = ko.utils.unwrapObservable(valueAccessor()),
mapOptions = ko.utils.unwrapObservable(data.mapOptions) || {},
levels = ko.utils.unwrapObservable(data.levels) || [],
map = new google.maps.Map(element, mapOptions);
// now that the map is created, create layers for each level in each country
// set the layers visibility
}
}
Run Code Online (Sandbox Code Playgroud)
然后,在update回调中您只需要更新图层的可见性
ko.bindingHandlers.KML = {
init: function (element, valueAccessor) {
},
update: function(element, valueAccessor){
// get data from valueAccessor
// for each level, set visibility
}
}
Run Code Online (Sandbox Code Playgroud)
但是,现在我们没有可在update回调中使用的地图。幸运的是,我们可以在 BindingHanlder 中创建自己的对象,所以让我们这样做:
ko.bindingHandlers.KML = {
config : {
map: {}
},
init: function (element, valueAccessor) {
var map = new google.maps.Map(element, mapOptions);
// now we can store our map;
ko.bindingHandlers.KML.config.map = map;
},
update: function(element, valueAccessor){
// and use it in the update
var map ko.bindingHandlers.KML.config.map;
}
}
Run Code Online (Sandbox Code Playgroud)
这也意味着我们也可以为我们的层定义一个模型,并让该模型通过可观察的来控制可见性。
这一切都会产生以下jsFiddle 示例
| 归档时间: |
|
| 查看次数: |
234 次 |
| 最近记录: |