真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

使用JS代碼實現(xiàn)俄羅斯方塊游戲

簡單的JS俄羅斯方塊游戲源碼,先給大家展示下效果圖,如果大家感覺不錯,請參考實現(xiàn)代碼,

10多年的新羅網(wǎng)站建設經(jīng)驗,針對設計、前端、開發(fā)、售后、文案、推廣等六對一服務,響應快,48小時及時工作處理。網(wǎng)絡營銷推廣的優(yōu)勢是能夠根據(jù)用戶設備顯示端的尺寸不同,自動調(diào)整新羅建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設計,從而大程度地提升瀏覽體驗。成都創(chuàng)新互聯(lián)公司從事“新羅網(wǎng)站設計”,“新羅網(wǎng)站推廣”以來,每個客戶項目都認真落實執(zhí)行。

  效果圖:

使用JS代碼實現(xiàn)俄羅斯方塊游戲

 代碼如下,復制即可使用:





使用JS實現(xiàn)俄羅斯方塊游戲







難度:

↑:變換
←:左移
→:右移
↓:加速

下一個圖形:
分數(shù):0

適用瀏覽器:360、FireFox、Chrome、Safari、Opera、傲游、搜狗、世界之窗. 不支持IE8及以下瀏覽器。

 GameFrame.js

function GameFrame(unit,row,col)
{
  //單位的像素
  this.unit = unit;
  //橫向單位個數(shù)(列),,(一行的個數(shù))
  this.row = row;
  //縱向單位個數(shù)(行),,(一列的個數(shù))
  this.col =col;
  //保存頁面創(chuàng)建div容器的屬性
  this.Content;
  //小圖形
  this.samlldiv;
  //定時器id
  this.intervalid;
  //速度
  this.speed =document.getElementById("level").value;
  //速度是否改變
  this.ChangeSped=0;
  //記錄每個位置是否有div
  this.datas=[];
  //記錄消除行數(shù)相應的分數(shù)
  this.score=[0,100,300,600,1000]
  //記錄當前的圖形的下標
  this.now;
  //記錄下一個圖形的下標
  this.next;
  //記錄當前的圖形的顏色
  this.nowcolor;
  //記錄下一個圖形的顏色
  this.nextcolor;
  //保存7種圖形相對坐標的數(shù)組
  this.arr = "0,1,0,2,1,2,2,2;0,1,1,1,1,2,2,2;0,1,0,2,1,1,2,1;0,2,1,1,1,2,2,1;1,0,1,1,1,2,1,3;1,1,1,2,2,1,2,2;1,1,2,0,2,1,2,2".split(";");
  //保存小方塊的顏色
  this.color=["red","blue","green","yellow","#00FFFF","#930093","#F80000","#984B4B"];
  //初始化容器div
  this.init = function()
  {
    //創(chuàng)建div
    var div = document.createElement("div");
    //設置div的寬度
    div.style.width = (this.unit*this.row)+"px";
    //設置div的高度
    div.style.height=(this.unit*this.col)+"px";
    //設置div的樣式
    div.className="MainFrame";
    div.id="MainFrame";
    //加入到body中
    document.getElementById("TFrime").appendChild(div);
    this.Content =div; //保存div的引用
    //初始化數(shù)組
    for(var i=0;i

 graph.js

function Graph(frame) {
  //保存7種圖形相對坐標的數(shù)組
//  var arr = "0,1,0,2,1,2,2,2;0,1,1,1,1,2,2,2;0,1,0,2,1,1,2,1;0,2,1,1,1,2,2,1;1,0,1,1,1,2,1,3;1,1,1,2,2,1,2,2;1,1,2,0,2,1,2,2".split(";");
  //保存4個小圖形的數(shù)組
  this.divs = [];
  //外部容器div的數(shù)組
  this.parentFrame = frame;
  //圖形橫縱偏移
  this.x = 0;
  this.y = 0;
  //記錄圖形的坐標數(shù)組
  this.zb = [];
  //記錄消除的行數(shù)
  this.line=0;
  //初始化小圖形的方法
  this.init = function(rand,color) {
      //計算圖形其實坐標的單位
      var startleft = (this.parentFrame.row - 4) / 2;
      this.x = startleft;
      //隨機生成圖形數(shù)組下標
//      var rand = Math.floor(Math.random() * arr.length);
      //分解圖形的坐標
      var smallarr = this.parentFrame.arr[rand].split(",");
      this.zb = smallarr;
      //循環(huán)設置小div的 left和top
      for (var i = 0; i < 8; i += 2) {
        //創(chuàng)建小div
        var smalldiv = document.createElement("div");
        //設置樣式
        smalldiv.className = "smallDiv";
        //設置顏色
        smalldiv.style.backgroundColor=color;
        //定義高寬
        smalldiv.style.width = (this.parentFrame.unit - 2) + "px";
        smalldiv.style.height = (this.parentFrame.unit - 2) + "px";
        //設置小div的top
        smalldiv.style.top = ((smallarr[i] - 0) * this.parentFrame.unit) + "px";
        //設置小div的left
        smalldiv.style.left = (((smallarr[i + 1] - 0) + startleft) * this.parentFrame.unit) + "px";
        //保存小div的引用
        this.divs.push(smalldiv);        
        //加入到外部容器
        document.getElementById("MainFrame").appendChild(smalldiv);
      }
      //執(zhí)行自動向下移動
      //this.parentFrame.intervalid = setInterval(autoMoveDown, this.parentFrame.speed);
    }
    //左移動
  this.moveleft = function() {
      //    var canmove = true;
      //    //判斷能否左移動
      //    
      //    for(var i=0;i=parseInt(this.parentFrame.Content.style.width))
    //      {
    //        canmove = false;
    //        break;
    //      }
    //    }
    var temp = canMove(this.zb, this.x, this.y, this.parentFrame, 1);
//    alert(temp);
    console.log(temp);
    if (canMove(this.zb, this.x, this.y, this.parentFrame, 1)) {
      this.x += 1;
      for (var i = 0; i < this.divs.length; i++) {
        var left = parseInt(this.divs[i].style.left);
        this.divs[i].style.left = (left + this.parentFrame.unit) + "px";
      }
    }
  }
  //變形
  this.change = function() {
    //變形的公式
    //小div的2個相對坐標點改變  x = y ; y= 3-x; 比如 (0,1) 變化之后 就是  x=1,y=3-0 -> (1,3)
    //循環(huán)4個小div
    if (!canMove(this.zb, this.x, this.y, this.parentFrame, 4)) {
      if (this.x < 0) {
        this.x += 1;
      } else {
        this.x -= 1;
      }
    }
    for (var i = 0; i < this.divs.length; i++) {
      //根據(jù)公式改變每個div的相對偏移量,2個一改
      var temp = this.zb[i * 2]
      this.zb[i * 2] = this.zb[i * 2 + 1];
      this.zb[i * 2 + 1] = 3 - temp;
      //根據(jù)改變后的偏移量計算圖形的當前l(fā)eft和top
      this.divs[i].style.top = ((this.y + parseInt(this.zb[i * 2])) * this.parentFrame.unit) + "px";
      this.divs[i].style.left = ((this.x + parseInt(this.zb[i * 2 + 1])) * this.parentFrame.unit) + "px";
    }
  }
  this.movedown = function() {
    var $this = this =="window" ? this.frame.samlldiv : this;
    if (canMove($this.zb, $this.x, $this.y, $this.parentFrame, 3)) {
      $this.y += 1;
      for (var i = 0; i < $this.divs.length; i++) {
        var top = parseInt($this.divs[i].style.top);
        $this.divs[i].style.top = (top + $this.parentFrame.unit) + "px";
      }
      return false;
    } else {
      clearInterval($this.parentFrame.intervalid);
//      var temp = $this.parentFrame.Content.getElementsByTagName("div");
      for (var i=0;i<$this.divs.length;i++) {
        //div變灰
        //$this.divs[i].className ="smallDivblack";
        var $y = $this.y + parseInt($this.zb[i*2]);
        var $x = $this.x+parseInt($this.zb[i*2+1]);
//        debugger;
        $this.parentFrame.datas[$y*$this.parentFrame.row+ $x] =1;
        $this.divs[i].dataset.row=$y;  //記錄div所在的行
        $this.divs[i].dataset.col=$x;  //記錄div所在的列
        $this.divs[i].className="smallDivblack";
        $this.divs[i].style.backgroundColor="black";
        //$this.parentFrame.datas[]
      }
        //消行并計分
        for (var i= 0;i<$this.parentFrame.col;i++) {    //i為行
          //判斷是否滿足消行條件
          for (var j=0;j<$this.parentFrame.row;j++) {    //j為列
            if($this.parentFrame.datas[i*$this.parentFrame.row+ j] !=1){
              break;
            }
          }
          //消行,將該行上面的所有div下移一行
          if(j==$this.parentFrame.row){
            var x;    //記錄div在哪一列
            var y;    //記錄div在哪一行
            var getsmalldiv=document.getElementById("TFrime").getElementsByClassName("smallDivblack");//得到小div
            for (var a=0;a0;a--) {
              for (var b=0;b= f.row)
          {
            return false;
          }else if(f.datas[(parseInt(zb[i + 1]) + x + 1)+(y+parseInt(zb[i]))*f.row] !=0)
          {
            return false;
          }
        }
        break;
      case 2:
        for (var i = 0; i < zb.length; i += 2) {
          if (parseInt(zb[i + 1]) + x - 1 < 0 ) {
            return false;
          }else if(f.datas[(parseInt(zb[i + 1]) + x - 1)+(y+parseInt(zb[i]))*f.row] !=0)
          {
            return false;
          }
        }
        break;
      case 3:
        for (var i = 0; i < zb.length; i += 2) {
          if (parseInt(zb[i]) + y + 1 >= f.col ||
          f.datas[(parseInt(zb[i + 1]) + x)+(parseInt(zb[i]) + y+1)*f.row] !=0) {
            return false;
          }
        }
        break;
      case 4:
        for (var i = 0; i < zb.length; i += 2) {
          var temp = 3 - zb[i];
          if (temp + x < 0 || temp + x >= f.row) {
            return false;
          }
        }
        break;
    }
    return true;
  }
  this.rescore=function(){
    var gamescore=document.getElementById("score");
    gamescore.innerHTML=parseInt(gamescore.innerHTML)+this.parentFrame.score[this.line];
  }
}

 index.js

var frame;
function initGame()
{
  frame = new GameFrame(16,20,38);
  frame.init();
  document.body.addEventListener("keydown",MoveOrChange)
}
function changespeed(){
  frame.changespeed();
}
function regame(){
  location.reload();
}
function MoveOrChange()
{
  switch(event.keyCode)
  {
    case 38: //變形(上方向鍵)
      frame.Change();
      break;
    case 37: //左移動
      frame.MoveLeft();
      break;
    case 39://右移動
      frame.MoveRight();
      break;
    case 40: //向下
      frame.MoveDown();
      break;
  }
}

總結(jié)

以上所述是小編給大家介紹的使用JS代碼實現(xiàn)俄羅斯方塊游戲,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網(wǎng)站的支持!


名稱欄目:使用JS代碼實現(xiàn)俄羅斯方塊游戲
標題網(wǎng)址:http://weahome.cn/article/iejghg.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部