【前端】用javaScript实现实现一个球池的效果
ballPool
用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 id="title">触摸你的屏幕/或移动你的鼠标</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;
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实现实现一个球池的效果的更多相关文章
- [总结]web前端常用JavaScript代码段及知识点集锦
DOM相关 判断浏览器是否支持placeholder属性 function placeholderSupport() { return 'placeholder' in document.create ...
- WEB前端常用JavaScript代码整理
文章目录 html代码用JS动态加载进页面 JS判断用户访问的是PC还是mobile或者微信浏览器 判断浏览器的简单有效方法 点击某个div区域之外,隐藏该div 如何在手机上禁止浏览器的网页滚动 改 ...
- 前端之JavaScript基础
前端之JavaScript基础 本节内容 JS概述 JS基础语法 JS循环控制 ECMA对象 BOM对象 DOM对象 1. JS概述 1.1. javascript历史 1992年Nombas开发出C ...
- 互联网公司前端初级Javascript面试题
互联网公司前端初级Javascript面试题 1.JavaScript是一门什么样的语言,它有哪些特点?(简述javascript语言的特点)JavaScript是一种基于对象(Object)和事件驱 ...
- 第三篇:web之前端之JavaScript基础
前端之JavaScript基础 前端之JavaScript基础 本节内容 JS概述 JS基础语法 JS循环控制 ECMA对象 BOM对象 DOM对象 1. JS概述 1.1. javascript ...
- 好程序员web前端分享javascript关联数组用法总结
好程序员web前端分享javascript关联数组用法总结,有需要的朋友可以参考下. Hash关联数组定义 代码如下 // 定义空数组 myhash = { } // 直接定义数组 myhash = ...
- 前端-JavaScript1-1——JavaScript简介
1.1 JavaScript用途 前端三层: 结构层 HTML 从语义的角度描述页面的结构 样式层 CSS 从审美的角度装饰页面 行为层 J ...
- 前端之JavaScript(二)
一.概述 本篇主要介绍JavaScript的BOM和DOM操作,在前端之JavaScript(一)中介绍了JavaScript基础知识 1.1.BOM和DOM BOM(Browser Object M ...
- Python web前端 05 JavaScript
Python web前端 05 JavaScript 一.获取元素 1.初识JavaScript /* .. */ #这是多行注释 // #这是单行注释 #JavaScript是一种脚本语言,是一种动 ...
随机推荐
- 如何给MFC的菜单项添加快捷键
我们一起分享,如何给MFC的菜单项添加快捷键.[程序在VC6.0编译环境下编译通过.(VS2010的编译环境大同小异)] 1.程序演示环境 1.1新建一个[对话框(Dialog)]的程序.然后,New ...
- QQ空间发表日志的图片上传功能实现
w间接促使了用户注意图片的顺序,进一步优化的方向的是手指触动或鼠标点击来同时进行图片的增删和调序,避免精确的数字输入. 有效code <form action="wcon/wact&q ...
- Spark源码分析 – Shuffle
参考详细探究Spark的shuffle实现, 写的很清楚, 当前设计的来龙去脉 Hadoop Hadoop的思路是, 在mapper端每次当memory buffer中的数据快满的时候, 先将memo ...
- mybatis调用oracle存储过程例子.
1.MYBATIS方法: <select id="getFlowNum" statementType="CALLABLE"> <![CDATA ...
- leetcode 去除单链表倒数第k个节点
Given a linked list, remove the n-th node from the end of list and return its head. Example: Given l ...
- Apache mahout 源码阅读笔记-DataModel之UserBaseRecommender
先来看一下使用流程: 1)拿到DataModel 2)定义相似度计算模型 PearsonCorrelationSimilarity 3)定义用户邻域计算模型 NearestNUserNeighborh ...
- 学习HashMap的笔记
对于HashMap只是学习了下put,remove方法,hashMap是数组+链表+红黑树组成 所以下面贴出我自己给代码的注释,看不懂的见谅哈,毕竟我也是刚了解,如果有错误的地方请指出,非常感谢 pu ...
- javaScript 调用构造函数 Array() 时没有使用参数, length总是0
如果调用构造函数 Array() 时没有使用参数,那么返回的数组为空,length 字段为 0. 当调用构造函数时只传递给它一个数字参数,该构造函数将返回具有指定个数.元素为 undefined 的数 ...
- django URL的补充 默认值 传多个参数
url 后面还可以加上默认值 默认值 url(r'^index/', views.index, {'name': 'root'}), urls.py url对应关系 from django.conf. ...
- Spring第七弹—依赖注入之注解方式注入及编码解析@Resource原理
注入依赖对象可以采用手工装配或自动装配,在实际应用中建议使用手工装配,因为自动装配会产生未知情况,开发人员无法预见最终的装配结果. 手工装配依赖对象 手工装配依赖对象,在这种方式中又有两种编 ...