Вход Регистрация
Файл: theme/selemet/jquery.event.swipe.js
Строк: 140
<?php
// jQuery.event.swipe
// 0.5
// Stephen Band

// Dependencies
// jQuery.event.move 1.2

// One of swipeleft, swiperight, swipeup or swipedown is triggered on
// moveend, when the move has covered a threshold ratio of the dimension
// of the target node, or has gone really fast. Threshold and velocity
// sensitivity changed with:
//
// jQuery.event.special.swipe.settings.threshold
// jQuery.event.special.swipe.settings.sensitivity

(function (module) {
    if (
typeof define === 'function' && define.amd) {
        
// AMD. Register as an anonymous module.
        
define(['jquery'], module);
    } else {
        
// Browser globals
        
module(jQuery);
    }
})(function(
jQueryundefined){
    var 
add jQuery.event.add,
       
        
remove jQuery.event.remove,

        
// Just sugar, so we can have arguments in the same order as
        // add and remove.
        
trigger = function(nodetypedata) {
            
jQuery.event.trigger(typedatanode);
        },

        
settings = {
            
// Ratio of distance over target finger must travel to be
            // considered a swipe.
            
threshold0.4,
            
// Faster fingers can travel shorter distances to be considered
            // swipes. 'sensitivity' controls how much. Bigger is shorter.
            
sensitivity6
        
};

    function 
moveend(e) {
        var 
whevent;

        
e.currentTarget.offsetWidth;
        
e.currentTarget.offsetHeight;

        
// Copy over some useful properties from the move event
        
event = {
            
distXe.distX,
            
distYe.distY,
            
velocityXe.velocityX,
            
velocityYe.velocityY,
            
fingere.finger
        
};

        
// Find out which of the four directions was swiped
        
if (e.distX e.distY) {
            if (
e.distX > -e.distY) {
                if (
e.distX/settings.threshold || e.velocityX e.distX/settings.sensitivity 1) {
                    
event.type 'swiperight';
                    
trigger(e.currentTargetevent);
                }
            }
            else {
                if (-
e.distY/settings.threshold || e.velocityY e.distY/settings.sensitivity 1) {
                    
event.type 'swipeup';
                    
trigger(e.currentTargetevent);
                }
            }
        }
        else {
            if (
e.distX > -e.distY) {
                if (
e.distY/settings.threshold || e.velocityY e.distY/settings.sensitivity 1) {
                    
event.type 'swipedown';
                    
trigger(e.currentTargetevent);
                }
            }
            else {
                if (-
e.distX/settings.threshold || e.velocityX e.distX/settings.sensitivity 1) {
                    
event.type 'swipeleft';
                    
trigger(e.currentTargetevent);
                }
            }
        }
    }

    function 
getData(node) {
        var 
data jQuery.data(node'event_swipe');
        
        if (!
data) {
            
data = { count};
            
jQuery.data(node'event_swipe'data);
        }
        
        return 
data;
    }

    
jQuery.event.special.swipe =
    
jQuery.event.special.swipeleft =
    
jQuery.event.special.swiperight =
    
jQuery.event.special.swipeup =
    
jQuery.event.special.swipedown = {
        
setup: function( datanamespaceseventHandle ) {
            var 
data getData(this);

            
// If another swipe event is already setup, don't setup again.
            
if (data.count++ > 0) { return; }

            
add(this'moveend'moveend);

            return 
true;
        },

        
teardown: function() {
            var 
data getData(this);

            
// If another swipe event is still setup, don't teardown.
            
if (--data.count 0) { return; }

            
remove(this'moveend'moveend);

            return 
true;
        },

        
settingssettings
    
};
});
?>
Онлайн: 0
Реклама