首页 > 代码库 > 【前端】用javaScript实现实现一个球池的效果
【前端】用javaScript实现实现一个球池的效果
ballPool
用javaScript实现实现一个球池的效果,实现效果如下所示:
动图:
截图:
HTML代码:
<!DOCTYPE html> <html > <head> <meta charset="UTF-8"> <title>ball pool</title> <link rel="stylesheet" href="http://www.mamicode.com/css/style.css"> </head> <body> <div class="instructions"> <p id="title">触摸你的屏幕/或移动你的鼠标</p> </div> <script src=http://www.mamicode.com/‘http://cdnjs.cloudflare.com/ajax/libs/pixi.js/4.5.1/pixi.min.js‘></script>"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; width: 100%; } #title{ display: inline-block;; border: 2px solid transparent; box-shadow: 1px 1px 20px #000; width: 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 = { width: 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 = { width: 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); })();
【前端】用javaScript实现实现一个球池的效果
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。