src/cm/media/js/lib/yui/yui_3.10.3/build/gesture-simulate/gesture-simulate-debug.js
author Yves-Marie Haussonne <ymh.work+github@gmail.com>
Fri, 09 May 2014 18:35:26 +0200
changeset 656 a84519031134
parent 525 89ef5ed3c48b
permissions -rw-r--r--
add link to "privacy policy" in the header test
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
525
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     1
/*
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     2
YUI 3.10.3 (build 2fb5187)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     3
Copyright 2013 Yahoo! Inc. All rights reserved.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     4
Licensed under the BSD License.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     5
http://yuilibrary.com/license/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     6
*/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     7
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     8
YUI.add('gesture-simulate', function (Y, NAME) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     9
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    10
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    11
 * Simulate high-level user gestures by generating a set of native DOM events.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    12
 *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    13
 * @module gesture-simulate
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    14
 * @requires event-simulate, async-queue, node-screen
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    15
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    16
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    17
var NAME = "gesture-simulate",
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    18
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    19
    // phantomjs check may be temporary, until we determine if it really support touch all the way through, like it claims to (http://code.google.com/p/phantomjs/issues/detail?id=375)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    20
    SUPPORTS_TOUCH = ((Y.config.win && ("ontouchstart" in Y.config.win)) && !(Y.UA.phantomjs) && !(Y.UA.chrome && Y.UA.chrome < 6)),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    21
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    22
    gestureNames = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    23
        tap: 1,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    24
        doubletap: 1,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    25
        press: 1,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    26
        move: 1,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    27
        flick: 1,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    28
        pinch: 1,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    29
        rotate: 1
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    30
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    31
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    32
    touchEvents = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    33
        touchstart: 1,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    34
        touchmove: 1,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    35
        touchend: 1,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    36
        touchcancel: 1
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    37
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    38
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    39
    document = Y.config.doc,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    40
    emptyTouchList,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    41
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    42
    EVENT_INTERVAL = 20,        // 20ms
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    43
    START_PAGEX,                // will be adjusted to the node element center
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    44
    START_PAGEY,                // will be adjusted to the node element center
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    45
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    46
    // defaults that user can override.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    47
    DEFAULTS = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    48
        // tap gestures
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    49
        HOLD_TAP: 10,           // 10ms
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    50
        DELAY_TAP: 10,          // 10ms
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    51
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    52
        // press gesture
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    53
        HOLD_PRESS: 3000,       // 3sec
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    54
        MIN_HOLD_PRESS: 1000,   // 1sec
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    55
        MAX_HOLD_PRESS: 60000,  // 1min
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    56
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    57
        // move gesture
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    58
        DISTANCE_MOVE: 200,     // 200 pixels
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    59
        DURATION_MOVE: 1000,    // 1sec
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    60
        MAX_DURATION_MOVE: 5000,// 5sec
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    61
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    62
        // flick gesture
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    63
        MIN_VELOCITY_FLICK: 1.3,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    64
        DISTANCE_FLICK: 200,     // 200 pixels
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    65
        DURATION_FLICK: 1000,    // 1sec
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    66
        MAX_DURATION_FLICK: 5000,// 5sec
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    67
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    68
        // pinch/rotation
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    69
        DURATION_PINCH: 1000     // 1sec
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    70
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    71
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    72
    TOUCH_START = 'touchstart',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    73
    TOUCH_MOVE = 'touchmove',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    74
    TOUCH_END = 'touchend',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    75
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    76
    GESTURE_START = 'gesturestart',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    77
    GESTURE_CHANGE = 'gesturechange',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    78
    GESTURE_END = 'gestureend',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    79
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    80
    MOUSE_UP    = 'mouseup',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    81
    MOUSE_MOVE  = 'mousemove',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    82
    MOUSE_DOWN  = 'mousedown',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    83
    MOUSE_CLICK = 'click',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    84
    MOUSE_DBLCLICK = 'dblclick',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    85
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    86
    X_AXIS = 'x',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    87
    Y_AXIS = 'y';
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    88
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    89
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    90
function Simulations(node) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    91
    if(!node) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    92
        Y.error(NAME+': invalid target node');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    93
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    94
    this.node = node;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    95
    this.target = Y.Node.getDOMNode(node);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    96
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    97
    var startXY = this.node.getXY(),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    98
        dims = this._getDims();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    99
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   100
    START_PAGEX = startXY[0] + (dims[0])/2;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   101
    START_PAGEY = startXY[1] + (dims[1])/2;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   102
}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   103
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   104
Simulations.prototype = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   105
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   106
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   107
     * Helper method to convert a degree to a radian.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   108
     * 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   109
     * @method _toRadian
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   110
     * @private
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   111
     * @param {Number} deg A degree to be converted to a radian.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   112
     * @return {Number} The degree in radian. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   113
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   114
    _toRadian: function(deg) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   115
        return deg * (Math.PI/180);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   116
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   117
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   118
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   119
     * Helper method to get height/width while accounting for 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   120
     * rotation/scale transforms where possible by using the 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   121
     * bounding client rectangle height/width instead of the 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   122
     * offsetWidth/Height which region uses.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   123
     * @method _getDims
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   124
     * @private
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   125
     * @return {Array} Array with [height, width]
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   126
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   127
    _getDims : function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   128
        var region,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   129
            width,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   130
            height;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   131
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   132
        // Ideally, this should be in DOM somewhere.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   133
        if (this.target.getBoundingClientRect) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   134
            region = this.target.getBoundingClientRect();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   135
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   136
            if ("height" in region) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   137
                height = region.height;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   138
            } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   139
                // IE7,8 has getBCR, but no height.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   140
                height = Math.abs(region.bottom - region.top);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   141
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   142
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   143
            if ("width" in region) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   144
                width = region.width;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   145
            } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   146
                // IE7,8 has getBCR, but no width.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   147
                width = Math.abs(region.right - region.left);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   148
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   149
        } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   150
            region = this.node.get("region");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   151
            width = region.width;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   152
            height = region.height;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   153
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   154
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   155
        return [width, height];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   156
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   157
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   158
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   159
     * Helper method to convert a point relative to the node element into 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   160
     * the point in the page coordination.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   161
     * 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   162
     * @method _calculateDefaultPoint
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   163
     * @private
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   164
     * @param {Array} point A point relative to the node element.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   165
     * @return {Array} The same point in the page coordination. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   166
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   167
    _calculateDefaultPoint: function(point) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   168
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   169
        var height;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   170
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   171
        if(!Y.Lang.isArray(point) || point.length === 0) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   172
            point = [START_PAGEX, START_PAGEY];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   173
        } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   174
            if(point.length == 1) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   175
                height = this._getDims[1];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   176
                point[1] = height/2;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   177
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   178
            // convert to page(viewport) coordination
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   179
            point[0] = this.node.getX() + point[0];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   180
            point[1] = this.node.getY() + point[1];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   181
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   182
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   183
        return point;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   184
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   185
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   186
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   187
     * The "rotate" and "pinch" methods are essencially same with the exact same 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   188
     * arguments. Only difference is the required parameters. The rotate method 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   189
     * requires "rotation" parameter while the pinch method requires "startRadius" 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   190
     * and "endRadius" parameters.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   191
     *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   192
     * @method rotate
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   193
     * @param {Function} cb The callback to execute when the gesture simulation 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   194
     *      is completed.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   195
     * @param {Array} center A center point where the pinch gesture of two fingers
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   196
     *      should happen. It is relative to the top left corner of the target 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   197
     *      node element.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   198
     * @param {Number} startRadius A radius of start circle where 2 fingers are 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   199
     *      on when the gesture starts. This is optional. The default is a fourth of 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   200
     *      either target node width or height whichever is smaller.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   201
     * @param {Number} endRadius A radius of end circle where 2 fingers will be on when
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   202
     *      the pinch or spread gestures are completed. This is optional. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   203
     *      The default is a fourth of either target node width or height whichever is less.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   204
     * @param {Number} duration A duration of the gesture in millisecond.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   205
     * @param {Number} start A start angle(0 degree at 12 o'clock) where the 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   206
     *      gesture should start. Default is 0.  
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   207
     * @param {Number} rotation A rotation in degree. It is required.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   208
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   209
    rotate: function(cb, center, startRadius, endRadius, duration, start, rotation) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   210
        var radius,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   211
            r1 = startRadius,   // optional
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   212
            r2 = endRadius;     // optional
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   213
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   214
        if(!Y.Lang.isNumber(r1) || !Y.Lang.isNumber(r2) || r1<0 || r2<0) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   215
            radius = (this.target.offsetWidth < this.target.offsetHeight)? 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   216
                this.target.offsetWidth/4 : this.target.offsetHeight/4;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   217
            r1 = radius;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   218
            r2 = radius;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   219
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   220
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   221
        // required
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   222
        if(!Y.Lang.isNumber(rotation)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   223
            Y.error(NAME+'Invalid rotation detected.');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   224
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   225
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   226
        this.pinch(cb, center, r1, r2, duration, start, rotation);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   227
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   228
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   229
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   230
     * The "rotate" and "pinch" methods are essencially same with the exact same 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   231
     * arguments. Only difference is the required parameters. The rotate method 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   232
     * requires "rotation" parameter while the pinch method requires "startRadius" 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   233
     * and "endRadius" parameters.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   234
     *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   235
     * The "pinch" gesture can simulate various 2 finger gestures such as pinch, 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   236
     * spread and/or rotation. The "startRadius" and "endRadius" are required.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   237
     * If endRadius is larger than startRadius, it becomes a spread gesture 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   238
     * otherwise a pinch gesture. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   239
     *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   240
     * @method pinch
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   241
     * @param {Function} cb The callback to execute when the gesture simulation 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   242
     *      is completed.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   243
     * @param {Array} center A center point where the pinch gesture of two fingers
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   244
     *      should happen. It is relative to the top left corner of the target 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   245
     *      node element.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   246
     * @param {Number} startRadius A radius of start circle where 2 fingers are 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   247
     *      on when the gesture starts. This paramenter is required.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   248
     * @param {Number} endRadius A radius of end circle where 2 fingers will be on when
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   249
     *      the pinch or spread gestures are completed. This parameter is required.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   250
     * @param {Number} duration A duration of the gesture in millisecond.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   251
     * @param {Number} start A start angle(0 degree at 12 o'clock) where the 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   252
     *      gesture should start. Default is 0.  
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   253
     * @param {Number} rotation If rotation is desired during the pinch or 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   254
     *      spread gestures, this parameter can be used. Default is 0 degree.  
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   255
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   256
    pinch: function(cb, center, startRadius, endRadius, duration, start, rotation) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   257
        var eventQueue,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   258
            i,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   259
            interval = EVENT_INTERVAL,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   260
            touches,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   261
            id = 0,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   262
            r1 = startRadius,   // required
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   263
            r2 = endRadius,     // required
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   264
            radiusPerStep,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   265
            centerX, centerY,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   266
            startScale, endScale, scalePerStep,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   267
            startRot, endRot, rotPerStep,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   268
            path1 = {start: [], end: []}, // paths for 1st and 2nd fingers. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   269
            path2 = {start: [], end: []},
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   270
            steps,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   271
            touchMove;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   272
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   273
        center = this._calculateDefaultPoint(center);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   274
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   275
        if(!Y.Lang.isNumber(r1) || !Y.Lang.isNumber(r2) || r1<0 || r2<0) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   276
            Y.error(NAME+'Invalid startRadius and endRadius detected.');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   277
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   278
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   279
        if(!Y.Lang.isNumber(duration) || duration <= 0) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   280
            duration = DEFAULTS.DURATION_PINCH;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   281
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   282
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   283
        if(!Y.Lang.isNumber(start)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   284
            start = 0.0;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   285
        } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   286
            start = start%360;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   287
            while(start < 0) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   288
                start += 360;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   289
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   290
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   291
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   292
        if(!Y.Lang.isNumber(rotation)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   293
            rotation = 0.0;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   294
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   295
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   296
        Y.AsyncQueue.defaults.timeout = interval;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   297
        eventQueue = new Y.AsyncQueue();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   298
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   299
        // range determination
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   300
        centerX = center[0];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   301
        centerY = center[1];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   302
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   303
        startRot = start;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   304
        endRot = start + rotation;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   305
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   306
        // 1st finger path
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   307
        path1.start = [
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   308
            centerX + r1*Math.sin(this._toRadian(startRot)), 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   309
            centerY - r1*Math.cos(this._toRadian(startRot))
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   310
        ];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   311
        path1.end   = [
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   312
            centerX + r2*Math.sin(this._toRadian(endRot)), 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   313
            centerY - r2*Math.cos(this._toRadian(endRot))
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   314
        ];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   315
        
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   316
        // 2nd finger path
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   317
        path2.start = [
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   318
            centerX - r1*Math.sin(this._toRadian(startRot)), 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   319
            centerY + r1*Math.cos(this._toRadian(startRot))
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   320
        ];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   321
        path2.end   = [
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   322
            centerX - r2*Math.sin(this._toRadian(endRot)), 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   323
            centerY + r2*Math.cos(this._toRadian(endRot))
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   324
        ];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   325
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   326
        startScale = 1.0;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   327
        endScale = endRadius/startRadius;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   328
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   329
        // touch/gesture start
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   330
        eventQueue.add({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   331
            fn: function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   332
                var coord1, coord2, coord, touches;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   333
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   334
                // coordinate for each touch object.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   335
                coord1 = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   336
                    pageX: path1.start[0], 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   337
                    pageY: path1.start[1],
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   338
                    clientX: path1.start[0], 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   339
                    clientY: path1.start[1]
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   340
                };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   341
                coord2 = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   342
                    pageX: path2.start[0], 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   343
                    pageY: path2.start[1],
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   344
                    clientX: path2.start[0], 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   345
                    clientY: path2.start[1]
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   346
                };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   347
                touches = this._createTouchList([Y.merge({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   348
                    identifier: (id++)   
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   349
                }, coord1), Y.merge({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   350
                    identifier: (id++)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   351
                }, coord2)]);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   352
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   353
                // coordinate for top level event
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   354
                coord = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   355
                    pageX: (path1.start[0] + path2.start[0])/2,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   356
                    pageY: (path1.start[0] + path2.start[1])/2,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   357
                    clientX: (path1.start[0] + path2.start[0])/2,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   358
                    clientY: (path1.start[0] + path2.start[1])/2
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   359
                };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   360
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   361
                this._simulateEvent(this.target, TOUCH_START, Y.merge({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   362
                    touches: touches,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   363
                    targetTouches: touches,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   364
                    changedTouches: touches,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   365
                    scale: startScale,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   366
                    rotation: startRot
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   367
                }, coord));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   368
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   369
                if(Y.UA.ios >= 2.0) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   370
                    /* gesture starts when the 2nd finger touch starts.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   371
                    * The implementation will fire 1 touch start event for both fingers,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   372
                    * simulating 2 fingers touched on the screen at the same time.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   373
                    */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   374
                    this._simulateEvent(this.target, GESTURE_START, Y.merge({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   375
                        scale: startScale,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   376
                        rotation: startRot
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   377
                    }, coord));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   378
                }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   379
            },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   380
            timeout: 0,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   381
            context: this
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   382
        });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   383
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   384
        // gesture change
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   385
        steps = Math.floor(duration/interval);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   386
        radiusPerStep = (r2 - r1)/steps;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   387
        scalePerStep = (endScale - startScale)/steps;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   388
        rotPerStep = (endRot - startRot)/steps;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   389
        
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   390
        touchMove = function(step) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   391
            var radius = r1 + (radiusPerStep)*step,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   392
                px1 = centerX + radius*Math.sin(this._toRadian(startRot + rotPerStep*step)),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   393
                py1 = centerY - radius*Math.cos(this._toRadian(startRot + rotPerStep*step)),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   394
                px2 = centerX - radius*Math.sin(this._toRadian(startRot + rotPerStep*step)),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   395
                py2 = centerY + radius*Math.cos(this._toRadian(startRot + rotPerStep*step)),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   396
                px = (px1+px2)/2,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   397
                py = (py1+py2)/2,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   398
                coord1, coord2, coord, touches;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   399
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   400
            // coordinate for each touch object.    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   401
            coord1 = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   402
                pageX: px1,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   403
                pageY: py1,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   404
                clientX: px1,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   405
                clientY: py1
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   406
            };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   407
            coord2 = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   408
                pageX: px2,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   409
                pageY: py2,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   410
                clientX: px2,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   411
                clientY: py2
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   412
            };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   413
            touches = this._createTouchList([Y.merge({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   414
                identifier: (id++)   
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   415
            }, coord1), Y.merge({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   416
                identifier: (id++)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   417
            }, coord2)]);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   418
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   419
            // coordinate for top level event
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   420
            coord = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   421
                pageX: px,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   422
                pageY: py,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   423
                clientX: px,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   424
                clientY: py
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   425
            };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   426
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   427
            this._simulateEvent(this.target, TOUCH_MOVE, Y.merge({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   428
                touches: touches,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   429
                targetTouches: touches,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   430
                changedTouches: touches,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   431
                scale: startScale + scalePerStep*step,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   432
                rotation: startRot + rotPerStep*step
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   433
            }, coord));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   434
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   435
            if(Y.UA.ios >= 2.0) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   436
                this._simulateEvent(this.target, GESTURE_CHANGE, Y.merge({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   437
                    scale: startScale + scalePerStep*step,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   438
                    rotation: startRot + rotPerStep*step
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   439
                }, coord));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   440
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   441
        };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   442
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   443
        for (i=0; i < steps; i++) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   444
            eventQueue.add({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   445
                fn: touchMove,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   446
                args: [i],
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   447
                context: this
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   448
            });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   449
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   450
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   451
        // gesture end
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   452
        eventQueue.add({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   453
            fn: function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   454
                var emptyTouchList = this._getEmptyTouchList(),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   455
                    coord1, coord2, coord, touches;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   456
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   457
                // coordinate for each touch object.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   458
                coord1 = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   459
                    pageX: path1.end[0], 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   460
                    pageY: path1.end[1],
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   461
                    clientX: path1.end[0], 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   462
                    clientY: path1.end[1]
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   463
                };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   464
                coord2 = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   465
                    pageX: path2.end[0], 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   466
                    pageY: path2.end[1],
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   467
                    clientX: path2.end[0], 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   468
                    clientY: path2.end[1]
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   469
                };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   470
                touches = this._createTouchList([Y.merge({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   471
                    identifier: (id++)   
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   472
                }, coord1), Y.merge({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   473
                    identifier: (id++)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   474
                }, coord2)]);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   475
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   476
                // coordinate for top level event
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   477
                coord = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   478
                    pageX: (path1.end[0] + path2.end[0])/2,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   479
                    pageY: (path1.end[0] + path2.end[1])/2,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   480
                    clientX: (path1.end[0] + path2.end[0])/2,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   481
                    clientY: (path1.end[0] + path2.end[1])/2
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   482
                };  
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   483
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   484
                if(Y.UA.ios >= 2.0) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   485
                    this._simulateEvent(this.target, GESTURE_END, Y.merge({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   486
                        scale: endScale,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   487
                        rotation: endRot
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   488
                    }, coord));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   489
                }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   490
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   491
                this._simulateEvent(this.target, TOUCH_END, Y.merge({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   492
                    touches: emptyTouchList,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   493
                    targetTouches: emptyTouchList,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   494
                    changedTouches: touches,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   495
                    scale: endScale,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   496
                    rotation: endRot
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   497
                }, coord));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   498
            },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   499
            context: this
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   500
        });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   501
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   502
        if(cb && Y.Lang.isFunction(cb)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   503
            eventQueue.add({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   504
                fn: cb,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   505
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   506
                // by default, the callback runs the node context where 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   507
                // simulateGesture method is called.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   508
                context: this.node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   509
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   510
                //TODO: Use args to pass error object as 1st param if there is an error.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   511
                //args: 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   512
            });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   513
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   514
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   515
        eventQueue.run();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   516
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   517
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   518
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   519
     * The "tap" gesture can be used for various single touch point gestures 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   520
     * such as single tap, N number of taps, long press. The default is a single 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   521
     * tap.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   522
     * 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   523
     * @method tap
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   524
     * @param {Function} cb The callback to execute when the gesture simulation 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   525
     *      is completed.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   526
     * @param {Array} point A point(relative to the top left corner of the 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   527
     *      target node element) where the tap gesture should start. The default 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   528
     *      is the center of the taget node.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   529
     * @param {Number} times The number of taps. Default is 1.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   530
     * @param {Number} hold The hold time in milliseconds between "touchstart" and
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   531
     *      "touchend" event generation. Default is 10ms.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   532
     * @param {Number} delay The time gap in millisecond between taps if this
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   533
     *      gesture has more than 1 tap. Default is 10ms.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   534
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   535
    tap: function(cb, point, times, hold, delay) {           
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   536
        var eventQueue = new Y.AsyncQueue(),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   537
            emptyTouchList = this._getEmptyTouchList(),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   538
            touches,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   539
            coord,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   540
            i,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   541
            touchStart,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   542
            touchEnd;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   543
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   544
        point = this._calculateDefaultPoint(point);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   545
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   546
        if(!Y.Lang.isNumber(times) || times < 1) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   547
            times = 1;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   548
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   549
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   550
        if(!Y.Lang.isNumber(hold)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   551
            hold = DEFAULTS.HOLD_TAP;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   552
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   553
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   554
        if(!Y.Lang.isNumber(delay)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   555
            delay = DEFAULTS.DELAY_TAP;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   556
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   557
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   558
        coord = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   559
            pageX: point[0], 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   560
            pageY: point[1],
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   561
            clientX: point[0], 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   562
            clientY: point[1]
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   563
        };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   564
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   565
        touches = this._createTouchList([Y.merge({identifier: 0}, coord)]);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   566
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   567
        touchStart = function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   568
            this._simulateEvent(this.target, TOUCH_START, Y.merge({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   569
                touches: touches,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   570
                targetTouches: touches,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   571
                changedTouches: touches
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   572
            }, coord));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   573
        };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   574
        
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   575
        touchEnd = function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   576
            this._simulateEvent(this.target, TOUCH_END, Y.merge({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   577
                touches: emptyTouchList,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   578
                targetTouches: emptyTouchList,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   579
                changedTouches: touches
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   580
            }, coord));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   581
        };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   582
        
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   583
        for (i=0; i < times; i++) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   584
            eventQueue.add({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   585
                fn: touchStart,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   586
                context: this,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   587
                timeout: (i === 0)? 0 : delay
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   588
            });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   589
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   590
            eventQueue.add({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   591
                fn: touchEnd,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   592
                context: this,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   593
                timeout: hold
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   594
            });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   595
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   596
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   597
        if(times > 1 && !SUPPORTS_TOUCH) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   598
            eventQueue.add({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   599
                fn: function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   600
                    this._simulateEvent(this.target, MOUSE_DBLCLICK, coord);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   601
                },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   602
                context: this
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   603
            });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   604
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   605
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   606
        if(cb && Y.Lang.isFunction(cb)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   607
            eventQueue.add({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   608
                fn: cb,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   609
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   610
                // by default, the callback runs the node context where 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   611
                // simulateGesture method is called.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   612
                context: this.node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   613
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   614
                //TODO: Use args to pass error object as 1st param if there is an error.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   615
                //args: 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   616
            });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   617
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   618
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   619
        eventQueue.run();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   620
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   621
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   622
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   623
     * The "flick" gesture is a specialized "move" that has some velocity 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   624
     * and the movement always runs either x or y axis. The velocity is calculated
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   625
     * with "distance" and "duration" arguments. If the calculated velocity is 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   626
     * below than the minimum velocity, the given duration will be ignored and 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   627
     * new duration will be created to make a valid flick gesture.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   628
     *   
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   629
     * @method flick
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   630
     * @param {Function} cb The callback to execute when the gesture simulation 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   631
     *      is completed.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   632
     * @param {Array} point A point(relative to the top left corner of the 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   633
     *      target node element) where the flick gesture should start. The default 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   634
     *      is the center of the taget node.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   635
     * @param {String} axis Either "x" or "y".
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   636
     * @param {Number} distance A distance in pixels to flick.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   637
     * @param {Number} duration A duration of the gesture in millisecond.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   638
     * 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   639
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   640
    flick: function(cb, point, axis, distance, duration) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   641
        var path;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   642
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   643
        point = this._calculateDefaultPoint(point);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   644
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   645
        if(!Y.Lang.isString(axis)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   646
            axis = X_AXIS;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   647
        } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   648
            axis = axis.toLowerCase();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   649
            if(axis !== X_AXIS && axis !== Y_AXIS) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   650
                Y.error(NAME+'(flick): Only x or y axis allowed');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   651
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   652
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   653
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   654
        if(!Y.Lang.isNumber(distance)) { 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   655
            distance = DEFAULTS.DISTANCE_FLICK; 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   656
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   657
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   658
        if(!Y.Lang.isNumber(duration)){
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   659
            duration = DEFAULTS.DURATION_FLICK; // ms
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   660
        } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   661
            if(duration > DEFAULTS.MAX_DURATION_FLICK) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   662
                duration = DEFAULTS.MAX_DURATION_FLICK;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   663
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   664
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   665
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   666
        /*
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   667
         * Check if too slow for a flick.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   668
         * Adjust duration if the calculated velocity is less than 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   669
         * the minimum velcocity to be claimed as a flick.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   670
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   671
        if(Math.abs(distance)/duration < DEFAULTS.MIN_VELOCITY_FLICK) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   672
            duration = Math.abs(distance)/DEFAULTS.MIN_VELOCITY_FLICK;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   673
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   674
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   675
        path = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   676
            start: Y.clone(point),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   677
            end: [
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   678
                (axis === X_AXIS) ? point[0]+distance : point[0],
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   679
                (axis === Y_AXIS) ? point[1]+distance : point[1]
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   680
            ]
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   681
        };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   682
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   683
        this._move(cb, path, duration);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   684
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   685
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   686
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   687
     * The "move" gesture simulate the movement of any direction between 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   688
     * the straight line of start and end point for the given duration.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   689
     * The path argument is an object with "point", "xdist" and "ydist" properties.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   690
     * The "point" property is an array with x and y coordinations(relative to the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   691
     * top left corner of the target node element) while "xdist" and "ydist" 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   692
     * properties are used for the distance along the x and y axis. A negative 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   693
     * distance number can be used to drag either left or up direction. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   694
     * 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   695
     * If no arguments are given, it will simulate the default move, which
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   696
     * is moving 200 pixels from the center of the element to the positive X-axis 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   697
     * direction for 1 sec.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   698
     * 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   699
     * @method move
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   700
     * @param {Function} cb The callback to execute when the gesture simulation 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   701
     *      is completed.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   702
     * @param {Object} path An object with "point", "xdist" and "ydist".
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   703
     * @param {Number} duration A duration of the gesture in millisecond.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   704
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   705
    move: function(cb, path, duration) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   706
        var convertedPath;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   707
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   708
        if(!Y.Lang.isObject(path)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   709
            path = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   710
                point: this._calculateDefaultPoint([]),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   711
                xdist: DEFAULTS.DISTANCE_MOVE,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   712
                ydist: 0
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   713
            };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   714
        } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   715
            // convert to the page coordination
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   716
            if(!Y.Lang.isArray(path.point)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   717
                path.point = this._calculateDefaultPoint([]);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   718
            } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   719
                path.point = this._calculateDefaultPoint(path.point);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   720
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   721
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   722
            if(!Y.Lang.isNumber(path.xdist)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   723
                path.xdist = DEFAULTS.DISTANCE_MOVE;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   724
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   725
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   726
            if(!Y.Lang.isNumber(path.ydist)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   727
                path.ydist = 0;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   728
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   729
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   730
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   731
        if(!Y.Lang.isNumber(duration)){
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   732
            duration = DEFAULTS.DURATION_MOVE; // ms
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   733
        } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   734
            if(duration > DEFAULTS.MAX_DURATION_MOVE) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   735
                duration = DEFAULTS.MAX_DURATION_MOVE;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   736
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   737
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   738
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   739
        convertedPath = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   740
            start: Y.clone(path.point),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   741
            end: [path.point[0]+path.xdist, path.point[1]+path.ydist]
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   742
        };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   743
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   744
        this._move(cb, convertedPath, duration);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   745
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   746
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   747
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   748
     * A base method on top of "move" and "flick" methods. The method takes
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   749
     * the path with start/end properties and duration to generate a set of 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   750
     * touch events for the movement gesture. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   751
     *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   752
     * @method _move
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   753
     * @private
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   754
     * @param {Function} cb The callback to execute when the gesture simulation 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   755
     *      is completed.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   756
     * @param {Object} path An object with "start" and "end" properties. Each 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   757
     *      property should be an array with x and y coordination (e.g. start: [100, 50])
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   758
     * @param {Number} duration A duration of the gesture in millisecond. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   759
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   760
    _move: function(cb, path, duration) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   761
        var eventQueue,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   762
            i,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   763
            interval = EVENT_INTERVAL,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   764
            steps, stepX, stepY,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   765
            id = 0,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   766
            touchMove;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   767
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   768
        if(!Y.Lang.isNumber(duration)){
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   769
            duration = DEFAULTS.DURATION_MOVE; // ms
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   770
        } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   771
            if(duration > DEFAULTS.MAX_DURATION_MOVE) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   772
                duration = DEFAULTS.MAX_DURATION_MOVE;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   773
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   774
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   775
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   776
        if(!Y.Lang.isObject(path)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   777
            path = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   778
                start: [
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   779
                    START_PAGEX, 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   780
                    START_PAGEY
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   781
                ], 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   782
                end: [
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   783
                    START_PAGEX + DEFAULTS.DISTANCE_MOVE, 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   784
                    START_PAGEY
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   785
                ]
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   786
            };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   787
        } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   788
            if(!Y.Lang.isArray(path.start)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   789
                path.start = [
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   790
                    START_PAGEX, 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   791
                    START_PAGEY
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   792
                ];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   793
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   794
            if(!Y.Lang.isArray(path.end)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   795
                path.end = [
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   796
                    START_PAGEX + DEFAULTS.DISTANCE_MOVE, 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   797
                    START_PAGEY
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   798
                ];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   799
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   800
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   801
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   802
        Y.AsyncQueue.defaults.timeout = interval;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   803
        eventQueue = new Y.AsyncQueue();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   804
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   805
        // start
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   806
        eventQueue.add({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   807
            fn: function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   808
                var coord = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   809
                        pageX: path.start[0], 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   810
                        pageY: path.start[1],
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   811
                        clientX: path.start[0], 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   812
                        clientY: path.start[1]
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   813
                    }, 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   814
                    touches = this._createTouchList([
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   815
                        Y.merge({identifier: (id++)}, coord)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   816
                    ]);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   817
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   818
                this._simulateEvent(this.target, TOUCH_START, Y.merge({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   819
                    touches: touches,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   820
                    targetTouches: touches,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   821
                    changedTouches: touches
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   822
                }, coord));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   823
            },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   824
            timeout: 0,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   825
            context: this
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   826
        });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   827
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   828
        // move
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   829
        steps = Math.floor(duration/interval);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   830
        stepX = (path.end[0] - path.start[0])/steps;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   831
        stepY = (path.end[1] - path.start[1])/steps;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   832
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   833
        touchMove = function(step) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   834
            var px = path.start[0]+(stepX * step),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   835
                py = path.start[1]+(stepY * step), 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   836
                coord = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   837
                    pageX: px, 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   838
                    pageY: py,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   839
                    clientX: px,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   840
                    clientY: py
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   841
                }, 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   842
                touches = this._createTouchList([
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   843
                    Y.merge({identifier: (id++)}, coord)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   844
                ]);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   845
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   846
            this._simulateEvent(this.target, TOUCH_MOVE, Y.merge({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   847
                touches: touches,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   848
                targetTouches: touches,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   849
                changedTouches: touches
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   850
            }, coord));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   851
        };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   852
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   853
        for (i=0; i < steps; i++) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   854
            eventQueue.add({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   855
                fn: touchMove,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   856
                args: [i],
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   857
                context: this
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   858
            });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   859
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   860
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   861
        // last move
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   862
        eventQueue.add({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   863
            fn: function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   864
                var coord = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   865
                        pageX: path.end[0], 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   866
                        pageY: path.end[1],
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   867
                        clientX: path.end[0], 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   868
                        clientY: path.end[1]
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   869
                    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   870
                    touches = this._createTouchList([
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   871
                        Y.merge({identifier: id}, coord)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   872
                    ]);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   873
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   874
                this._simulateEvent(this.target, TOUCH_MOVE, Y.merge({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   875
                    touches: touches,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   876
                    targetTouches: touches,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   877
                    changedTouches: touches
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   878
                }, coord));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   879
            },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   880
            timeout: 0,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   881
            context: this
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   882
        });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   883
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   884
        // end
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   885
        eventQueue.add({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   886
            fn: function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   887
                var coord = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   888
                    pageX: path.end[0], 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   889
                    pageY: path.end[1],
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   890
                    clientX: path.end[0], 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   891
                    clientY: path.end[1]
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   892
                },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   893
                emptyTouchList = this._getEmptyTouchList(),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   894
                touches = this._createTouchList([
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   895
                    Y.merge({identifier: id}, coord)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   896
                ]);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   897
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   898
                this._simulateEvent(this.target, TOUCH_END, Y.merge({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   899
                    touches: emptyTouchList,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   900
                    targetTouches: emptyTouchList,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   901
                    changedTouches: touches
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   902
                }, coord));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   903
            },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   904
            context: this
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   905
        });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   906
        
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   907
        if(cb && Y.Lang.isFunction(cb)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   908
            eventQueue.add({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   909
                fn: cb,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   910
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   911
                // by default, the callback runs the node context where 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   912
                // simulateGesture method is called.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   913
                context: this.node
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   914
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   915
                //TODO: Use args to pass error object as 1st param if there is an error.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   916
                //args: 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   917
            });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   918
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   919
        
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   920
        eventQueue.run();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   921
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   922
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   923
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   924
     * Helper method to return a singleton instance of empty touch list.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   925
     * 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   926
     * @method _getEmptyTouchList
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   927
     * @private
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   928
     * @return {TouchList | Array} An empty touch list object.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   929
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   930
    _getEmptyTouchList: function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   931
        if(!emptyTouchList) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   932
            emptyTouchList = this._createTouchList([]);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   933
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   934
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   935
        return emptyTouchList;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   936
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   937
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   938
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   939
     * Helper method to convert an array with touch points to TouchList object as
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   940
     * defined in http://www.w3.org/TR/touch-events/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   941
     * 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   942
     * @method _createTouchList
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   943
     * @private
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   944
     * @param {Array} touchPoints 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   945
     * @return {TouchList | Array} If underlaying platform support creating touch list
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   946
     *      a TouchList object will be returned otherwise a fake Array object 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   947
     *      will be returned.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   948
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   949
    _createTouchList: function(touchPoints) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   950
        /*
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   951
        * Android 4.0.3 emulator:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   952
        * Native touch api supported starting in version 4.0 (Ice Cream Sandwich).
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   953
        * However the support seems limited. In Android 4.0.3 emulator, I got
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   954
        * "TouchList is not defined".
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   955
        */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   956
        var touches = [],
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   957
            touchList,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   958
            self = this;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   959
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   960
        if(!!touchPoints && Y.Lang.isArray(touchPoints)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   961
            if(Y.UA.android && Y.UA.android >= 4.0 || Y.UA.ios && Y.UA.ios >= 2.0) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   962
                Y.each(touchPoints, function(point) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   963
                    if(!point.identifier) {point.identifier = 0;}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   964
                    if(!point.pageX) {point.pageX = 0;}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   965
                    if(!point.pageY) {point.pageY = 0;}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   966
                    if(!point.screenX) {point.screenX = 0;}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   967
                    if(!point.screenY) {point.screenY = 0;}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   968
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   969
                    touches.push(document.createTouch(Y.config.win, 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   970
                        self.target,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   971
                        point.identifier, 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   972
                        point.pageX, point.pageY, 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   973
                        point.screenX, point.screenY));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   974
                });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   975
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   976
                touchList = document.createTouchList.apply(document, touches);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   977
            } else if(Y.UA.ios && Y.UA.ios < 2.0) { 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   978
                Y.error(NAME+': No touch event simulation framework present.');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   979
            } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   980
                // this will inclide android(Y.UA.android && Y.UA.android < 4.0) 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   981
                // and desktops among all others. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   982
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   983
                /*
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   984
                 * Touch APIs are broken in androids older than 4.0. We will use 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   985
                 * simulated touch apis for these versions. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   986
                 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   987
                touchList = [];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   988
                Y.each(touchPoints, function(point) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   989
                    if(!point.identifier) {point.identifier = 0;}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   990
                    if(!point.clientX)  {point.clientX = 0;}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   991
                    if(!point.clientY)  {point.clientY = 0;}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   992
                    if(!point.pageX)    {point.pageX = 0;}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   993
                    if(!point.pageY)    {point.pageY = 0;}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   994
                    if(!point.screenX)  {point.screenX = 0;}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   995
                    if(!point.screenY)  {point.screenY = 0;}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   996
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   997
                    touchList.push({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   998
                        target: self.target,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   999
                        identifier: point.identifier,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1000
                        clientX: point.clientX,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1001
                        clientY: point.clientY,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1002
                        pageX: point.pageX,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1003
                        pageY: point.pageY,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1004
                        screenX: point.screenX,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1005
                        screenY: point.screenY
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1006
                    });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1007
                });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1008
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1009
                touchList.item = function(i) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1010
                    return touchList[i];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1011
                };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1012
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1013
        } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1014
            Y.error(NAME+': Invalid touchPoints passed');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1015
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1016
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1017
        return touchList;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1018
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1019
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1020
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1021
     * @method _simulateEvent
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1022
     * @private
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1023
     * @param {HTMLElement} target The DOM element that's the target of the event.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1024
     * @param {String} type The type of event or name of the supported gesture to simulate 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1025
     *      (i.e., "click", "doubletap", "flick").
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1026
     * @param {Object} options (Optional) Extra options to copy onto the event object. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1027
     *      For gestures, options are used to refine the gesture behavior.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1028
     * @return {void}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1029
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1030
    _simulateEvent: function(target, type, options) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1031
        var touches;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1032
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1033
        if (touchEvents[type]) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1034
            if(SUPPORTS_TOUCH) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1035
                Y.Event.simulate(target, type, options);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1036
            } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1037
                // simulate using mouse events if touch is not applicable on this platform.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1038
                // but only single touch event can be simulated.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1039
                if(this._isSingleTouch(options.touches, options.targetTouches, options.changedTouches)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1040
                    type = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1041
                        touchstart: MOUSE_DOWN,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1042
                        touchmove: MOUSE_MOVE,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1043
                        touchend: MOUSE_UP
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1044
                    }[type];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1045
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1046
                    options.button = 0;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1047
                    options.relatedTarget = null; // since we are not using mouseover event.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1048
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1049
                    // touchend has none in options.touches.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1050
                    touches = (type === MOUSE_UP)? options.changedTouches : options.touches;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1051
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1052
                    options = Y.mix(options, {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1053
                        screenX: touches.item(0).screenX,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1054
                        screenY: touches.item(0).screenY,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1055
                        clientX: touches.item(0).clientX,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1056
                        clientY: touches.item(0).clientY
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1057
                    }, true);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1058
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1059
                    Y.Event.simulate(target, type, options);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1060
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1061
                    if(type == MOUSE_UP) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1062
                        Y.Event.simulate(target, MOUSE_CLICK, options);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1063
                    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1064
                } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1065
                    Y.error("_simulateEvent(): Event '" + type + "' has multi touch objects that can't be simulated in your platform.");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1066
                }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1067
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1068
        } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1069
            // pass thru for all non touch events
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1070
            Y.Event.simulate(target, type, options);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1071
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1072
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1073
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1074
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1075
     * Helper method to check the single touch.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1076
     * @method _isSingleTouch
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1077
     * @private
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1078
     * @param {TouchList} touches
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1079
     * @param {TouchList} targetTouches
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1080
     * @param {TouchList} changedTouches
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1081
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1082
    _isSingleTouch: function(touches, targetTouches, changedTouches) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1083
        return (touches && (touches.length <= 1)) && 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1084
            (targetTouches && (targetTouches.length <= 1)) &&
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1085
            (changedTouches && (changedTouches.length <= 1));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1086
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1087
};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1088
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1089
/*
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1090
 * A gesture simulation class.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1091
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1092
Y.GestureSimulation = Simulations;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1093
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1094
/*
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1095
 * Various simulation default behavior properties. If user override 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1096
 * Y.GestureSimulation.defaults, overriden values will be used and this 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1097
 * should be done before the gesture simulation.  
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1098
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1099
Y.GestureSimulation.defaults = DEFAULTS;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1100
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1101
/*
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1102
 * The high level gesture names that YUI knows how to simulate.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1103
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1104
Y.GestureSimulation.GESTURES = gestureNames;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1105
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1106
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1107
 * Simulates the higher user level gesture of the given name on a target. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1108
 * This method generates a set of low level touch events(Apple specific gesture 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1109
 * events as well for the iOS platforms) asynchronously. Note that gesture  
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1110
 * simulation is relying on `Y.Event.simulate()` method to generate 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1111
 * the touch events under the hood. The `Y.Event.simulate()` method
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1112
 * itself is a synchronous method.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1113
 * 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1114
 * Users are suggested to use `Node.simulateGesture()` method which 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1115
 * basically calls this method internally. Supported gestures are `tap`, 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1116
 * `doubletap`, `press`, `move`, `flick`, `pinch` and `rotate`.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1117
 * 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1118
 * The `pinch` gesture is used to simulate the pinching and spreading of two
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1119
 * fingers. During a pinch simulation, rotation is also possible. Essentially
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1120
 * `pinch` and `rotate` simulations share the same base implementation to allow
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1121
 * both pinching and rotation at the same time. The only difference is `pinch`
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1122
 * requires `start` and `end` option properties while `rotate` requires `rotation` 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1123
 * option property.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1124
 * 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1125
 * The `pinch` and `rotate` gestures can be described as placing 2 fingers along a
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1126
 * circle. Pinching and spreading can be described by start and end circles while 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1127
 * rotation occurs on a single circle. If the radius of the start circle is greater 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1128
 * than the end circle, the gesture becomes a pinch, otherwise it is a spread spread.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1129
 * 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1130
 * @example
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1131
 *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1132
 *     var node = Y.one("#target");
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1133
 *       
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1134
 *     // double tap example
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1135
 *     node.simulateGesture("doubletap", function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1136
 *         // my callback function
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1137
 *     });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1138
 *     
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1139
 *     // flick example from the center of the node, move 50 pixels down for 50ms)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1140
 *     node.simulateGesture("flick", {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1141
 *         axis: y,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1142
 *         distance: -100
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1143
 *         duration: 50
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1144
 *     }, function() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1145
 *         // my callback function
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1146
 *     });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1147
 *     
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1148
 *     // simulate rotating a node 75 degrees counter-clockwise 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1149
 *     node.simulateGesture("rotate", {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1150
 *         rotation: -75
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1151
 *     });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1152
 *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1153
 *     // simulate a pinch and a rotation at the same time. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1154
 *     // fingers start on a circle of radius 100 px, placed at top/bottom
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1155
 *     // fingers end on a circle of radius 50px, placed at right/left 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1156
 *     node.simulateGesture("pinch", {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1157
 *         r1: 100,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1158
 *         r2: 50,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1159
 *         start: 0
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1160
 *         rotation: 90
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1161
 *     });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1162
 *     
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1163
 * @method simulateGesture
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1164
 * @param {HTMLElement|Node} node The YUI node or HTML element that's the target 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1165
 *      of the event.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1166
 * @param {String} name The name of the supported gesture to simulate. The 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1167
 *      supported gesture name is one of "tap", "doubletap", "press", "move", 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1168
 *      "flick", "pinch" and "rotate". 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1169
 * @param {Object} [options] Extra options used to define the gesture behavior:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1170
 * 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1171
 *      Valid options properties for the `tap` gesture:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1172
 *      
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1173
 *      @param {Array} [options.point] (Optional) Indicates the [x,y] coordinates 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1174
 *        where the tap should be simulated. Default is the center of the node 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1175
 *        element.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1176
 *      @param {Number} [options.hold=10] (Optional) The hold time in milliseconds. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1177
 *        This is the time between `touchstart` and `touchend` event generation.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1178
 *      @param {Number} [options.times=1] (Optional) Indicates the number of taps.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1179
 *      @param {Number} [options.delay=10] (Optional) The number of milliseconds 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1180
 *        before the next tap simulation happens. This is valid only when `times` 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1181
 *        is more than 1. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1182
 *        
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1183
 *      Valid options properties for the `doubletap` gesture:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1184
 *      
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1185
 *      @param {Array} [options.point] (Optional) Indicates the [x,y] coordinates 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1186
 *        where the doubletap should be simulated. Default is the center of the 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1187
 *        node element.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1188
 * 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1189
 *      Valid options properties for the `press` gesture:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1190
 *      
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1191
 *      @param {Array} [options.point] (Optional) Indicates the [x,y] coordinates 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1192
 *        where the press should be simulated. Default is the center of the node 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1193
 *        element.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1194
 *      @param {Number} [options.hold=3000] (Optional) The hold time in milliseconds. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1195
 *        This is the time between `touchstart` and `touchend` event generation. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1196
 *        Default is 3000ms (3 seconds).
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1197
 * 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1198
 *      Valid options properties for the `move` gesture:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1199
 *      
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1200
 *      @param {Object} [options.path] (Optional) Indicates the path of the finger 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1201
 *        movement. It's an object with three optional properties: `point`, 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1202
 *        `xdist` and  `ydist`.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1203
 *        @param {Array} [options.path.point] A starting point of the gesture.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1204
 *          Default is the center of the node element.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1205
 *        @param {Number} [options.path.xdist=200] A distance to move in pixels  
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1206
 *          along the X axis. A negative distance value indicates moving left.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1207
 *        @param {Number} [options.path.ydist=0] A distance to move in pixels  
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1208
 *          along the Y axis. A negative distance value indicates moving up.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1209
 *      @param {Number} [options.duration=1000] (Optional) The duration of the 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1210
 *        gesture in milliseconds.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1211
 * 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1212
 *      Valid options properties for the `flick` gesture:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1213
 *      
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1214
 *      @param {Array} [options.point] (Optional) Indicates the [x, y] coordinates 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1215
 *        where the flick should be simulated. Default is the center of the 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1216
 *        node element.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1217
 *      @param {String} [options.axis='x'] (Optional) Valid values are either 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1218
 *        "x" or "y". Indicates axis to move along. The flick can move to one of 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1219
 *        4 directions(left, right, up and down).
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1220
 *      @param {Number} [options.distance=200] (Optional) Distance to move in pixels
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1221
 *      @param {Number} [options.duration=1000] (Optional) The duration of the 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1222
 *        gesture in milliseconds. User given value could be automatically 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1223
 *        adjusted by the framework if it is below the minimum velocity to be 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1224
 *        a flick gesture.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1225
 * 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1226
 *      Valid options properties for the `pinch` gesture:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1227
 *      
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1228
 *      @param {Array} [options.center] (Optional) The center of the circle where 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1229
 *        two fingers are placed. Default is the center of the node element.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1230
 *      @param {Number} [options.r1] (Required) Pixel radius of the start circle 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1231
 *        where 2 fingers will be on when the gesture starts. The circles are 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1232
 *        centered at the center of the element.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1233
 *      @param {Number} [options.r2] (Required) Pixel radius of the end circle 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1234
 *        when this gesture ends.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1235
 *      @param {Number} [options.duration=1000] (Optional) The duration of the 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1236
 *        gesture in milliseconds.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1237
 *      @param {Number} [options.start=0] (Optional) Starting degree of the first 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1238
 *        finger. The value is relative to the path of the north. Default is 0 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1239
 *        (i.e., 12:00 on a clock).
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1240
 *      @param {Number} [options.rotation=0] (Optional) Degrees to rotate from 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1241
 *        the starting degree. A negative value means rotation to the 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1242
 *        counter-clockwise direction.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1243
 * 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1244
 *      Valid options properties for the `rotate` gesture:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1245
 *      
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1246
 *      @param {Array} [options.center] (Optional) The center of the circle where 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1247
 *        two fingers are placed. Default is the center of the node element.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1248
 *      @param {Number} [options.r1] (Optional) Pixel radius of the start circle 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1249
 *        where 2 fingers will be on when the gesture starts. The circles are 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1250
 *        centered at the center of the element. Default is a fourth of the node 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1251
 *        element width or height, whichever is smaller.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1252
 *      @param {Number} [options.r2] (Optional) Pixel radius of the end circle 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1253
 *        when this gesture ends. Default is a fourth of the node element width or 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1254
 *        height, whichever is smaller.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1255
 *      @param {Number} [options.duration=1000] (Optional) The duration of the 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1256
 *        gesture in milliseconds.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1257
 *      @param {Number} [options.start=0] (Optional) Starting degree of the first 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1258
 *        finger. The value is relative to the path of the north. Default is 0 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1259
 *        (i.e., 12:00 on a clock).
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1260
 *      @param {Number} [options.rotation] (Required) Degrees to rotate from 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1261
 *        the starting degree. A negative value means rotation to the 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1262
 *        counter-clockwise direction.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1263
 * 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1264
 * @param {Function} [cb] The callback to execute when the asynchronouse gesture  
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1265
 *      simulation is completed. 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1266
 *      @param {Error} cb.err An error object if the simulation is failed.  
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1267
 * @return {void}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1268
 * @for Event
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1269
 * @static
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1270
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1271
Y.Event.simulateGesture = function(node, name, options, cb) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1272
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1273
    node = Y.one(node);    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1274
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1275
    var sim = new Y.GestureSimulation(node);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1276
    name = name.toLowerCase();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1277
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1278
    if(!cb && Y.Lang.isFunction(options)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1279
        cb = options;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1280
        options = {};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1281
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1282
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1283
    options = options || {};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1284
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1285
    if (gestureNames[name]) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1286
        switch(name) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1287
            // single-touch: point gestures 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1288
            case 'tap':
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1289
                sim.tap(cb, options.point, options.times, options.hold, options.delay);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1290
                break;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1291
            case 'doubletap':
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1292
                sim.tap(cb, options.point, 2);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1293
                break;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1294
            case 'press':
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1295
                if(!Y.Lang.isNumber(options.hold)) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1296
                    options.hold = DEFAULTS.HOLD_PRESS;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1297
                } else if(options.hold < DEFAULTS.MIN_HOLD_PRESS) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1298
                    options.hold = DEFAULTS.MIN_HOLD_PRESS;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1299
                } else if(options.hold > DEFAULTS.MAX_HOLD_PRESS) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1300
                    options.hold = DEFAULTS.MAX_HOLD_PRESS;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1301
                }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1302
                sim.tap(cb, options.point, 1, options.hold);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1303
                break;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1304
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1305
            // single-touch: move gestures 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1306
            case 'move':
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1307
                sim.move(cb, options.path, options.duration);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1308
                break;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1309
            case 'flick':
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1310
                sim.flick(cb, options.point, options.axis, options.distance, 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1311
                    options.duration);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1312
                break;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1313
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1314
            // multi-touch: pinch/rotation gestures
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1315
            case 'pinch':
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1316
                sim.pinch(cb, options.center, options.r1, options.r2, 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1317
                    options.duration, options.start, options.rotation);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1318
                break;    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1319
            case 'rotate':
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1320
                sim.rotate(cb, options.center, options.r1, options.r2, 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1321
                    options.duration, options.start, options.rotation);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1322
                break;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1323
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1324
    } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1325
        Y.error(NAME+': Not a supported gesture simulation: '+name);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1326
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1327
};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1328
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1329
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
  1330
}, '3.10.3', {"requires": ["async-queue", "event-simulate", "node-screen"]});