> 웹 프론트엔드 > JS 튜토리얼 > JS를 통해 포물선 모션을 구현하는 방법(자세한 튜토리얼)

JS를 통해 포물선 모션을 구현하는 방법(자세한 튜토리얼)

亚连
풀어 주다: 2018-06-08 17:47:50
원래의
2760명이 탐색했습니다.

이 글은 주로 JS가 구현하는 포물선 운동 효과를 소개하고, 자바스크립트 포물선 운동의 관련 연산과 요소 동적 연산의 구현 기술을 예제 형식으로 분석합니다. 도움이 필요한 친구들은 참고할 수 있습니다

이 글의 예제 JS가 구현하는 포물선 운동 효과를 설명합니다. 참고용으로 모두와 공유하세요. 세부 사항은 다음과 같습니다.

실행 효과를 먼저 살펴보겠습니다.

구체 코드는 다음과 같습니다.

<!doctype html >
<html>
<head>
  <meta charset="utf-8"/>
  <title>抛物线运动</title>
  <style>
    .pwx_rect{position:absolute;left:10px;top:300px;background-color:#888;height:50px;width:50px;}
    .pwx_hr{border-top:2px solid #ddd;position:absolute;width:98%;left:0px;top:350px;}
  </style>
  <script>
    test = function(){
      var rect = document.getElementById("rect");
      pwx(rect,60,5); //参数2:抛物线角度,参数3:横向速度每次增加5
    }
    function pwx(rect,radian,step){
      var animate = function(opt){
        var cos = Math.cos(opt.radian*Math.PI/180);//邻边比斜边,60度的话等于1/2
        var sin = Math.sin(opt.radian*Math.PI/180);//对边比斜边,30度的话等于1/2
        var left = opt.rect.offsetLeft;
        var top = opt.rect.offsetTop;
        if(opt.radian>0){
          left+=opt.step;
          opt.radian-=1; //角度递减1
          var a = left - opt.initLeft;
          var c = (a/cos);
          var b = (sin*c);
          opt.rect.style.left = opt.initLeft+a+"px";
          opt.rect.style.top = opt.initTop-b+"px";
          setTimeout(function(){
            animate(opt);
          },10);
        }else{
          opt.rect.style.left = left+opt.step+"px";
          opt.rect.style.top = opt.initTop+"px";
        }
      }
      animate({
        step : step,
        rect : rect,
        radian : radian,
        initTop : rect.offsetTop,
        initLeft : rect.offsetLeft
      });
    }
  </script>
</head>
<body>
www.jb51.net
<input type="button" value="抛物线" onclick="test()"/>
  <p class="pwx_rect" id="rect"></p>
  <p class="pwx_hr"></p>
</body>
</html>
로그인 후 복사

구현 아이디어:

The X 방향의 변 길이는 5씩 증가하고 각도는 1씩 감소합니다. 이 두 가지 알려진 조건에 따라 Y 방향의 길이는 삼각 함수

를 통해 계산되어 좌표 값을 얻을 수 있습니다. ​​각 움직임의 X, Y 방향을 포물선 효과로 표현한 것입니다

위에서 모두를 위해 정리한 내용이 앞으로 모든 분들께 도움이 되기를 바랍니다.

관련 기사:

webpack에서 아이콘 글꼴 글꼴 아이콘을 사용하는 방법

WeChat 애플릿에서 원형 진행률 표시줄을 구현하는 방법

webpack에서 동적으로 파일 가져오기 구현

위 내용은 JS를 통해 포물선 모션을 구현하는 방법(자세한 튜토리얼)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
js
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿