zoukankan      html  css  js  c++  java
  • 纯JS实现俄罗斯方块,打造属于你的游戏帝国

      纯JS俄罗斯方块,打造属于你的游戏帝国。

      本文原始作者博客 http://www.cnblogs.com/toutou

      俄罗斯方块(Tetris, 俄文:Тетрис)是一款电视游戏机和掌上游戏机游戏,它由俄罗斯人阿列克谢·帕基特诺夫发明,故得此名。
    俄罗斯方块的基本规则是移动、旋转和摆放游戏自动输出的各种方块,使之排列成完整的一行或多行并且消除得分。由于上手简单、老少皆宜,从而家喻户晓,风靡世界。
    那么,我们的问题来了,学挖掘机技术哪家强?强

    本文原创来自博客园 请叫我头头哥的博客, 请尊重版权,跳转至原博文预览。

     

      俄罗斯方块可以说是风靡全世界,老少皆知的一款游戏, 那么我们作为web开发是否可以使用代码简单实现这个小游戏呢?

      html代码部分:

      

     1 <!doctype html>
     2 <html>
     3 <head>
     4 </head>
     5 <body>
     6     <h2 style="background-color:yellow;">博客园:请叫我头头哥</h2>
     7     <div id="box"></div>
     8     <div id="info">
     9         NEXT:
    10         <div id="next"></div>
    11         <div id="text"></div>
    12     </div>
    13 </body>
    14 </html>

      css部分:

      

    body {
            background: blue;
            font: 25px / 25px ËÎÌå;
        }
    
        #box {
            float: left;
            width: 252px;
            border: #999 20px ridge;
            color: #9f9;
            text-shadow: 2px 3px 1px #0f0;
        }
    
        #info {
            float: left;
            color: #cfc;
            padding: 24px;
        }
    
        #next {
            padding: 8px;
            width: 105px;
            color: #9f9;
            text-shadow: 2px 3px 1px #0f0;
        }

      js部分:

      

     1 var map = eval("[" + Array(23).join("0x801,") + "0xfff]");
     2     var tatris = [[0x6600], [0x2222, 0xf00], [0xc600, 0x2640], [0x6c00, 0x4620], [0x4460, 0x2e0, 0x6220, 0x740], [0x2260, 0xe20, 0x6440, 0x4700], [0x2620, 0x720, 0x2320, 0x2700]];
     3     var char = { x: "u3000", s: "u25a0", t: "u25a1" };
     4     var keycom = { "38": "rotate(1)", "40": "down()", "37": "move(2,1)", "39": "move(0.5,-1)", "32": "0;pause=!pause" };
     5     var dia, pos, bak, run, next, pause = false, info = { speed: 1, lines: 0, score: 0 };
     6 
     7     // 开始时间
     8     function start() {
     9         dia = next.d;
    10         bak = pos = {
    11             fk: [],
    12             y: 0,
    13             x: 4,
    14             s: next.s
    15         };
    16         nextdia();
    17         document.getElementById("next").innerHTML = (next.d[next.s % next.d.length] | 0x10000).toString(2).slice(-16).replace(/..../g, "$&<br/>").replace(/1/g, char.t).replace(/0/g, char.x);
    18         document.getElementById("text").innerHTML = "SCORE:" + info.score + "<br/><br/>LINES:" + info.lines + "<br/><br/>SPEED:" + info.speed;
    19         rotate(0);
    20         run = setInterval("pause||down()", ~ ~(Math.pow(1.3, 12 - info.speed) * 30 + 20));
    21     }
    22 
    23     // 游戏结束时事件
    24     function over() {
    25         document.onkeydown = null;
    26 
    27         // confirm, 是否再来一局
    28         var end = confirm("游戏结束, 是再来一局");
    29         if (end) {
    30             window.location.href = window.location.href;
    31         } else {
    32             alert("骚年,自制力不错!");
    33         }
    34     }
    35 
    36     function nextdia() {
    37         next = { d: tatris[~ ~(Math.random() * 7)], s: ~ ~(Math.random() * 4) };
    38     }
    39 
    40     function update(t) {
    41         bak = { fk: pos.fk.slice(0), y: pos.y, x: pos.x, s: pos.s };
    42         if (t) return;
    43         for (var i = 0, a2 = ""; i < 22; i++) a2 += map[i].toString(2).slice(1, -1) + "<br/>";
    44         for (var i = 0, n; i < 4; i++)
    45             if (/([^0]+)/.test(bak.fk[i].toString(2).replace(/1/g, char.t)))
    46                 a2 = a2.substr(0, n = (bak.y + i + 1) * 15 - RegExp.$_.length - 4) + RegExp.$1 + a2.slice(n + RegExp.$1.length);
    47         document.getElementById("box").innerHTML = a2.replace(/1/g, char.s).replace(/0/g, char.x);
    48     }
    49 
    50     function is() {
    51         for (var i = 0; i < 4; i++)
    52             if ((pos.fk[i] & map[pos.y + i]) != 0)
    53                 return pos = bak;
    54     }
    55 
    56     function rotate(r) {
    57         var f = dia[pos.s = (pos.s + r) % dia.length];
    58         for (var i = 0; i < 4; i++)
    59             pos.fk[i] = (f >> (12 - i * 4) & 15) << pos.x;
    60         update(is());
    61     }
    62 
    63     function down() {
    64         ++pos.y;
    65         if (is()) {
    66             for (var i = 0, r = 0; i < 4 && pos.y + i < 22; i++)
    67                 if ((map[pos.y + i] |= pos.fk[i]) == 0xfff) {
    68                     map.splice(pos.y + i, 1), map.unshift(0x801);
    69                     ++info.lines % 20 == 0 && info.speed++, r++;
    70                 }
    71             clearInterval(run);
    72             if (map[1] != 0x801)
    73                 return over();
    74             info.score += ~ ~(Math.pow(r, 1.5) * 10) + 2;
    75             start();
    76         }
    77         update();
    78     }
    79 
    80     function move(t, k) {
    81         pos.x += k;
    82         for (var i = 0; i < 4; i++)
    83             pos.fk[i] *= t;
    84         update(is());
    85     }
    86 
    87     document.onkeydown = function (e) {
    88         eval("pause||" + keycom[(e ? e : event).keyCode]);
    89     };
    90     nextdia();
    91     start();

      实现效果图:

       另外提供源码下载。

      特此声明:所有评论和私信都会在第一时间回复。也欢迎园子的大大们指正错误,共同进步。

      本文原始作者博客 http://www.cnblogs.com/toutou

      if您看了这篇博客。对您有所帮助,请不要吝啬您的“推荐”,您的推荐将是我最大的动力。有问题的话可以评论交流。

  • 相关阅读:
    漫谈五种IO模型
    jvm调优-命令大全(jps jstat jmap jhat jstack jinfo)
    Intellij IDEA 插件开发秘籍
    二进制
    java程序员必知的 8大排序
    Redis常见问题
    BitMap位图
    编程思想
    Final修饰的字段是否可以通过反射设置值
    ORACLE 11g ORA-20000: Unable to analyze TABLE "AA"."CMP3$87651", insufficient privileges or does not exist
  • 原文地址:https://www.cnblogs.com/toutou/p/4460509.html
Copyright © 2011-2022 走看看