Removing Map Pin with Search

后端 未结 3 1802
-上瘾入骨i
-上瘾入骨i 2021-01-19 02:43

I\'m trying to create a search bar that filters out items from a list if they do not match the search query. The additional functionality that I\'m trying to add is that if

相关标签:
3条回答
  • 2021-01-19 03:10

    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 itself
    var 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;
        });
    });
    
    0 讨论(0)
  • 2021-01-19 03:12

    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

    <div id="gmap"></div>
    
    <div id="menu">
      <a href="javascript:void(0);" class="loc_link" data-lat="12.58" data-long="77.38" data-title="Bangalore" data-html="Bangalore, Karnataka, India">A</a>
    
      <a href="javascript:void(0);" class="loc_link" data-lat="31.2" data-long="121.5" data-title="Shanghai" data-html="Shanghai, China">B</a>
    
      <a href="javascript:void(0);" class="loc_link" data-lat="35.6895" data-long="139.6917" data-title="Tokyo" data-html="Tokyo, Japan">C</a>
    
      <a href="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>
    
      <a href="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/>
      <span id="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;
    }
    #menu a.loc_link {
     background: #0f89cf;
     color: #fff;
     margin-right: 10px;
     display: inline-block;
     margin-bottom:10px;
     padding: 5px;
     border-radius: 3px;
     text-decoration: none;
    }
    #menu span#tool_tip {
      display: inline-block;
      margin-top: 10px;
    }
    

    JQuery

    $(function(){
    var map;
    var LocA = [{
        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 = new Maplace({
      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.13 http://maplacejs.com/src/maplace-0.1.3.min.js

    Hope this helps.

    0 讨论(0)
  • 2021-01-19 03:22

    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) {
            var match = pin.name().toLowerCase().indexOf(search) >= 0;
    
            pin.marker.setVisible(match); // maps API hide call
            return match;
        });
    });
    

    Google Maps Marker Documentation

    0 讨论(0)
提交回复
热议问题