I’m working on some Google Web Toolkit Code that places an AbsolutePanel on top of an image. The way I’m doing this is to:
-
wait until the image is loaded (i.e. width/height are >0)
-
get the absolute coordinates of the image in the viewport using image.getAbsoluteLeft() and image.getAbsoluteTop
-
Set the position of the AbsolutePanel (a direct child of the RootPanel) to the same coordinates using RootPanel.get().setWidgetPosition(myPanel, imageAbsLeft, imageAbsTop);
This works in Chrome and IE. Strangely, though, Firefox always positions the AbsolutePanel “a few” pixels (I’d say between 1 and approx 10? But it varies from page load to page load) above the image. I’m clueless as to what’s causing this. Any hints much appreciated!
A live example of this is here: http://yuma-js.github.com. If you click the “Add Annotation” there’s a draggable box, which movement is constrained by the AbsolutePanel. You’ll notice that the constraining works perfect for Chrome, but is off for FireFox.
Morning,
well, I did some research how I could overlay an image with a another object too, and found this article: How to overlay one div over another div.
Based on that I made a similar example using SVG and drawing example, where I draw a rectangle around a space station. What I can tell you is, that you don’t want to mix pixel and percentage positioning, and if you can, you should use percentage positioning!
Hope this helps somehow.
Here is my example: