BOUNCE анимация не работает на карте - PullRequest
0 голосов
/ 29 мая 2019

Как видно из названия, анимация BOUNCE не работает на карте, но я уверен, что она должна работать именно так.Можете ли вы помочь мне понять, где я не прав?Это фрагмент кода, который я использую для добавления маркеров на карту

this.addMarker = function(lat, lng, url, title, icon, shadow, body, full_address, animation) {
        if(lat == 0.0) return;

    var latLng = new google.maps.LatLng(lat, lng); 
    var zIndex = 99999 + this.numMarkers;

    var markerOptions = {
        position: latLng, 
        map: this.map,
        linkURL: '',
        zIndex: zIndex,
       // animation: "",//google.maps.Animation.BOUNCE,
        title: title,
        full_address: full_address
    };
    google.maps.event.addListener(markerOptions, "mouseover", up)

    function up(){
        if(typeof animation == "undefined"){
            markerOptions.animation = google.maps.Animation.BOUNCE;
        } else {
            markerOptions.animation = null;
        }
    }
    if(typeof icon !== "undefined" && icon.length > 0) markerOptions.icon = icon;
        else if(this.icon) markerOptions.icon = this.icon;

    // console.log(markerOptions); 

    if(typeof shadow !== "undefined" && shadow.length > 0) markerOptions.shadow = shadow; 
        else if(this.shadow.length > 0) markerOptions.shadow = this.shadow; 

    var marker = new google.maps.Marker(markerOptions); 

    var infowindow = new google.maps.InfoWindow({
        content: '<div class="gmaps-box" style="width: 100%;"><h5>'+title+'</h5><p>'+body+'</p></div>'
    }); 

    if(url.length > 0) marker.linkURL = url;
    if(this.hoverBox) marker.hoverBoxTitle = title; 
        else marker.setTitle(title); 

    this.markers[this.numMarkers] = marker;
    this.numMarkers++;

    if(marker.linkURL.length > 0) {
        google.maps.event.addListener(marker, 'click', function(e) {
            // window.location.href = marker.linkURL; 
            infowindow.open(this.map, marker);

        }); 
    }
    if(markerOptions.icon !== "undefined" && this.iconHover) {
        var iconHover = this.iconHover; 
        google.maps.event.addListener(marker, 'mouseover', function(e) {
            marker.setIcon(iconHover); 
        });
        google.maps.event.addListener(marker, 'mouseout', function(e) {
            marker.setIcon(markerOptions.icon); 
        }); 
    }

    if(this.hoverBox) {

        var $hoverBox = this.hoverBox; 
        var offsetTop = this.hoverBoxOffsetTop;
        var offsetLeft = this.hoverBoxOffsetLeft; 

        var mouseMove = function(e) {
            $hoverBox.css({
                'top': e.pageY + offsetTop,
                'left': e.pageX + offsetLeft
            });
        }; 

        // console.log($hoverBox); 

        google.maps.event.addListener(marker, 'mouseover', function(e) {
            this._currentURL = url;
            $hoverBox.html("<span>" + marker.hoverBoxTitle + "</span>")
                .css('top', '0px')
                .css('left', '0px')
                .css('display', 'block')
                .css('width', 'auto')
                .css('z-index', 9999); 
            $hoverBox.show();

            $(document).mousemove(mouseMove); 
        }); 

        google.maps.event.addListener(marker, 'mouseout', function(e) {
            $hoverBox.hide();
            $(document).unbind("mousemove", mouseMove);
        }); 

    }
}

Результат должен выглядеть следующим образом: https://jsfiddle.net/api/post/library/pure/

1 Ответ

0 голосов
/ 29 мая 2019

Чтобы все было просто и не беспокоиться о области видимости, вместо вызова up в addEventListener, вы можете попробовать вызвать саму функцию:

google.maps.event.addListener(markerOptions, "mouseover", function(){
        if(typeof animation == "undefined"){
            markerOptions.animation = google.maps.Animation.BOUNCE;
        } else {
            markerOptions.animation = null;
        }
    });
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...