blob: 1f172eb067257a625284046f4b73d8cbd617ee68 [file] [log] [blame]
// Copyright 2014 The Closure Library Authors. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS-IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
/**
* @fileoverview This class aims to smooth out inconsistencies between browser
* handling of wheel events by providing an event that is similar to that
* defined in the standard, but also easier to consume.
*
* It is based upon the WheelEvent, which allows for up to 3 dimensional
* scrolling events that come in units of either pixels, lines or pages.
* http://www.w3.org/TR/2014/WD-DOM-Level-3-Events-20140925/#interface-WheelEvent
*
* The significant difference here is that it also provides reasonable pixel
* deltas for clients that do not want to treat line and page scrolling events
* specially.
*
* Clients of this code should be aware that some input devices only fire a few
* discrete events (such as a mouse wheel without acceleration) whereas some can
* generate a large number of events for a single interaction (such as a
* touchpad with acceleration). There is no signal in the events to reliably
* distinguish between these.
*
* @see ../demos/wheelhandler.html
*/
goog.provide('goog.events.WheelEvent');
goog.require('goog.asserts');
goog.require('goog.events.BrowserEvent');
/**
* A common class for wheel events. This is used with the WheelHandler.
*
* @param {Event} browserEvent Browser event object.
* @param {goog.events.WheelEvent.DeltaMode} deltaMode The delta mode units of
* the wheel event.
* @param {number} deltaX The number of delta units the user in the X axis.
* @param {number} deltaY The number of delta units the user in the Y axis.
* @param {number} deltaZ The number of delta units the user in the Z axis.
* @constructor
* @extends {goog.events.BrowserEvent}
* @final
*/
goog.events.WheelEvent = function(
browserEvent, deltaMode, deltaX, deltaY, deltaZ) {
goog.events.WheelEvent.base(this, 'constructor', browserEvent);
goog.asserts.assert(browserEvent, 'Expecting a non-null browserEvent');
/** @type {goog.events.WheelEvent.EventType} */
this.type = goog.events.WheelEvent.EventType.WHEEL;
/**
* An enum corresponding to the units of this event.
* @type {goog.events.WheelEvent.DeltaMode}
*/
this.deltaMode = deltaMode;
/**
* The number of delta units in the X axis.
* @type {number}
*/
this.deltaX = deltaX;
/**
* The number of delta units in the Y axis.
* @type {number}
*/
this.deltaY = deltaY;
/**
* The number of delta units in the Z axis.
* @type {number}
*/
this.deltaZ = deltaZ;
// Ratio between delta and pixel values.
var pixelRatio = 1; // Value for DeltaMode.PIXEL
switch (deltaMode) {
case goog.events.WheelEvent.DeltaMode.PAGE:
pixelRatio *= goog.events.WheelEvent.PIXELS_PER_PAGE_;
break;
case goog.events.WheelEvent.DeltaMode.LINE:
pixelRatio *= goog.events.WheelEvent.PIXELS_PER_LINE_;
break;
}
/**
* The number of delta pixels in the X axis. Code that doesn't want to handle
* different deltaMode units can just look here.
* @type {number}
*/
this.pixelDeltaX = this.deltaX * pixelRatio;
/**
* The number of pixels in the Y axis. Code that doesn't want to
* handle different deltaMode units can just look here.
* @type {number}
*/
this.pixelDeltaY = this.deltaY * pixelRatio;
/**
* The number of pixels scrolled in the Z axis. Code that doesn't want to
* handle different deltaMode units can just look here.
* @type {number}
*/
this.pixelDeltaZ = this.deltaZ * pixelRatio;
};
goog.inherits(goog.events.WheelEvent, goog.events.BrowserEvent);
/**
* Enum type for the events fired by the wheel handler.
* @enum {string}
*/
goog.events.WheelEvent.EventType = {
/** The user has provided wheel-based input. */
WHEEL: 'wheel'
};
/**
* Units for the deltas in a WheelEvent.
* @enum {number}
*/
goog.events.WheelEvent.DeltaMode = {
/** The units are in pixels. From DOM_DELTA_PIXEL. */
PIXEL: 0,
/** The units are in lines. From DOM_DELTA_LINE. */
LINE: 1,
/** The units are in pages. From DOM_DELTA_PAGE. */
PAGE: 2
};
/**
* A conversion number between line scroll units and pixel scroll units. The
* actual value per line can vary a lot between devices and font sizes. This
* number can not be perfect, but it should be reasonable for converting lines
* scroll events into pixels.
* @const {number}
* @private
*/
goog.events.WheelEvent.PIXELS_PER_LINE_ = 15;
/**
* A conversion number between page scroll units and pixel scroll units. The
* actual value per page can vary a lot as many different devices have different
* screen sizes, and the window might not be taking up the full screen. This
* number can not be perfect, but it should be reasonable for converting page
* scroll events into pixels.
* @const {number}
* @private
*/
goog.events.WheelEvent.PIXELS_PER_PAGE_ = 30 *
goog.events.WheelEvent.PIXELS_PER_LINE_;