angular-google-maps在mouseover事件中没有显示infowindow

时间:2015-03-02 09:26:08

标签: angularjs google-maps google-maps-api-3 angular-google-maps

我正在使用angularjs-google-map http://angular-ui.github.io/angular-google-maps/#!/api

我可以添加多个标记,通过在标记上显示来显示infoWindow,但现在我需要在鼠标进入标记图标区域时显示标记infoWindow并在鼠标离开标记图标区域时隐藏它使用点击事件。

您可以在Jsfiddle https://jsfiddle.net/meher12/bgb36q7b/上查看此示例,以了解我的目的!

我的HTML代码:

    <ui-gmap-google-map center="map.center" zoom="map.zoom"  dragging="map.dragging" bounds="map.bounds"
                events="map.events"  options="map.options" pan="true" control="map.control">    


            <ui-gmap-markers models="map.randomMarkers" coords="'self'" icon="'icon'"
                doCluster="map.doClusterRandomMarkers" clusterOptions="map.clusterOptions" modelsbyref="true"
                events="map.markersEvents" options="'options'"
                >


                <ui-gmap-windows show="'showWindow'" ng-cloak>
                <div>
                    <p>This is an info window</p>
                </div>
            </ui-gmap-windows>


            </ui-gmap-markers>      

        </ui-gmap-google-map>


  </div>

我的JS代码:

myApp.controller('MainController', function ($scope,uiGmapGoogleMapApi) {

    $scope.numOfMarkers = 25;
uiGmapGoogleMapApi.then(function(maps) { $scope.googleVersion = maps.version; });



    $scope.map = {
        center: {
            latitude: 45,
            longitude: -73
        },
        zoom: 10,
        options: {
            streetViewControl: false,
            panControl: false,
            maxZoom: 20,
            minZoom: 3
        },
        dragging: false,
        bounds: {},

        randomMarkers: [],
        doClusterRandomMarkers: true,
        currentClusterType: 'standard',
        clusterOptions: {
            title: 'Hi I am a Cluster!', gridSize: 60, ignoreHidden: true, minimumClusterSize: 2
        }

    };

     $scope.map.markersEvents = {
        mouseover: function (marker, eventName, model, args) {
          model.options.labelContent = "Position - lat: " + model.latitude + " lon: " + model.longitude;
          marker.showWindow = true;
          $scope.$apply();
        },
        mouseout: function (marker, eventName, model, args) {
           model.options.labelContent = " ";
           marker.showWindow = false;
           $scope.$apply();
        }
    };


    var genRandomMarkers = function (numberOfMarkers, scope) {
        var markers = [];
        for (var i = 0; i < numberOfMarkers; i++) {
          markers.push(createRandomMarker(i, scope.map.bounds))
      }
      scope.map.randomMarkers = markers;
  };

     var createRandomMarker = function (i, bounds, idKey) {
     var lat_min = bounds.southwest.latitude,
  lat_range = bounds.northeast.latitude - lat_min,
  lng_min = bounds.southwest.longitude,
  lng_range = bounds.northeast.longitude - lng_min;

if (idKey == null)
  idKey = "id";

var latitude = lat_min + (Math.random() * lat_range);
var longitude = lng_min + (Math.random() * lng_range);
var ret = {
  latitude: latitude,
  longitude: longitude,
  title: 'm' + i,
  showWindow: false,
  options: {
        labelContent: ' ',
        labelAnchor: "22 0",
        labelClass: "marker-labels",
        draggable: true
      }
};
ret[idKey] = i;
return ret;
};


   $scope.genRandomMarkers = function (numberOfMarkers) {
      genRandomMarkers(numberOfMarkers, $scope);
  };
   $scope.removeMarkers = function () {

    $scope.map.randomMarkers = [];

 };

});

就像你在我的JS代码中看到的那样,我创建了markerEvents并且我可以在鼠标事件上更改标记标签,但是当鼠标事件被触发时仍然没有显示附加到地图上每个标记的infoWindow,尽管它的值正在改变并采取正确的价值。

有人有想法解决这个问题吗? 随意将您的更改添加到我的Jsfiddle代码:)

2 个答案:

答案 0 :(得分:4)

您必须设置model.showWindow而不是marker.showWindow

答案 1 :(得分:0)

您可以在html删除model.show = true中设置model.showWindow而不是show =showWindow