爱易网
IT新闻
IT新闻
爱易资讯
网站搭建
云虚拟主机教程
云服务器教程
Apache教程
IIS教程
Nginx教程
网站策划
站长文章
推广教程
淘宝客教程
网页设计
HTML教程
XHTML教程
CSS教程
HTML5教程
CSS3教程
JavaSript基础
JQuery教程
Node.js教程
前端技术
Ajax教程
Js特效
Xml教程
平面设计
页面UI设计
photoshop教程
程序开发
AI人工智能
Asp教程
Php教程
Asp.Net教程
Net Core教程
C#教程
Java教程
Jsp教程
开发技术
微信小程序教程
Uniapp开发教程
微信公众号开发
Andriod教程
IOS教程
DOS教程
Python教程
Docker教程
Windows Container教程
数据库
MSSQL教程
MySQL教程
Redis教程
Access教程
Oracle教程
数据库教程
操作系统
Linux教程
Windows教程
MAC教程
Cisco教程
交换机教程
防火墙教程
搜索
爱易网页
JS特效
js制作的简单方块碰撞测试特效代码
js制作的简单方块碰撞测试特效代码
日期:2014-05-18 浏览次数:20169 次
以下是程序代码
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>javascript开发中的基本动画: 简单的碰撞测试</title> <style type="text/css"> *{margin : 0; padding : 0;} body{font:12px "微软雅黑", Tahoma, "宋体" } .inputcon{margin:50px auto 50px;; width:600px;} .inputcon p{ padding-bottom : 10px;} .inputcon .inp{ border : 1px solid #ccc; width : 100px; height: 18px; line-height : 18px;} .container{ position:relative; overflow:hidden; border:1px solid #000; margin:0 auto;} .container .sprite { overflow:hidden; background:#f00; color:#fff; line-height:40px; position:absolute; } </style> <script type="text/javascript"> //第一次遇到这么面试的公司, 从来没写过这些东东, 当时2小时没全做好被pass掉了,现在补上来,整整花了5小时 /* ** 运动对象封装 */ function Run(dir){this.dir = dir;}; Run.prototype = {}; /* ** 自动移动 ** 返回值: undefined ** 参数: w : 舞台宽度(Number) h : 舞台高度(Number) sw : 移动对象宽度(Number) sh : 移动对象高度(Number) gx : 单位时间沿x轴移动的长度(Number) gy : 单位时间沿y轴移动的长度(Number) sprite : 运动对象(dom Object) t : 移动间隔(单位毫秒 Number) */ Run.prototype.play = function(w, h, sw, sh, gx, gy, sprite, t){ var _this = this; (function(dir){ _this.dir = dir; var _self = arguments.callee; _this.__beginauto(t, function(){ var _left = parseInt(sprite.style.left); var _top = parseInt(sprite.style.top); sprite.innerHTML = "<p>"+ dir + "</p>" + "<p>" + _left + "," + _top + "</p>"; if(dir === "top"){//竖直向上运动 sprite.style.top = _top - gy + "px"; if(parseInt(sprite.style.top) <= 0){ sprite.style.top = 0 + "px"; _self("bottom"); }; }else if(dir === "bottom"){//竖直向下运动 sprite.style.top = _top + gy + "px"; if(parseInt(sprite.style.top) + sh >= h){ sprite.style.top = h - sh + "px"; _self("top"); }; }else if(dir === "right"){//水平向右运动 sprite.style.left = _left + gx + "px"; if(parseInt(sprite.style.left) + sw >= w){ sprite.style.left = w - sw; _self("left"); }; }else if(dir === "left"){//水平相左运动 //_this.__stopauto(); //alert(_left - gy) sprite.style.left = _left - gx + "px"; if(parseInt(sprite.style.left) <= 0){ sprite.style.left = 0; _self("right"); }; }else if(dir === "leftTop"){//向左上角方向运动 sprite.style.left = _left - gx +"px"; sprite.style.top = _top - gy + "px"; if(parseInt(sprite.style.left) <= 0 || parseInt(sprite.style.top) <= 0){ if(parseInt(sprite.style.left) + sw <= 0){ sprite.style.left = 0; }; if(parseInt(sprite.style.top) + sh <= 0){ sprite.style.top = 0; }; _self("rightBottom"); }; }else if(dir === "rightTop"){//向右上角方向运动 sprite.style.left = _left + gx + "px"; sprite.style.top = _top - gy + "px"; if(parseInt(sprite.style.left) + sw >= w || parseInt(sprite.style.top) <= 0){ if(parseInt(sprite.style.left) + sw >= w){ sprite.style.left = w - sw; }; if(parseInt(sprite.style.top) <= 0){ sprite.style.top = 0; }; _self("leftBottom&q
上一篇:狡猾的按钮特效
下一篇:如何获取某个元素定义的全部样式
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
二代 iPad Air将配备2GB内存?为同屏多任务做准备
用户喊话当当网:我彻底把你们丢弃了
陈天桥之鉴:产品创新被扼杀那些事
为啥苹果定要出廉价iPhone?都是安卓逼的
特斯拉将获上海免费牌照 充电桩面临双重标准
国美痛批网购七宗罪 用短暂盈利输了未来
全球网络遭史上最大规模攻击:攻击数据每秒300G
神州泰岳雪上加霜:副总违规买卖遭罚
乐视今日临时停牌 受广电酝酿新规消息影响
推荐阅读
更多>
英特尔承认,联想最新K系列智能手机放弃英特尔处理器
京东封杀财付通:终极目标是电商生态圈
孙正义入股阿里往事还原:阿里巴巴并非软银首选
互联网金融一周年:余额宝最接地气,比特币最作死
特斯拉技术专利开放,要革自己的命?
看蜗牛如何放水养鱼,盘活生态系统
途牛开盘价9美元 与发行价持平
组建铁塔公司倒逼运营商改革 或加速4G网建设
喜大普奔:2016年国内乘客有望在飞机上使用手机
支付宝全面封杀比特币:充值码淘宝店或遭封禁
微软张亚勤趋势判断:未来三十年属于物理化互联网
刘强东:京东上市融资用于开拓三至六线城市
618首日看京东阿里不同策略,鹿死谁手?
柳传志马云陷舆论漩涡:请不要辜负这个时代
广东移动高层受调查 中移动或现更大反腐风暴
固话上网卡或将实名制 运营商泄露用户信息将被罚
传三星为赢得新兴市场:推廉价版Note3
Facebook以“人”为本的名义占领安卓
2013年至今中国互联网行业十大并购案汇总
原万网CTO周雷加盟亿玛 出任CTO一职