爱易网
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 浏览次数:20477 次
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()的执行顺序
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
js 种的实现 转载
js怎么获取form表单源码及表单元素状态
js判断页面是不是在iframe或者frame里的一种偏锋写法
小白碰到两个js冲突,忘大神解救
jsp 懂得301和302的区别
怎么让框架页面有top,left暂时隐藏
js中字符串处置的常用方法replaceAll, split , join, indexOf , Array
js解析json跟xml
捕获键盘事件有关问题
推荐阅读
更多>
JS-事件
Java乔晓松-JavaScript增强2
正题:深刻理解JavaScript基于原型的面向对象
js怎么获取 input radio的值
[译文]50个jQuery代码段相助你成为一个更好的JavaScript开发者
请问以下异常如何解决
《Javascript高级程序设计》(第2版)学习札记05-正则表达式
JS表单印证集锦(之一)
JavaScript闭包和类的继承封装是同一回事吗,他们是什么关系解决办法
Extjs4 上拉框combo的重复取值和联动有关问题
js关于浏览器document对象属性支持有关问题
JavaScript怎么定义类的属性成员
js中settimeout的停止
jsp界面施用cookie实现换肤
Js节点属性与步骤
js向靠山发送请求的方法有哪些
JavaScript Canvas 画夹(线条)
javascript中两个惊叹号的作用
哪位高手能帮小弟我解释一下以下几个内容!比内急还急
本人JS初学者,向高手请问怎么修改表单内容