Bug 24407

Summary: Windows wheel scrolls by too little
Product: WebKit Reporter: Peter Kasting <pkasting>
Component: WebCore Misc.Assignee: Peter Kasting <pkasting>
Status: RESOLVED FIXED    
Severity: Normal    
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: PC   
OS: Windows XP   
Attachments:
Description Flags
patch v1 fishd: review+

Peter Kasting
Reported 2009-03-05 15:03:09 PST
(As discussed with hyatt on IRC) On Windows, users can configure the mousewheel to scroll a particular number of lines per wheel tick (default 3). Safari scrolls 40/3 pixels per line, meaning it scrolls 40 px per wheel tick by default. This matches what happens on Mac, except that Mac wheel events are accelerated, meaning that repeated wheel events are reported as having higher deltas, and thus result in much larger scrolls. On Windows, where this acceleration does not occur, Safari feels like it takes forever to scroll down a page. Other browsers' behavior varies widely. IE appears to scroll approximately 50 px per line, so ~150 px per wheel tick, or almost 4x Safari's amount. However, IE also animates the scroll, which allows larger scrolls without the eye losing its place; a value this large in Safari feels too jerky. Firefox scrolls based on the actual height of the "current line" as reported by the renderer, leading to bizarre effects like scrolling down and back up not returning users to the same spot, and scroll amounts changing as you travel through a page or across pages. Google Chrome 1.0 scrolled 40 px per line, about 3x Safari's current value, which felt like a little too much -- a number of users complained about losing their place while wheel scrolling. Given a lack of consistency among other products, I'm just going to try a few values. In the process I think the scrolling code can be simplified. When scrolling by line, we first consult a member function of the PlatformWheelEvent to decide how many lines to scroll in a wheel tick, and then multiply again later to convert lines to pixels. It seems simpler to just eliminate the line-scrolling type and make wheel scrolls either be pixel- or page-based, and do all necessary conversion for pixel scrolls in the platform-specific code.
Attachments
patch v1 (14.58 KB, patch)
2009-03-05 15:39 PST, Peter Kasting
fishd: review+
Peter Kasting
Comment 1 2009-03-05 15:39:05 PST
Created attachment 28333 [details] patch v1 After some experimentation, 100 px/wheel tick felt the best of any value I tried.
Darin Fisher (:fishd, Google)
Comment 2 2009-03-06 11:40:33 PST
Comment on attachment 28333 [details] patch v1 LGTM I wonder if this will impact any layout tests...
Peter Kasting
Comment 3 2009-03-06 11:56:42 PST
Fixed in r41495.
Note You need to log in before you can comment on or make changes to this bug.