js 포인트 포켓 게임 실현
주: 만약에 작은 공이 밑에 있는 네모난 덩어리의 각과 충돌한다면 포인트는 약간의 버그가 있을 수 있습니다
<style>
  #box {
   width: 400px;
   height: 400px;
   border: 1px solid #000000;
   margin: 50px auto;
   position: relative;
  }
  #ball {
   height: 60px;
   width: 60px;
   border-radius: 50%;
   background-color: red;
   position: absolute;
   left: 0;
   top: 0;
  }
  #block {
   width: 100px;
   height: 20px;
   position: absolute;
   left: 150px;
   bottom: 0;
   background-color: black;
  }
  #count {
   color: #ff0000;
   font-size: 18px;
   position: absolute;
   width: 20px;
   height: 20px;
   left: -20px;
   top: 0;
  }
</style>
<body>
 <div id="box">
  <div id="count">0</div>
  <div id="ball"></div>
  <div id="block"></div>
 </div>
</body>
<script>
 var oBox = document.querySelector('#box');
 var oBall = document.querySelector('#ball');
 var oBlock = document.querySelector('#block');
 var oCount = document.querySelector('#count');
 var speedBlock = 5;
 var speedX = 5;
 var speedY = 4;
 var maxLeft = oBox.clientWidth - oBall.offsetWidth;
 var maxTop = oBox.clientHeight - oBall.offsetHeight;
 var max = oBox.clientWidth - oBlock.offsetWidth;
 setInterval(function () {
  var left = oBall.offsetLeft;
  var top = oBall.offsetTop;
  left += speedX;
  top += speedY;
  if (left < 0 || left > maxLeft) {
   speedX = -speedX;
  }
  if (top < 0) {
   speedY *= -1;
  }
  var r = oBall.offsetWidth / 2;
  if (left >= oBlock.offsetLeft - r && //  
   left <= oBlock.offsetLeft - r + oBlock.offsetWidth && //  
   top >= maxTop - oBlock.offsetHeight   //  
  ) {
   // console.log(' ');
   speedY = -Math.abs(speedY);
   // speedY *= -1;
   oCount.innerHTML = oCount.innerHTML * 1 + 1;
  }
  if (top > maxTop) {
   left = 0;
   top = 0;
  }
  oBall.style.left = left + 'px';
  oBall.style.top = top + 'px';
 }, 50);
 document.onkeydown = function (e) {
  var ev = event || e;
  var keyCode = ev.keyCode || ev.which;
  var left = oBlock.offsetLeft;
  if (keyCode === 37) {
   left -= speedBlock;
  }
  if (keyCode === 39) {
   left += speedBlock;
  }
  if (left <= 0) {
   left = 0
  }
  if (left >= max) {
   left = max;
  }
  oBlock.style.left = left + 'px';
 }
</script>이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
[2022.04.19] 자바스크립트 this - 생성자 함수와 이벤트리스너에서의 this18일에 this에 대해 공부하면서 적었던 일반적인 함수나 객체에서의 this가 아닌 오늘은 이벤트리스너와 생성자 함수 안에서의 this를 살펴보기로 했다. new 키워드를 붙여 함수를 생성자로 사용할 때 this는...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.