Removing Map Pin With Search
Solution 1:
I would encapsulate your markers into their own data model that takes care of the interaction with Google Maps behind the scenes:
// we have to give it access to the map object, so that// it can register and de-register itselfvar Pin = function Pin(map, name, lat, lon, text) {
var marker;
this.name = ko.observable(name);
this.lat = ko.observable(lat);
this.lon = ko.observable(lon);
this.text = ko.observable(text);
marker = new google.maps.Marker({
position: new google.maps.LatLng(lat, lon),
animation: google.maps.Animation.DROP
});
this.isVisible = ko.observable(false);
this.isVisible.subscribe(function(currentState) {
if (currentState) {
marker.setMap(map);
} else {
marker.setMap(null);
}
});
this.isVisible(true);
}
Now you can create your pins with pin = new Pin(map, 1, 2, 'text')
, and when you toggle their visibility state with pin.isVisible(false)
, they automatically register or deregister with the map.
Your filter function thus becomes
self.filterPins = ko.computed(function () {
var search = self.query().toLowerCase();
return ko.utils.arrayFilter(self.pins(), function (pin) {
var doesMatch = pin.name().toLowerCase().indexOf(search) >= 0;
pin.isVisible(doesMatch);
return doesMatch;
});
});
Solution 2:
You can use a Google map plug-in such as Maplace. it will reduce the complexity. it makes easy to add/remove locations on map, trigger new locations on some event. it has easy to use built-in methods.
Check this Demo on how to add/remove new locations in Google map dynamically.
Here is the code.
HTML
<divid="gmap"></div><divid="menu"><ahref="javascript:void(0);"class="loc_link"data-lat="12.58"data-long="77.38"data-title="Bangalore"data-html="Bangalore, Karnataka, India">A</a><ahref="javascript:void(0);"class="loc_link"data-lat="31.2"data-long="121.5"data-title="Shanghai"data-html="Shanghai, China">B</a><ahref="javascript:void(0);"class="loc_link"data-lat="35.6895"data-long="139.6917"data-title="Tokyo"data-html="Tokyo, Japan">C</a><ahref="javascript:void(0);"class="loc_link"data-lat="28.6139"data-long="77.2089"data-title="New Delhi"data-html="New Delhi, India">D</a><ahref="javascript:void(0);"class="loc_link"data-lat="40.7127"data-long="74.0059"data-title="New York"data-html="New York City">E</a><br/><spanid="tool_tip">Click links to see effect!</span></div>
CSS
#gmap{
width: 70%;
height: 350px;
margin: 0 auto;
}
#menu {
width: 300px;
margin: 15px auto;
text-align:center;
}
#menua.loc_link {
background: #0f89cf;
color: #fff;
margin-right: 10px;
display: inline-block;
margin-bottom:10px;
padding: 5px;
border-radius: 3px;
text-decoration: none;
}
#menuspan#tool_tip {
display: inline-block;
margin-top: 10px;
}
JQuery
$(function(){
var map;
varLocA = [{
lat: 12.58,
lon: 77.38,
title: 'Bangalore',
html: 'Bangalore, Karnataka, India',
zoom: 4,
icon: 'http://maps.google.com/mapfiles/markerA.png',
animation: google.maps.Animation.DROP
}];
map = newMaplace({
locations: LocA,
map_div: '#gmap',
generate_controls: false,
start: 0
}).Load();
$(".loc_link").click(function(){
var newLoc = [{
lat: $(this).data('lat'),
lon: $(this).data('long'),
title: $(this).data('title'),
html: $(this).data('html'),
zoom: 4,
icon: 'http://maps.google.com/mapfiles/marker'+$(this).text()+'.png',
animation:google.maps.Animation.DROP
}];
map.AddLocations(newLoc).Load();
map.ViewOnMap($(this).index()+1);
});
});
You need to add these two js libraries to make it work
http://maps.google.com/maps/api/js?sensor=false&libraries=geometry&v=3.13http://maplacejs.com/src/maplace-0.1.3.min.js
Hope this helps.
Solution 3:
I can't simulate this, but after read your code I assume this code will work.. First add marker as your pin property:
self.mapPin = function (name, lat, lon, text) {
this.name = ko.observable(name);
this.lat = ko.observable(lat);
this.lon = ko.observable(lon);
this.text = ko.observable(text);
this.marker = new google.maps.Marker({
position: new google.maps.LatLng(lat, lon),
map: map,
animation: google.maps.Animation.DROP
});
// removed for clarity
};
then set pin marker visibility while filtering your pins
self.filterPins = ko.computed(function () {
var search = self.query().toLowerCase();
return ko.utils.arrayFilter(self.pins(), function (pin) {
varmatch = pin.name().toLowerCase().indexOf(search) >= 0;
pin.marker.setVisible(match); // maps API hide callreturnmatch;
});
});
Post a Comment for "Removing Map Pin With Search"