rc-gesture
Version:
Support gesture for react component
149 lines (141 loc) • 4.13 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.now = now;
exports.calcMutliFingerStatus = calcMutliFingerStatus;
exports.calcMoveStatus = calcMoveStatus;
exports.calcRotation = calcRotation;
exports.getEventName = getEventName;
exports.shouldTriggerSwipe = shouldTriggerSwipe;
exports.shouldTriggerDirection = shouldTriggerDirection;
exports.getDirection = getDirection;
exports.getMovingDirection = getMovingDirection;
exports.getDirectionEventName = getDirectionEventName;
var _config = require('./config');
function _calcTriangleDistance(x, y) {
return Math.sqrt(x * x + y * y);
} /* tslint:disable:no-bitwise */
function _calcAngle(x, y) {
var radian = Math.atan2(y, x);
return 180 / (Math.PI / radian);
}
function now() {
return Date.now();
}
function calcMutliFingerStatus(touches) {
if (touches.length < 2) {
return;
}
var _touches$ = touches[0],
x1 = _touches$.x,
y1 = _touches$.y;
var _touches$2 = touches[1],
x2 = _touches$2.x,
y2 = _touches$2.y;
var deltaX = x2 - x1;
var deltaY = y2 - y1;
return {
x: deltaX,
y: deltaY,
z: _calcTriangleDistance(deltaX, deltaY),
angle: _calcAngle(deltaX, deltaY)
};
}
function calcMoveStatus(startTouches, touches, time) {
var _startTouches$ = startTouches[0],
x1 = _startTouches$.x,
y1 = _startTouches$.y;
var _touches$3 = touches[0],
x2 = _touches$3.x,
y2 = _touches$3.y;
var deltaX = x2 - x1;
var deltaY = y2 - y1;
var deltaZ = _calcTriangleDistance(deltaX, deltaY);
return {
x: deltaX,
y: deltaY,
z: deltaZ,
time: time,
velocity: deltaZ / time,
angle: _calcAngle(deltaX, deltaY)
};
}
function calcRotation(startMutliFingerStatus, mutliFingerStatus) {
var startAngle = startMutliFingerStatus.angle;
var angle = mutliFingerStatus.angle;
return angle - startAngle;
}
function getEventName(prefix, status) {
return prefix + status[0].toUpperCase() + status.slice(1);
}
function shouldTriggerSwipe(delta, velocity) {
return Math.abs(delta) >= _config.SWIPE.threshold && Math.abs(velocity) > _config.SWIPE.velocity;
}
function shouldTriggerDirection(direction, directionSetting) {
if (directionSetting & direction) {
return true;
}
return false;
}
/**
* @private
* get the direction between two points
* Note: will change next version
* @param {Number} x
* @param {Number} y
* @return {Number} direction
*/
function getDirection(x, y) {
if (x === y) {
return _config.DIRECTION_NONE;
}
if (Math.abs(x) >= Math.abs(y)) {
return x < 0 ? _config.DIRECTION_LEFT : _config.DIRECTION_RIGHT;
}
return y < 0 ? _config.DIRECTION_UP : _config.DIRECTION_DOWN;
}
/**
* @private
* get the direction between tow points when touch moving
* Note: will change next version
* @param {Object} point1 coordinate point, include x & y attributes
* @param {Object} point2 coordinate point, include x & y attributes
* @return {Number} direction
*/
function getMovingDirection(point1, point2) {
var x1 = point1.x,
y1 = point1.y;
var x2 = point2.x,
y2 = point2.y;
var deltaX = x2 - x1;
var deltaY = y2 - y1;
if (deltaX === 0 && deltaY === 0) {
return _config.DIRECTION_NONE;
}
if (Math.abs(deltaX) >= Math.abs(deltaY)) {
return deltaX < 0 ? _config.DIRECTION_LEFT : _config.DIRECTION_RIGHT;
}
return deltaY < 0 ? _config.DIRECTION_UP : _config.DIRECTION_DOWN;
}
function getDirectionEventName(direction) {
var name = void 0;
switch (direction) {
case _config.DIRECTION_NONE:
break;
case _config.DIRECTION_LEFT:
name = 'left';
break;
case _config.DIRECTION_RIGHT:
name = 'right';
break;
case _config.DIRECTION_UP:
name = 'up';
break;
case _config.DIRECTION_DOWN:
name = 'down';
break;
default:
}
return name;
}
;