>웹 프론트엔드 >JS 튜토리얼 >JavaScript 게임에서 동시에 누른 키를 어떻게 감지할 수 있습니까?

JavaScript 게임에서 동시에 누른 키를 어떻게 감지할 수 있습니까?

DDD
DDD원래의
2024-12-14 21:36:16775검색

How Can I Detect Simultaneously Pressed Keys in JavaScript Games?

JavaScript에서 여러 키를 동시에 누르는 것을 감지하는 방법

문제 설명

JavaScript 게임 엔진에서는 스페이스 키를 누르면 점프 기능이 실행됩니다. , 오른쪽 화살표 키를 누르면 오른쪽 이동이 시작됩니다. 사용자가 오른쪽 화살표 키를 누른 다음 Space 키를 누르면 문제가 발생합니다. 이 시나리오에서는 캐릭터가 점프하고 움직임을 멈춥니다. 목표는 이러한 시나리오를 효과적으로 처리하기 위해 여러 키를 동시에 눌렀는지 확인하는 것입니다.

해결책

여러 키 입력을 감지하려면 이벤트 리스너 기능을 사용할 수 있습니다.

onkeydown = onkeyup = function(event) {
  // event object contains information about the key pressed
  const key = event.keyCode; // Use event.key for modern browsers (more reliable)
  // map stores the pressed keys and their current states (true/false)
  const map[key] = event.type == "keydown";
};

이 코드 조각은 keydown 및 keyup 이벤트 리스너를 설정합니다. 키를 누르면 해당 keyCode가 해당 상태(눌린 경우 true, 눌린 경우 false)와 함께 지도 객체에 기록됩니다.

키 조합 확인

동시에 눌린 여러 키를 확인하려면 , 조건부 논리를 사용할 수 있습니다.

if (map[key1] && map[key2] && map[key3]) {
  // Do something when all three keys are pressed
}

이 접근 방식을 사용하면 포괄적인 키 조합 감지가 가능합니다.

추가 고려 사항

  • 브라우저 기본값: 일부 브라우저에는 특정 키 조합에 대한 기본 동작이 있습니다(예: 북마크의 경우 Ctrl D). 충돌을 방지하려면 event.preventDefault()를 사용하여 기본 작업을 중지하는 것이 좋습니다.
  • Event.keyCode 사용 중단: 최신 브라우저에서는 대신 event.key를 사용해야 합니다. event.keyCode는 더 이상 사용되지 않습니다.
  • return false 사용;: return 거짓; 이벤트 전파 및 키 누르기의 기본 동작을 방지하는 데 사용할 수 있지만 이 접근 방식은 의도하지 않은 결과를 초래할 수 있습니다.
  • 이벤트 핸들러: 보다 원활한 이벤트 처리 및 예측 가능한 동작.
  • 도우미 클래스: 사용자 정의 도우미 클래스는 작업을 단순화할 수 있습니다. 키 누르기 상태를 관리하고 특정 키 조합에 대한 감시점을 설정합니다.

위 내용은 JavaScript 게임에서 동시에 누른 키를 어떻게 감지할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.