Instead of Google Maps API's default info window, I'm going to use other jQuery tooltip plugin over marker. So I need to get marker's DIV and its pixel position.
But couldn't get it because there are no id or class for certain marker. Only I can access map canvas div from marker object and undocumented pixelBounds object.
- How can I access marker's DIV?
- Where can I get DIV's pixel position? Can I convert lat-lng position to pixel values?
== appended:
I also tried with below code, but it doesn't change when I scroll the map.
var marker = new google.maps.Marker({...});
google.maps.event.addListener(marker, 'click', function() {
var px = this.getMap().getProjection().fromLatLngToPoint(this.getPosition());
console.log("(" + px.x + "," + px.y + ")");
});
I don't really get why would you want to get specific div for marker? If you want to display tooltip then all you need is pixel position of markers anchor (and knowledge about size of marker and placement of anchor), not div element. You can always trigger opening and closing tooltip by hand when event occurs on google.maps side.
For getting pixel position of anchor of given marker you can use this code:
In
pixelDistance
you get offset of specific marker anchor counted from left upper corner of the map (and you can get it's position frommap.getDiv()
div). Why it works like this (or is there a better way?) you can read in documentation of google maps overlays.MapCanvasProjection's
fromLatLngToContainerPixel()
is probably what the author's after. It will give you the pixel offset relative to the map's container. I did some experiments and found the "simplest" working solution. (I wish Google makes this feature more accessible!)First you declare a subclass of
OverlayView
somewhere like so:Then somewhere else in your code where you instantiate the map, you also instantiate this OverlayView and set its map, like so:
Then, whenever you need to use
fromLatLngToContainerPixel
, you just do this:Note that because the MapCanvasProjection object will only be available once
draw()
is called, which is sometime before the map'sidle
, I suggest creating a boolean "mapInitialized" flag, set it to true on the first mapidle
callback. And then do what you need to do only after that.One thing to remember when using MBO's code: When the map tiles are repeated,
map.getBounds().getSouthWest()
returns "-180" independent of the map's position. A fallback I'm using in this case is calculating the pixel distance to the center instead of the upper left corner, sincemap.getCenter()
seems to return the currently centered point in any case. E.g. (using jQuery):Well, if you MUST access the DIV, here's some code. Beware that this will only work with the standard marker (20x34px), and it'll find all markers. You might want to improve this hack to suit your needs...
BEWARE! THIS IS A HACK
anyone still looking for an answer to this, have a look here: http://code.google.com/p/google-maps-utility-library-v3/wiki/Libraries among some other useful google maps stuff there's RichMarker which allows you to add DOM elements of your choice as draggable markers. just add class/id to handle with jQuery.
A working snippet jQuery style ready to copy/paste:
step 1 - initialize your map and options
As you can see, lower, the variable map is not preceded by VAR, because it should be Global as we use another function to get the fromLatLngToContainerPixel. For more details check closures.