>  기사  >  웹 프론트엔드  >  JavaScript에서 포물선 운동을 시뮬레이션하기 위한 코드 예제에 대한 자세한 설명

JavaScript에서 포물선 운동을 시뮬레이션하기 위한 코드 예제에 대한 자세한 설명

黄舟
黄舟원래의
2017-03-15 14:35:231825검색

포물선 운동은 중력 유도에 의해 발생하는 일종의 운동입니다. 이 기사에서는 간단한 JavaScript 코드를 사용하여 포물선 운동 구현을 시뮬레이션합니다. 다음 코드는 JavaScript를 배우는 데 매우 유용합니다.

이 JavaScript 코드는 중력 상태 에서 포물선 운동을 시뮬레이션합니다. 다음 매개변수를 설정할 수 있습니다: 가로 초기 속도, 세로 초기 속도, 중력 가속도(이 가속도가 다음과 같이 변경되는 값인 경우) time , 다른 비균일 가속 동작의 효과를 얻을 수 있습니다.), 애니메이션 간격 시간 등, 비교적 전문적인 코드는 다음과 같습니다.

<!doctype html>
<html>
<head>
<title>js抛物运动</title>
<meta charset="utf-8" />
<style type="text/css">
*{padding:0;margin:0;}
body{font-size:13px;padding:10px;}
p{margin:2px;}
.wrap{position:relative;width:1000px;height:550px;margin:0 auto;border:1px solid #ccc;margin-top:50px;}
#fall{width:20px;font-size:1px;height:20px;background:#000;position:absolute;top:0;left:0;}
</style>
</head>
<body>
<h3>模拟重力状态下的抛物运动(假使1px==1mm)</h3>
<p>横向初速度:<input id="Vx" type="text" value="2" />px/ms</p>
<p>纵向初速度:<input id="Vy" type="text" value="-2" />px/ms</p>
<p>重力加速度:<input id="a" type="text" value="0.0098" />px/平方ms</p>
<p>(如果这个加速度是一个随时间变化的值,就能达到其他非匀加速运动的效果了。)</p>
<p>单位时间:<input id="t" type="text" value="10" />(记录运动的时间间隔)
<p><input type="button" value="演示" onclick="demo(document.getElementById(&#39;Vx&#39;).value, document.getElementById(&#39;Vy&#39;).value, 
document.getElementById(&#39;a&#39;).value, document.getElementById(&#39;t&#39;).value)"/></p>
<p class="wrap">
<p id="fall">o</p>
</p>
</body>
<script type="text/javascript">
function demo(x,y,a,t) {
var f=document.getElementById(&#39;fall&#39;);
var Vx=parseInt(x),
Vy=parseInt(y),
g=a,
t=parseInt(t),
h=0,l=0,Sx=0,Sy=0;
var i=setInterval(function(){
if(f){
Sx+=Vx*t;
l=Sx;
Vy+=g*t;
h+=Vy*t;
f.style.left=l+&#39;px&#39;;
f.style.top=h+&#39;px&#39;;
if(h>500||l>900)clearInterval(i);
}
},t);
}
</script>
</html>

여기를 클릭하면 됩니다. 포물선 운동 데모 효과의 JavaScript 시뮬레이션을 참조하세요.

위 내용은 JavaScript에서 포물선 운동을 시뮬레이션하기 위한 코드 예제에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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