爱易网
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 浏览次数:20500 次
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()的执行顺序
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
请问上字符串分隔
ExtJs4.0整合Swfupload下传组件
关于内存泄漏,请各位看看解决方案
求一段验证用户密码强度的js解决方法
jQuery中的toggle()有关问题
新手提问一个关于javascript DOM解析的有关问题
Ext.tree的铺展"+"图标有click事件吗?什么搞
js抢救,等。怎样让弹出层锁定居中。不随滚动条滚动而改变位置
EXt JS官方的图书推荐(二)-LearningExtJS
推荐阅读
更多>
js 字符串日期 yyyy-MM-dd 转化作 date
my eclipse那个版本比较好解决办法
javascript 菜鸟有关问题.
[javascript]九宫格拖拽拼图游戏 puzzle
ExtJs的列方式column(xtype)详解
初识Node.js-《牛逼的Node.js 将JavaScript进行到底》样章试读有感
施用SBJson
【转】相关onsubmit return false 阻止form表单提交:js
组合正则表达式验证数学公式(含变量,js版)
大神在吗?小弟我想把获取到的一个变量赋给所有的隐藏域name="aid01"咋实现
JS判断一个数组中是不是有重复值的三种方法
深入了解JavaScript的变量作用域
JS-免费刷流量软件工具源码
data-options的有关问题
帮忙看上网站用到的js有什么有关问题 多谢
javascript有没有象vs.net那样快速开发功能强大的开发环境或工具,该怎么处理
js怎的实现这样的图片功能
构造函数不初始化直接调用时赋值不行吗?解决方案
ExtJs ajax调用集锦
js取现阶段url参数