js五彩小球

<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style type="text/css">
*{
margin: 0px;
padding: 0px;
}
html,body{
height: 100%;
width: 100%;
overflow: hidden; /*隐藏滚动条,消除小球碰到滚动条出现的窗口闪动*/
}
.content{
width: 100%;
height: 100%;
position: relative;
background: black;
}
.ball{
position: absolute;
border-radius: 50%;
}
</style>
</head>
<body>
<div class="content" id="con"></div>
<script type="text/javascript">
//定义随机函数
function RandomNum(num1,num2){
return Math.floor(Math.random()*(num2-num1+1)+num1);
}
//构造小球函数
function Ball(){
this.ball=document.createElement("div");
var randomNum=RandomNum(20,50);
this.width=randomNum
this.height=randomNum
//如果元素有id名,我们可以直接使用,不用document.get....获取
this.left=RandomNum(0,con.offsetWidth-randomNum);
this.top=RandomNum(0,con.offsetHeight-randomNum);
this.backgroundColor="rgba("+RandomNum(0,255)+","+RandomNum(0,255)+","+RandomNum(0,255)+","+Math.random()+")";//随机颜色
this.tempX=this.left;
this.tempY=this.top;
this.speedx=RandomNum(10,20)-15.5;//后面的小数是保证随机产生的方向有正有负
this.speedy=RandomNum(10,20)-15.5;
}
//画小球的方法
Ball.prototype.draw=function(){
this.ball.style.width=this.width+"px";
this.ball.style.height=this.height+"px";
this.ball.className="ball";
this.ball.style.left=this.tempX+"px";
this.ball.style.top=this.tempY+"px";
this.ball.style.backgroundColor=this.backgroundColor;
con.appendChild(this.ball);
}
//运动函数
Ball.prototype.move=function(){
this.tempX=this.tempX+this.speedx;
this.tempY=this.tempY+this.speedy;
// 判断临界值
if(this.tempX+this.width>=document.body.clientWidth||this.tempX<=0){
this.speedx = -this.speedx;//改变方向
}
if(this.tempY+this.height>=document.body.clientHeight||this.tempY<=0) {
this.speedy = -this.speedy;
}
this.draw();
}
//产生小球
var balls=[];
for(var i=0;i<100;i++){
var ball=new Ball();
balls.push(ball);//生成的小球对象放进数组
}
function start(){
for(var i = 0;i < balls.length;i++) {
balls[i].move();
}
}
window.onload=function(){
setInterval(start,10);//设置定时器
}
</script>
</body>
</html>
js五彩小球的更多相关文章
- js实现小球的弹性碰撞。
前 言 MYBG 小编最近在做自己的个人网站,其中就用到了一个小球碰撞检测的功能,想自己写,无奈本人能力不足啊(毕竟还是一个菜鸟)!!就想着找个插件用一下也好,可是找了好久也没有找到一个比较好用 ...
- js实现小球碰撞游戏
效果图: 效果图消失只是截的gif图的问题 源码: <!DOCTYPE html> <html lang="en"> <head> <m ...
- js中小球碰壁反弹
一. 在指定容器内的碰壁反弹 <!DOCTYPE HTML> <html> <head> <title></title> <meta ...
- Canvas+Js制作动量守恒的小球碰撞
目的:通过js实现小球碰撞并实现动量守恒 canvas我们就不多说了,有用着呢. 我们可以通过canvas画2D图形(圆.方块.三角形等等)3D图形(球体.正方体等待). 当然这只是基础的皮毛而已,c ...
- 撩课-Web架构师养成系列第一篇
前言 Web架构师养成系列共15篇,每周更新一篇,主要分享.探讨目前大前端领域(前端.后端.移动端)企业中正在用的各种成熟的.新的技术.部分文章也会分析一些框架的底层实现,让我们做到知其然知其所以然. ...
- Unity3D 5.x 简单实例 - 脚本编写
1,Vector3 类型变量存储向量坐标值 Vector3.forward Vector3(0,0,1) Vector3.up Vector3(0,1,0) Vector3.right Vector3 ...
- [js高手之路]html5 canvas动画教程 - 边界判断与小球粒子模拟喷泉,散弹效果
备注:本文后面的代码,如果加载了ball.js,那么请使用这篇文章[js高手之路] html5 canvas动画教程 - 匀速运动的ball.js代码. 本文,我们要做点有意思的效果,首先,来一个简单 ...
- js实现多个小球碰撞
实现思路:小球的移动,是通过改变小球的left和top值来改变,坐标分别为(x,y)当x/y值加到最大,即加到父级的宽度或者高度时,使x值或者y值减小,同理当x值或者y值减到最小时,同样的使x值或者y ...
- 原生js小球运动
//html代码 <input type="button" value="小球运动" /> <div></div> //js ...
随机推荐
- Dart的List比较特殊的几个API
List里面常用的属性和方法: 常用属性: length 长度 reversed 翻转 isEmpty 是否为空 isNotEmpty 是否不为空 常用方法: add 增加 addAll 拼接数组 i ...
- LintCode上的一道算法面试题: 数字的统计
说到数字的统计,小时候的数学课大家都应该有学过,但数字太多太复杂的,手动肯定耗时间不说还很容易出错.所以今天分享一下如何用程序来完成. Have you met this question in a ...
- [Abp vNext微服务实践] - 启动流程
前几篇分别介绍了abp vNext微服务框架和微服务CI/CD环境搭建,本篇开始介绍vNext微服务框架的开发环境搭建. 环境准备 官方介绍的系统架构图如下: 上图中身份服务和网关服务已经集成在系统中 ...
- 如何在SpringBoot的 过滤器之中注入Bean对象
我建立一个全局拦截器,此拦截器主要用于拦截APP用户登录和请求API时候,必须加密,我把它命名为SecurityFilter,它继承了Filter,web应用启动的顺序是:listener->f ...
- string::cbegin string::cend
const_iterator cbegin() const noexcept; const_iterator cend() const noexcept;注:返回常量迭代器,不能修改 #include ...
- Linux文件系统之删除文件、文件夹(rm,rmdir)
rm命令,rmdir命令 rm命令Remove,功能:1)删除目录,2)删除文件. (可以递归的删除指定目录的所有文件及子目录) 注意:rm是一个危险的命令,使用的时候要特别当心,尤其对于初学者来说 ...
- python3正则表达式总结
转自csdn,去这里看更多吧: https://blog.csdn.net/weixin_40136018/article/details/81183504 还有一个废话很多的详细系列,在这里:htt ...
- 粗暴,干就完了----徐晓冬似的C语言自学笔记-----实现一个链表结构
#include <stdio.h> #include <stdlib.h> #define N 5 /*N 假定数组长度为5*/ typedef struct snode { ...
- IDEA 安装与破解(亲测有效)
本文转载:https://blog.csdn.net/g_blue_wind/article/details/74380483 根据以下的流程,顺利安装了最新版本的idea企业版. IDEA 全称 I ...
- Appium Python核心API
adb命令模拟按键事件 :http://blog.sina.com.cn/s/blog_68f262210102vc1b.html