爱易网
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 浏览次数:20116 次
以下是程序代码
<!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
上一篇:狡猾的按钮特效
下一篇:如何获取某个元素定义的全部样式
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
估值增长9.8% 阿里IPO前市值达2450亿美元
欧盟控诉苹果在爱尔兰非法进行税收交易
杨元庆去年总薪酬1.33亿元
北京今日实现用支付宝钱包为公交卡充值
完美入股盛大:一桩各怀心事的交易
逆转猜想:如果阿里成为雅虎大股东会怎样?
“论文查重”网店一月收入竟过百万
三大运营商合建铁塔公司真相:未涉及电信业重组
传苹果与雅虎协作信息提供 进一步摆脱谷歌
推荐阅读
更多>
这一次,微软将带给我们什么惊喜?
阿朗力避步北电后尘 急切停止自我革新
IT企业人才争夺战打响:员工待遇水涨船高
纸媒深探版权蓝海抗衡互联网的时机到来了
支付宝全面封杀比特币:充值码淘宝店或遭封禁
苹果优势逐渐丧失 传即将推出廉价iPhone
Facebook思科联手推免费WiFi 欲覆盖全美
200美元英特尔Android笔记本行将到来
360涉足搜索范围 百度市场份额面临应战
华为任正非:家族成员不会成为接班人
网络文学竞争白热化 百度多酷文学网上线
2018双11阿里云老用户怎么参加拼团活动 老用户拼团方法
巧用百度推行系统 突显竞价效果
三星维修新规:Galaxy S4主板进水也收费修
代工厂生活危机:“富士康们”何去何从?
宽带中国战略明确 运营商建设成本超6000亿
苹果收购Beats交易或将延期尚需解决5大问题
为啥苹果定要出廉价iPhone?都是安卓逼的
新一代iPhone11月底国内上市 支持TD制式
小米打响手机价格战 为米3铺路或另有所图