问题描述
我正在尝试使用jGestures实现触摸效果. swipeone可以正常工作,但其他任何东西(向左滑动,向右滑动等)都不会触发.
I'm trying to implement touch evens with jGestures. swipeone works fine but anything else (swipeleft, swiperight etc) is not firing.
<div id="wrap" style="height:500px; width:500px; background: blue;">
</div>
<script type="text/javascript">
$('#wrap').bind('swipeleft', function(){
alert("test");
});
</script>
这只是我所做的测试页.它实际上在我的主项目中正在工作,但似乎根本没有任何原因停止,甚至当我恢复到较旧的版本时也是如此.我尝试了其他版本的jGestures,但没有运气.
This is just a test page I did. It was actually working at one point in my main project but seemed to have stopped for no reason at all, not even when I reverted to an older version. I've tried a different version of jGestures with no luck.
推荐答案
SwipeLeft,SwipeRight,-Up和-Down实施得很差.仅当您完全停留在开始触摸事件的轴上时,它们才会被触发.例如,仅当手指从(X,Y)(120,0)移至(250,0)时,SwipeRight才起作用.
SwipeLeft, SwipeRight, -Up and -Down are kind of poorly implemented. They are only triggered if you stay EXACTLY on the axis where you started the touch event.For example, SwipeRight will only work if your finger moves from (X,Y) (120, 0) to (250, 0).
如果起点和终点的Y坐标不同,则将无法正常工作.
If the Y-Coordinates from Start- and Endpoint differ, it's not gonna work.
jGestures.js(大约1095行)应该看起来像这样(可读):
jGestures.js (ca. line 1095) should better look something like this (readable):
/**
* U Up, LU LeftUp, RU RightUp, etc.
*
* \U|U/
* LU\|/RU
*L---+---R
* LD/|\RD
* /D|D\
*
*/
if ( _bHasTouches && _bHasMoved === true && _bHasSwipeGesture===true) {
_bIsSwipe = true;
var deltaX = _oDetails.delta[0].lastX;
var deltaY = _oDetails.delta[0].lastY;
var hor = ver = '';
if (deltaX > 0) { // right
hor = 'right';
if (deltaY > 0) {
ver = 'down'
} else {
ver = 'up';
}
if (Math.abs(deltaY) < deltaX * 0.3) {
ver = '';
} else if (Math.abs(deltaY) >= deltaX * 2.2) {
hor = '';
}
} else { // left
hor = 'left';
if (deltaY > 0) {
ver = 'down'
} else {
ver = 'up';
}
if (Math.abs(deltaY) < Math.abs(deltaX) * 0.3) {
ver = '';
} else if (Math.abs(deltaY) > Math.abs(deltaX) * 2.2) {
hor = '';
}
}
// (_oDetails.delta[0].lastX < 0) -> 'left'
// (_oDetails.delta[0].lastY > 0) -> 'down'
// (_oDetails.delta[0].lastY < 0) -> 'up'
// alert('function swipe_' + hor + '_' + ver);
_oDetails.type = ['swipe', hor, ver].join('');
_$element.triggerHandler(_oDetails.type, _oDetails);
}
这篇关于只有swipeone与jGestures一起使用的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!