速度と加速度方向が異なる円運動|HTML5

速度と加速度方向が異なる円運動|HTML5

速度と加速度方向が異なる円運動|HTML5(HTML5, JavaScript, CSS3) : デモ

速度と加速度方向が異なる円運動|HTML5(HTML5, JavaScript, CSS3) : ZIPファイル(3kb)

1.HTML

<!DOCTYPE html>
<html lang="jp">
    <head>
        <meta charset="UTF-8" />
        <title>速度と加速度方向が異なる円運動</title>
        <link href="css/base.css" rel="stylesheet" type="text/css">
        <script src="js/base.js"></script>
    </head>
    <body>
        <div id="contents">
            <canvas id="canvas" width="275" height="275"></canvas>
        </div>
    </body>
</html>

2.CSS

@charset "utf-8";
 
body
{
    margin:0;
    padding:0;
    background-color: #fff;
    font-family:Helvetica, HiraKakuProN-W3, sans-serif; 
    font-size:12px;
    color:#000;
}
 
#contents
{
    position: absolute;
    top: 0;
    left: 0;
    width: 275px;
    height:275px;
    border: 1px solid #000;
    overflow:hidden;
}
 
#canvas
{
    position: absolute;
    top: 0;
    left: 0;
    width: 275px;
    height:275px;
}

3.JavaScript

base.js

window.addEventListener("load", init, false);
  
var ctx = null;
var theCanvas = null;
 
var ball1 = new Object();
ball1.x = 150;//x軸の位置
ball1.y = 30;//y軸の位置
ball1.vx = 10;//x軸の初期速度
ball1.vy = 0;//y軸の初期速度
ball1.ax = 0;//x軸の加速度
ball1.ay = 0;//y軸の加速度
ball1.r = 10;//ボールの半径
 
var t = 1000/60;//時間
 
function init()
{
    var theContents = document.getElementById("contents");
    offsetX = (theContents.currentStyle || document.defaultView.getComputedStyle(theContents,'')).width;
    offsetX = Number(offsetX.replace('px',''));
     
    
      
    offsetY = (theContents.currentStyle || document.defaultView.getComputedStyle(theContents,'')).height;
    offsetY = Number(offsetY.replace('px',''));
     
    offsetX=offsetX/2;
    offsetY=offsetY/2;
     
    setBallAnimation();
}
 
function setBallAnimation()
{
    ctx = document.getElementById('canvas').getContext("2d");
    setInterval(animation, t);
}
 
function moveX()
{
    var ddx = ball1.x + 5-offsetX;
    ball1.vx = ball1.vx - (ddx*0.01);
    ball1.x += ball1.vx;
     
    return ball1.x;
}
 
function moveY()
{
    var ddy = ball1.y + 5-offsetY;
    ball1.vy = ball1.vy - (ddy*0.01);
    //ball1.vy += ball1.ay;
    ball1.y += ball1.vy;
     
     
    return ball1.y;
}
 
function animation()
{
    ctx.clearRect(0,0,300,300);   
    ctx.strokeStyle = "#000000";
    ctx.lineWidth = 1;
    ctx.fillStyle = "#000000";
    ctx.beginPath();
    ctx.arc(moveX(),  moveY(), ball1.r,0,Math.PI*2,true);
    ctx.fill();
    ctx.stroke();
}

コメントを残す

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です