/* * Paper.js * * This file is part of Paper.js, a JavaScript Vector Graphics Library, * based on Scriptographer.org and designed to be largely API compatible. * http://paperjs.org/ * http://scriptographer.org/ * * Copyright (c) 2011, Juerg Lehni & Jonathan Puckey * http://lehni.org/ & http://jonathanpuckey.com/ * * Distributed under the MIT license. See LICENSE file for details. * * All rights reserved. */ /** * @name MouseEvent * * @class MouseEvent The MouseEvent object is received by the {@link Item}'s * mouse event handlers {@link Item#onMouseDown}, {@link Item#onMouseDrag}, * {@link Item#onMouseMove}, {@link Item#onMouseUp}, {@link Item#onClick}, * {@link Item#onDoubleClick}, {@link Item#onMouseEnter} and * {@link Item#onMouseLeave}. The MouseEvent object is the only parameter passed * to these functions and contains information about the mouse event. * * @extends Event */ var MouseEvent = this.MouseEvent = Event.extend(/** @lends MouseEvent# */{ initialize: function(type, event, point, target, delta) { this.base(event); this.type = type; this.point = point; this.target = target; this.delta = delta; }, /** * The type of mouse event. * * @name MouseEvent#type * @type String('mousedown', 'mouseup', 'mousedrag', 'click', * 'doubleclick', 'mousemove', 'mouseenter', 'mouseleave') */ /** * The position of the mouse in project coordinates when the event was * fired. * * @name MouseEvent#point * @type Point */ // DOCS: document MouseEvent#target /** * @name MouseEvent#target * @type Item */ // DOCS: document MouseEvent#delta /** * @name MouseEvent#delta * @type Point */ /** * @return {String} A string representation of the mouse event. */ toString: function() { return '{ type: ' + this.type + ', point: ' + this.point + ', target: ' + this.target + (this.delta ? ', delta: ' + this.delta : '') + ', modifiers: ' + this.getModifiers() + ' }'; } });