按下键时响应鼠标移动(Javascript,jQuery)

时间:2013-03-24 03:11:53

标签: javascript javascript-events event-handling three.js mousemove

编辑:看起来问题出在触摸板而不是鼠标上。

目标: 即使正在按下按键,也能够响应鼠标移动。

我想修改Three.js的PointerLockControls,以便:如果用户在按下“W”时移动鼠标,则摄像机应继续向前移动,摄像机的方向也应根据鼠标移动而改变。这种情况在正常情况下不会发生。以下是听众:

mousemove事件的监听器:

var onMouseMove = function ( event ) {
    var movementX = event.movementX || event.mozMovementX || event.webkitMovementX || 0;
    camera.rotation.y-=movementX*0.002;
  };

keydown事件的监听器:

var onKeyDown = function ( event ) {

        case 38: // up
        case 87: // w
            moveForward = true;
            break;
        //keys: a, s, d are handled similarly

        case 32: // space
            if ( canJump === true ) velocity.y += 10;
            canJump = false;
            break;
   }

关键字事件的监听器:

var onKeyUp = function(event){
        case 38: // up
        case 87: // w
            moveForward = false;
            break;
}

我发现,如果按“W”时按空格键,则播放器继续向前移动并响应鼠标移动。这就是我想要的效果(但即使没有击中空格键也应该有效)。

1 个答案:

答案 0 :(得分:2)

通常,操作系统会在键入时禁用触控板。你应该找到一个选项,在你的操作系统设置上切换它。