Как я могу удалить булавки с карт Google при выборе нового местоположения в меню выбора? - PullRequest
0 голосов
/ 15 сентября 2018

Я создал простую карту с раскрывающимся списком, которая позволяет пользователю выбрать местоположение кампуса колледжа.Теперь я пытаюсь очистить предыдущий выбор при выборе нового местоположения ... любые предложения с этим были бы хорошими.

Я знаю, что должен быть лучший способ сделать это вместо создания нескольких переменныхи функции, но это просто должно быть функциональным в этой точке.

<!DOCTYPE html>
<html>
<head>
    <title>Page Title</title>
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <link rel="stylesheet" href="http://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.css" />
    <link rel="stylesheet" href="styles.css" />
    <script src="https://maps.googleapis.com/maps/api/js?key=
    AIzaSyDCnqMp9UXHgRIu0A9vWtn2MFiO1Ze-sq8
    &callback=initMap"></script>
    <script src="http://code.jquery.com/jquery-1.9.1.min.js"></script>
    <script src="http://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.js"></script>
</head>
<body>
    <header>
          <div class="ui-body ui-body-a ui-corner-all">
            <h3>BCIT Campuses</h3>
                  <p>This app is designed to show you the various BCIT Campus locations</p>
        </div>
    </header>
    <form>
        <div class="ui-field-contain">
                <label for="select-native-1">Select a campus</label>
                <select id="location" name="location">
                <option disabled selected> -- select a location -- </option>
                        <option value="DTN" onClick="downtownPin()">Downtown Campus</option>
                        <option id="BBY" name="burnaby" value="BBY" onClick="burnabyPin()">Burnaby Campus</option>
                <option id="ANN" value="ANN" onClick="annacisPin()">Annacis Campus</option>  
            </select>
        </div>
    </form>
    <div data-role="page" id="map-page" data-url="map-page">
        <div data-role="header" data-theme="a">
            <h1>Maps</h1>
        </div>
        <div role="main" class="ui-content" id="map-canvas">
            <!-- map loads here... -->
        </div>
    </div>
    <footer>
         <div class="ui-body ui-body-a ui-corner-all">
            <h4>Wade Barrie</h4>
              
        </div>
    </footer>
</body>
<script>
    /*
     * Google Maps documentation: http://code.google.com/apis/maps/documentation/javascript/basics.html
     * Geolocation documentation: http://dev.w3.org/geo/api/spec-source.html
     */
    var map;
    function myMap() {
        var mapCanvas = document.getElementById("map-canvas");
        var mapOptions = {
            center: new google.maps.LatLng(49.2595139, -123.1133546),
            zoom: 10
        };
        map = new google.maps.Map(mapCanvas, mapOptions);
    }
    var myLatlng = new google.maps.LatLng(49.283333, -123.115556);
    var downtownCampus = new google.maps.LatLng(49.283333, -123.115556);
    var annacisCampus = new google.maps.LatLng(49.1636275, -122.9702631);
    var burnabyCampus = new google.maps.LatLng(49.2505981, -123.0020511);
    var mapOptions = {
        zoom: 10,
        center: myLatlng
    }
    var map = new google.maps.Map(document.getElementById("map-canvas"), mapOptions);

    var downtownCampus = new google.maps.Marker({
        position: downtownCampus,
        title: "Downtown Campus"
    });

    var annacisCampus = new google.maps.Marker({
        position: annacisCampus,
        title: "Annacis Island"
    });

    var burnabyCampus = new google.maps.Marker({
        position: burnabyCampus,
        title: "Burnaby Campus"
    });
    // functions that actually place the pin on the map when selected
    function annacisPin(reload) {
        annacisCampus.setMap(map);
    }
    function downtownPin() {
        downtownCampus.setMap(map);
    }
    function burnabyPin() {
        burnabyCampus.setMap(map);
    }
</script>
</html>

1 Ответ

0 голосов
/ 15 сентября 2018

Вы можете использовать yourmarker.setMap(null), чтобы удалить маркер с карты перед отображением следующего.setMap (карта) добавляет маркер на карту.setMap (null) удаляет его.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...