爱易网
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 浏览次数:20606 次
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 prototype 学习体会2
js或vbs有代码可直接修改系统日期吗?解决方案
怎么用Javascript打开另一个页面并执行另一个Javascript函数
jstl fmt效能
小弟我与node.js
请推荐javaScript经典书,该如何解决
ArcGIS API for JavaScript v3.1鹰眼式样修改
IE跟firefox通用的复制到剪贴板的JS函数
jsp utf 乱码异常 com.caucho.jsp.JspParseException: illegal utf8 encoding at 0xdf
推荐阅读
更多>
js判断浏览器部类
jsonObject 转化 bean list 地图 array
施用IE6时window.open弹出的页面是空白页面
关于建立网站和网站维护的一些基本有关问题!求教
js正则印证
JavaScript的Socket通信包 jSocket
jsp的相对定位跟绝对定位
,text光标定位有关问题
JSP上拉多选
EXTjs TabPanel listeners事件怎么让它加载完html后执行?实在是查不到
小结整理JS各常用功能
JS,帮小弟我解答下多谢
js正则往空格,全空格,左右空格
JS与php数组,该怎么解决
js隐藏table列或者行
javascript 计算疑惑?该怎么解决
给指定元素的后头追加内容 原生js
jsp中文参数乱码的有关问题
ie8上如何支持js里面的confirm()和alert()
表单动态添加控件,如果判断与取值?该如何解决