如何使用jquery-ui-map的个性化图标

时间:2012-06-04 15:38:37

标签: jquery google-maps-api-3 jquery-ui-map

使用jquery-ui-map,我尝试使用个性化图标。 我这样做很好:

$("#gmap_" + parent).gmap('addMarker', { 
    "id": "marker-"+m.id,
    'position': new google.maps.LatLng(m.lat, m.lon), 
    'bounds':true,
    'icon': '/images/'+m.icon
})

因为我的图标只是一个网址。但我想把所有的图标都放在一个精灵中,所以我必须设置其他选项:

$("#gmap_" + parent).gmap('addMarker', { 
    "id": "marker-"+m.id,
    'position': new google.maps.LatLng(m.lat, m.lon), 
    'bounds':true,
    'icon': new google.maps.MarkerImage( {
        'url' : "http://crm.brunet.pro/images/markers.png",
        'origin': new google.maps.Point(m.pos, 0),
        'size' : new google.maps.Size(20, 34)
    })
})

我收到此错误:

GET http://mysite.com/[object%20Object] 400 (Bad Request)

所以看起来icon选项只接受一个字符串。但是你可以在api中看到它应该接受MarkerImage对象。

我错了什么?

由于

1 个答案:

答案 0 :(得分:4)

MarkerImage最多使用五个参数创建,例如MarkerImage(myUrl, size1, point1, point2),但您已将其写为一个对象参数。

我认为API文档可能会在这种情况下混淆。看看这些例子:

https://developers.google.com/maps/documentation/javascript/overlays#ComplexIcons

  var image = new google.maps.MarkerImage('images/beachflag.png',
  // This marker is 20 pixels wide by 32 pixels tall.
  new google.maps.Size(20, 32),
  // The origin for this image is 0,0.
  new google.maps.Point(0,0),
  // The anchor for this image is the base of the flagpole at 0,32.
  new google.maps.Point(0, 32));

http://blog.mridey.com/2010/03/using-markerimage-in-maps-javascript.html(解释从精灵表中加载)

未提及

size, origin, anchor,但您需要遵守API文档中给出的顺序。