【前端】用javaScript实现实现一个球池的效果

ballPool

  用javaScript实现实现一个球池的效果,实现效果如下所示:

动图:

 【前端】用javaScript实现实现一个球池的效果

截图:

【前端】用javaScript实现实现一个球池的效果

HTML代码:

<!DOCTYPE html>
<html >
<head>
  	<meta charset="UTF-8">
  	<title>ball pool</title>
  	<link rel="stylesheet" href="css/style.css">
</head>
<body>
  	<div class="instructions">
   		<p >触摸你的屏幕/或移动你的鼠标</p>
	</div>
	<script src='http://cdnjs.cloudflare.com/ajax/libs/pixi.js/4.5.1/pixi.min.js'></script>
	<script src='https://cdnjs.cloudflare.com/ajax/libs/jquery/3.1.1/jquery.min.js'></script>
    <script src="js/index.js"></script>
</body>
</html>

  

CSS代码:

body {
  margin:0;
  overflow:hidden;
  color:rgba(255,255,255,.5);
  font-family:arial;
  font-size: 3em;
  font-family: '幼圆';
  color: #fff;
  text-shadow: 1px 1px 10px #000;
  position: relative;

}

canvas {
  background: #dbdbdb;
}

.instructions {
  position: absolute;
   100%;
}

#title{
  display: inline-block;;
  border: 2px solid transparent;
  box-shadow: 1px 1px 20px #000;
   100%;
  margin: auto;
  padding:  3px 0 3px 0;
  text-align: center;
  background: inherit;
  opacity: 0.8;
  position: fixed;
  cursor: none;
  border-radius: 0 0 20px 20px;
}

  

JAVASCRIPT代码:

// *******************
// 初始化
// *******************

const userDefined = {
  gravity: 10,
  friction: .99,
  ballSize: 65,
  wallFriction: .5,
  distribution: 10,
  spread: 10
}

const colours = [
  '0xf20053',
  '0xfffc00',
  '0x0070ff',
  '0x00ffff',
  '0x00ff00', 
  '0xffb2aa'
]

const coloursLength = colours.length;
const halfSpread = userDefined.spread/2;
var mouse = {x:0,y:0};
var oldMouse = {x:0,y:0};
var balls = [];


// *******************
// 图像
// *******************

const pixelTexture = PIXI.Texture.fromImage('');

// *******************
//窗口尺寸
// *******************

var windowDimensions = {
   window.innerWidth,
  height: window.innerHeight
}

// *******************
// 设置 pixi
// *******************

const app = new PIXI.Application(windowDimensions.width, windowDimensions.height, { 
    antialias: true, transparent: true 
  });
document.body.appendChild(app.view);

// *******************
// DOM
// *******************

$(window).on('resize', function () {  
  
  windowDimensions = {
     window.innerWidth,
    height: window.innerHeight
  }  
  
  app.renderer.resize(windowDimensions.width,windowDimensions.height);
  
});

$(window).on('mousemove touchmove', function (e) {

  mouse = {
    x: e.originalEvent.touches ? e.originalEvent.touches[0].pageX : e.pageX,
    y: e.originalEvent.touches ? e.originalEvent.touches[0].pageY : e.pageY,
  }
  
  for (let i = 0, length = Math.random()*userDefined.distribution; i < length; i++) {
    
    createBall(
      mouse.x, 
      mouse.y,
      (mouse.x - oldMouse.x)*Math.random(), 
      (mouse.y - oldMouse.y)*Math.random());
    
  }

  oldMouse = {
    x: mouse.x,
    y: mouse.y
  }
  
});


// *******************
// 创建小球
// *******************

function createBall (x, y, xv, yv) {  
    var ball = new PIXI.Sprite(pixelTexture);
    ball.x = x;
    ball.y = y;
    ball.width = ball.height = userDefined.ballSize;
    ball.xv = xv + (-halfSpread+Math.random()*userDefined.spread);
    ball.yv = yv + (-halfSpread+Math.random()*userDefined.spread);
    ball.tint = colours[Math.floor(Math.random()*coloursLength)];
    balls.push(ball);  
    app.stage.addChild(ball);    
}


// *******************
// 开始窗口
// *******************

setTimeout(function () {
  for (let i = 0, length = userDefined.distribution*100; i < length; i++) {  

    createBall(
      Math.random()*windowDimensions.width, 
      Math.random()*(-windowDimensions.height),
      -5+Math.random()*10,
      -5+Math.random()*10)
  }
}, 2500);

// ******************
// 小球运动周期
// ******************   
(function loop() {
  for (let i = 0, length = balls.length; i < length; i++) {
    //移动
    balls[i].x += balls[i].xv;
    balls[i].y += balls[i].yv+userDefined.gravity; 
    
    //通过摩擦力减速
    balls[i].xv *= userDefined.friction;
    balls[i].yv *= userDefined.friction;
    
    //禁止出界
    if (balls[i].x <= 0) {
      balls[i].x = 0;      
    } else if (balls[i].x >= windowDimensions.width-userDefined.ballSize) {
      balls[i].x = windowDimensions.width-userDefined.ballSize;      
    }
    
    //弹离
    if (balls[i].x <= 0 || balls[i].x >= windowDimensions.width-userDefined.ballSize) {
      
      //反转
      balls[i].xv*=-1;
      
      //减速
      balls[i].xv *= userDefined.wallFriction;
    }
  }

  // 清除
  for (let i = 0, length = balls.length; i < length; i++) {

    if (balls[i].y >= windowDimensions.height) {
      app.stage.removeChild(balls[i]); 
      balls.splice(i, 1);
      length--; 
    }

  }   
  //再次运行
  requestAnimationFrame(loop);

})();