WebKit Bugzilla
New
Browse
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED DUPLICATE of
bug 225788
145214
Pinch-to-zoom has no JavaScript event and cannot be prevented, unlike Chrome
https://bugs.webkit.org/show_bug.cgi?id=145214
Summary
Pinch-to-zoom has no JavaScript event and cannot be prevented, unlike Chrome
evan.exe
Reported
2015-05-20 11:12:49 PDT
The trackpad pinch-to-zoom gesture currently zooms into the page, even on OS X. This is frustrating for web applications because it's often not what the user wants and there's no way for the developer to override this. For example, when a user pinches on
https://www.google.com/maps
they surely mean to zoom the map, not the page. Chrome has recently copied this feature but they allow it to be overridden. Pinch gestures get mapped to wheel events with the control key pressed, and calling preventDefault() will prevent the page from zooming. This allows web applications to have custom handling for pinch gestures. I'm currently working on a vector content editor for the web and this feature makes the Safari experience so broken for our users that we're considering just blocking Safari entirely and telling people to use Chrome instead. Is there any way to prevent WebKit from doing this on OS X? Maybe the "user-scalable=no" meta tag? Even better, is there a way to get the actual scale values from the pinch gesture?
Attachments
Add attachment
proposed patch, testcase, etc.
thesmart
Comment 1
2015-05-20 13:43:43 PDT
I'd like to pile on that this feature is incredibly confusing to end-users. Here are some grievances: (1) pinch gesture is very sensitive, too easy to do by accident (2) does not show zoom-level-% to inform the user of their zoom level (3) zooming and then refreshing the page leaves the window zoomed, leading end-users to believe the site or their computer is broken (seriously!) (4) ignores the Viewport meta tag "standard" (5) no good way to detect zoom level or zoom events in JavaScript (6) Apple Touchpad acts like a touch device, but does not trigger proper touch events Giving Macbook TrackPad more touch-device-like capabilities is laudable, but failing to properly hook it up to existing touch APIs is hurting the end-user experience.
evan.exe
Comment 2
2015-05-20 17:57:47 PDT
Those are good points. However, the trackpad is a bit of an odd beast and doesn't map well to touch events. The touches are indirect and don't have screen-space positions. I'm much more in favor of something like the approach OS X takes where the gesture recognition has already been performed and you get separate pinch and rotate events. This could easily be added to the web platform either as new events or using existing events as Chrome has done. One easy way to introduce pinch-to-zoom that's less hacky than Chrome's approach could be to emit wheel events with the scale factor change in the deltaZ value.
Ebrahim Byagowi
Comment 3
2017-03-10 00:39:37 PST
Some useful links: *
https://github.com/dimsemenov/PhotoSwipe/issues/897
*
https://bugs.chromium.org/p/chromium/issues/detail?id=289887
*
http://jsbin.com/cuxopid/1/edit
Tim Horton
Comment 4
2021-08-04 02:44:00 PDT
There /are/ non-standard gesture events that do allow custom pinch-zooming (e.g. your map example; try pinch-zooming on DuckDuckGo Maps, for example (
https://duckduckgo.com/?q=1+infinite+loop&t=h_&ia=places&iaxm=maps
). These have been around for a long time:
https://trac.webkit.org/changeset/191299/webkit
The Chrome-like "map it to ctrl-wheel" behavior was also recently implemented in
https://trac.webkit.org/changeset/277772/webkit
. I'm going to dupe you to the second one; feel free to kick this back with more details if it doesn't address your needs. *** This bug has been marked as a duplicate of
bug 225788
***
Note
You need to
log in
before you can comment on or make changes to this bug.
Top of Page
Format For Printing
XML
Clone This Bug