爱易网
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教程
交换机教程
防火墙教程
搜索
爱易网页
JavaSript
JavaScript, 兑现俄罗斯方块
JavaScript, 兑现俄罗斯方块
日期:2014-05-16 浏览次数:20536 次
JavaScript, 实现俄罗斯方块
<!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>俄罗斯方块</title> <style type="text/css"> body{ width:530px; background:#F7F7F7; margin:20px auto} table#gameBoard{ border:1px solid black; border-collapse: collapse; float:left;} table#gameBoard td{ width:30px; height:30px; border: 1px dotted #0cc;} div#gameControl{ widows:160; float:right; height: 200px;; line-height: 200px;} .font{ font-family:'微软雅黑'; font-size:18px; text-align:center;} div input { width: 60px; height:25px; } </style> <script type="text/javascript"> var T = TETRIS = { aBoardGrids : [], aShapes: [ [0xCC00], [0x8888, 0xF00], [0x8C40, 0x6C00], [0x4C80, 0xC600], [0x44C0, 0x8E00, 0xC880, 0xE200], [0x88C0, 0xE800, 0xC440, 0x2E00], [0x4E00, 0x8C80, 0xE400, 0x4C40] ], //代表所有方块的形状数 init : function(){ this.oDomBoard = document.getElementById("gameBoard"); this.oDomScore = document.getElementById("score"); this.aBoardGrids = new Array(18); for (var rows = 0 ; rows < 18 ; rows++){ this.aBoardGrids[rows] = new Array(10); var oDomTr = this.oDomBoard.insertRow(-1); for (var cols = 0 ; cols < 10 ; cols++){ this.aBoardGrids[rows][cols] = 0; oDomTr.insertCell(cols); } } document.onkeydown = function(keyEvent){ keyEvent = keyEvent || window.event; var ikeyNum = keyEvent.which || keyEvent.keyCode; switch(ikeyNum){ case 37://← T.oBlock.move("left"); break; case 38://↑ T.oBlock.rotate((function (){ var vShape = T.aShapes[T.iShapeIdx][ (++T.index)%T.aShapes[T.iShapeIdx].length]; var sShape = vShape.toString(2); sShape = new Array(17 - sShape.length).join(0) + sShape; T.matrix = sShape.match(/\d{4}/g); return T.matrix; })()); //变形 break; case 39://→ T.oBlock.move("right"); break; case 40://↓ T.oBlock.move("down"); break; } } }, next : function (){ this.iShapeIdx = parseInt(Math.random() * this.aShapes.length); this.index = 0; var vShape = this.aShapes[this.iShapeIdx][this.index]; var sShape = vShape.toString(2); //将16进制转换为二进制 sShape = new Array(17 - sShape.length).join(0) + sShape; //不够16位,在前面用0补全 this.matrix = sShape.match(/\d{4}/g); //利用正则表达式匹配 this.oBlock = new TETRIS.Block(this.matrix); clearInterval(T.timer); //注册定时器 T.timer = setInterval(function (){ T.oBlock.move("down"); }, 1000); if( !T.oBlock.checkBlock() ){ alert("Game Over~"); clearInterval(T.timer); } }, updateBoard : function (){ //更新面板 for(var i = 0 ; i < 4 ; i++){ this.aBoardGrids[T.oBlock.shape[i].y][T.oBlock.shape[i].x] = 1; } }, eraseLines : function (){ var iLines = 0; for(var j = 17 ; j >= 0 ; j--){ var num = 0; for(var i = 0 ; i< 10 ; i++){ if(this.aBoardGrids[j][i] == 1) num ++; } if(num == 10){ iLines ++; for(var m = 0 ; m < i ; m++){ for(var n = j ; n > 0 ; n--){ this.aBoardGrids[n][m] = this.aBoardGrids[n-1][m]; T.oDomBoard.rows[n].cells[m].style.background = T.oDomBoard.rows[n-1].cells[m].style.background; } this.aBoardGrids[0][m] = 0; } j++; } } return iLines; }, setScore : function (iLines){ var iScore = parseInt(this.oDomScore.innerHTML); if(iLines == 1){ iScore += 100; } else if(iLines == 2){ iScore += 300; } else if(iLines == 3){ iScore
上一篇: ssh如何知道删除实体成不成功
下一篇: 关于setTimeout()跟setInterval()的执行顺序
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
配备Myeclipse6.5+Tomcat6.0+Jdk1.6开发jsp
JavaScript怎么判断两个字符串型日期的大小
jsp页面导出成word资料
js 标签切换效能
textarea里面怎么检测到回车事件
jsp生成静态页面—一
DOM相关的javascript有关问题
寻找卓越网鼠标经过链接的时候出现一个DIV,触发这个事件的代码,该如何解决
js有木有类似功能的全局变量?该怎么解决
推荐阅读
更多>
未结束的字符串常量 。找了半天 没找到异常在哪
记时,即使刷新也没事
Html 5 中canvas.toDataURL方法报SecurityError异常 ,如何解决 ?
easyui的combobox示范代码,从VS调试,结果不正确,为什么
用js步骤在文本框输入字符串然后下边的多行文本值根据输入的改变
修改一下JS日历控件的格式!该如何处理
几种定义Javascript对象的模式
ExtJS-10.2 Ext工具类 Ext.util.ClickRepeater
写了个最简单的正则表达式 遇到有关问题 请帮忙
超酷的实时色彩数据跟踪javascript类库 - Tracking.js
Json-lib 与 hibernate _lazy共同使用的有关问题
Js FCKeditor的值获取跟修改的代码小结
vml中怎么用javascript去掉polyline的箭头
JavaScript offset等框子、高度理解
急问当某个事件发生实,怎么把该页面置顶以提示用户
jsp,擢升系统的性能 转载
js放大镜放大图片成效 详细出处参考:http://www.jb51.net/article/14335.htm
jstl跟EL 组合显示 select和radio标签
jquery 删除节点的有关问题
js创建对象的几种惯用方式