プログラミングとイラストレーション » 等速・等加速度運動の組合せに反発係数と抵抗力を追加|HTML5
プログラミングとイラストレーション > HTML5 > 等速・等加速度運動の組合せに反発係数と抵抗力を追加|HTML5

等速・等加速度運動の組合せに反発係数と抵抗力を追加|HTML5

等速・等加速度運動の組合せに反発係数と抵抗力を追加|HTML5

等速・等加速度運動の組合せに反発係数と抵抗力を追加|HTML5(HTML5, JavaScript, CSS3) : デモ

等速・等加速度運動の組合せに反発係数と抵抗力を追加|HTML5(HTML5, JavaScript, CSS3) : ZIPファイル(8kb)

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/devicecheck.js"></script>
        <script src="js/base.js"></script>
    </head>
    <body>
        <div id="contents">
            <canvas id="canvas" width="275" height="275"></canvas>
        </div>
        <div id="txt">x: 0<br/>y: 0</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;
}
 
#txt
{
    position: absolute;
    top: 10px;
    left: 10px;
    width: 250px;
    height:10px;
}

3.JavaScript

base.js

window.addEventListener("load", init, false);
  
var ctx = null;
var theCanvas = null;
  
var ball1 = new Object();
ball1.initVy = -10;//y軸の初期速度
ball1.x = 5;//x軸の位置
ball1.y = 270;//y軸の位置
ball1.vx = 5;//x軸の速度
ball1.vy = ball1.initVy;//y軸の速度
ball1.ax = 0;//x軸の加速度
ball1.ay = 0.1;//y軸の加速度(重力加速度)
ball1.r = 10;//ボールの半径
ball1.rebound = 0.9;//反発係数
ball1.friction = 0.98;//抵抗力
 
var t = 1000/60;//時間
  
function init()
{
    document.getElementById('canvas').addEventListener('touchstart', function() 
    {
        event.preventDefault();
    });
    document.getElementById('canvas').addEventListener('touchmove', function() 
    {
        event.preventDefault();
    });
    document.getElementById('canvas').addEventListener('touchend', function() 
    {
        event.preventDefault();
    });
     
    //ボタンタイプ
    if(g_mobiledevice==true)
    {
        buttonDown = 'touchstart';
        buttonMove = 'touchmove';
        buttonUp = 'touchend';
    }
    else
    {
        buttonDown = 'mousedown';
        buttonMove = 'mousemove';
        buttonUp = 'mouseup';
    }
     
    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',''));
     
    theContents.addEventListener(buttonDown, downHandler, false);
      
    setBallAnimation();
}
 
function downHandler()
{
    ball1.initVy = -10;//y軸の初期速度
    ball1.x = 5;//x軸の位置
    ball1.y = 270;//y軸の位置
    ball1.vx = 5;//x軸の速度
    ball1.vy = ball1.initVy;//y軸の速度
    ball1.ax = 0;//x軸の加速度
    ball1.ay = 0.1;//y軸の加速度(重力加速度)
}
  
function setBallAnimation()
{
    ctx = document.getElementById('canvas').getContext("2d");
    setInterval(animation, t);
}
  
function animation()
{
    ctx.clearRect(0,0,300,300);
    ctx.strokeStyle = "#000000";
    ctx.lineWidth = 1;
    ctx.beginPath();
    ctx.arc(moveX(), moveY(), ball1.r, 0, Math.PI*2, true);
    ctx.fill();
    ctx.stroke();
    document.getElementById('txt').innerHTML = 'x: '+moveX()+'<br/>y: '+moveY();
}
 
function moveX()
{
    if(ball1.x - ball1.r < 0)
    {
        ball1.x = ball1.r;
        ball1.vx = Math.abs(ball1.vx)*ball1.rebound;
    }
    else
    if(ball1.x + ball1.r > offsetX)
    {
        ball1.x = offsetX-ball1.r;
        ball1.vx = -Math.abs(ball1.vx)*ball1.rebound;
    }
    ball1.x = ball1.x + ball1.vx;
    return ball1.x;
}
  
function moveY()
{
    if(ball1.y - ball1.r < 0)
    {
        ball1.y = ball1.r;
        ball1.initVy = ball1.initVy*ball1.rebound;
        ball1.vy = ball1.initVy;
        ball1.vy = Math.abs(ball1.vy);
    }
    else
    if(ball1.y + ball1.r > offsetY)
    {
        ball1.y = offsetY-ball1.r;
        ball1.initVy = ball1.initVy*ball1.rebound;
        ball1.vy = ball1.initVy;
        ball1.vy = -Math.abs(ball1.vy);
    }
    ball1.vy = (ball1.vy*ball1.friction) + ball1.ay;
    ball1.y = ball1.y + ball1.vy;
    return ball1.y;
}

devicecheck.js

var g_mobiledevice = false; //iPhone、iPad、Androidのときtrue
var g_browsername = 'unknown';
var g_browserver = -1;
 
if(checkUserAgent() == false)
{
    window.alert('このブラウザは対象外です');
}
 
function checkUserAgent()
{
    var ua = navigator.userAgent;
 
    //iPhoneか?  
    var mstr = ua.match(/iPhone OS \d+/);
    if(mstr != null){
        var vstr = mstr[0].match(/\d+/);
        if(parseInt(vstr[0]) >= 3) 
        {
            g_mobiledevice = true;
            g_browsername = 'iPhone';
            //alert('major-version ' + vstr);
            return true;
        }
    }
    //iPadか?
    if(ua.indexOf('iPad') > -1)
    {
        mstr = ua.match(/CPU OS \d+/);
        if(mstr != null)
        {
            var vstr = mstr[0].match(/\d+/);
            if(parseInt(vstr[0]) >= 3) {
                g_mobiledevice = true;
                g_browsername = 'iPad';
                //alert('major-version ' + vstr);
                return true;
            }       
        }       
    }   
    //Androidか? 
    var mstr = ua.match(/Android \d+\.\d+/);
    if(mstr != null)
    {
        g_browsername = 'Android';
        var vstr = mstr[0].match(/\d+\.\d+/);
        g_browserver = parseFloat(vstr[0]);
        g_mobiledevice = true;
        if(pg_browserver > 2.1) 
        {
            //alert('version ' + vstr);
            return true;
        }
    }
    //Chromeか?
    mstr = ua.match(/Chrome\/\d+/);
    if(mstr != null)
    {
        g_browsername = 'Chrome';
        var vstr = mstr[0].match(/\d+/);
        g_browserver = parseInt(vstr[0]);
        if(g_browserver >= 9) 
        {
            //alert('major-version ' + vstr);
             
            return true;
        }       
    }
    //Safariか?
    if(ua.indexOf('Safari') > -1)
    {
        mstr = ua.match(/Version\/\d+/);
        if(mstr != null){
            var vstr = mstr[0].match(/\d+/);
            if(parseInt(vstr[0]) >= 5) 
            {
                g_browsername = 'Safari';
                //alert('major-version ' + vstr);
                return true;
            }       
        }       
    }
    //Internet Explorerか?
    mstr = ua.match(/MSIE \d+/);
    if(mstr != null)
    {
        var vstr = mstr[0].match(/\d+/);
        if(parseInt(vstr[0]) >= 9) 
        {
            g_browsername = 'MSIE';
            //alert('major-version ' + vstr);
            return true;
        }       
    }
    //Firefoxか?
    mstr = ua.match(/Firefox\/\d+/);
    if(mstr != null){
        var vstr = mstr[0].match(/\d+/);
        if(parseInt(vstr[0]) >= 4) 
        {
            g_browsername = 'Firefox';
            //alert('major-version ' + vstr);
            return true;
        }       
    }
    //Operaか?
    if(ua.indexOf('Opera') > -1)
    {
        mstr = ua.match(/Version\/\d+/);
        if(mstr != null){
            var vstr = mstr[0].match(/\d+/);
            if(parseInt(vstr[0]) >= 11) 
            {
                g_browsername = 'Opera';
                //alert('major-version ' + vstr);
                return true;
            }       
        }       
    }
     
    return false;
}

コメントを残す

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

コメントフィード

トラックバック URL : http://www.htmlcode.jp/%e7%ad%89%e9%80%9f%e3%83%bb%e7%ad%89%e5%8a%a0%e9%80%9f%e5%ba%a6%e9%81%8b%e5%8b%95%e3%81%ae%e7%b5%84%e5%90%88%e3%81%9b%e3%81%ab%e5%8f%8d%e7%99%ba%e4%bf%82%e6%95%b0%e3%81%a8%e6%8a%b5%e6%8a%97%e5%8a%9b/trackback/