I am working on a page in witch all its contents are scaled by using zoom. The problem is that when I drag something in the page the dragging item gets a bad position that seems relative to the zoom amount.
To solve this I tried to do some math on the position of the draggable component, but seems that even tho visually its corrected, the "true" position its not recalculated.
here is some code to explain better:
var zoom = Math.round((parseFloat($("body").css("zoom")) / 100)*10)/10;
var x = $(this).data('draggable').position;
$(this).data('draggable').position.left = Math.round(x.left/zoom);
$(this).data('draggable').position.top = Math.round(x.top/zoom);
Any help would be greatly appreciated
Took a lot of time and effort to fix this, but finally, I have a solution that works.
This solution works for both Firefox and IE. #canvas is the div that contains the draggable. Note that we have to make sure the elements stays inside the canvas manually.
This also works if if canvas has a different zoom level than the rest of the page.
If CSS Zoom is performed specifically on the html body, there is a very easy fix, but it does require you to modify the source. That's a no-go for some, but I'll post the solution here anyway.
So the draggable functionality of jQuery UI figures out the mouseposition using a method called
_generatePosition
. The problem is that it doesn't take zoom into account (duh), so we merely have to divide its outcome by the zoom level and everything will work.So turn this:
in
That's all. I suggest saving it under a specific name so it's easily recognized that it has been modified. E.g.:
jquery-ui.ZOOMFIX.js
I used the
jquery-ui.js
file from the following package: https://jqueryui.com/resources/download/jquery-ui-1.12.1.zipI was struggling with this for some hours. I had a grid where I started of with scaling it by setting the font-size (125% etc on the container). This worked well until I came into images that didn't scale with the grid.
Thought I'd use zoom instead and it worked brilliantly. Then I relized by draggable/droppable wasn't scaling with it hmm.. Spend several hours trying to destroy and re-init the jqueryUI objects but nothing worked.
Then finally I realized I could use a combination of font-size for zooming the grid and css-zoom for the images. Now everything works and I can drag/drop with the same instance of jQueryUI.
Hope this approach helps someone else. :-)
Are you taking the scroll position, margin and padding into account? Such as:
Then adjusting for the zoom value as needed?