成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

展示js簡單拼圖游戲

3403771864 / 423人閱讀

  我們看看js實現(xiàn)簡單拼圖游戲的詳細代碼,HTML僅有一個id為game的div,也不錯編寫CSS,僅要img文件夾中放置一個圖片文件就行,此處我放置的是LOL皇子的圖片,圖片名為'lol.png'

  <div id="game">
  </div>

  下面展示具體效果

  多的不說,直接上js代碼

  /**
  * 游戲配置
  */
  var gameConfig = {
  width: 500,
  height: 500,
  rows: 3, //行數(shù)
  cols: 3, //列數(shù)
  isOver: false, //游戲是否結(jié)束
  imgurl: "img/lol.png", //圖片路徑,注意:相對的是頁面路徑
  dom: document.getElementById("game") //游戲的dom對象
  };
  //每一個小塊的寬高
  gameConfig.pieceWidth = gameConfig.width / gameConfig.cols;
  gameConfig.pieceHeight = gameConfig.height / gameConfig.rows;
  //小塊的數(shù)量
  gameConfig.pieceNumber = gameConfig.rows * gameConfig.cols;
  var blocks = []; //包含小方塊信息的數(shù)組
  function isEqual(n1, n2) {
  return parseInt(n1) === parseInt(n2);
  }
  /**
  * 小方塊的構(gòu)造函數(shù)
  * @param {*} left
  * @param {*} top
  * @param {*} isVisible 是否可見
  */
  function Block(left, top, isVisible) {
  this.left = left; //當(dāng)前的橫坐標
  this.top = top; //當(dāng)前的縱坐標
  this.correctLeft = this.left; //正確的橫坐標
  this.correctTop = this.top; //正確的縱坐標
  this.isVisible = isVisible; //是否可見
  this.dom = document.createElement("div");
  this.dom.style.width = gameConfig.pieceWidth + "px";
  this.dom.style.height = gameConfig.pieceHeight + "px";
  this.dom.style.background = `url("${gameConfig.imgurl}") -${this.correctLeft}px -${this.correctTop}px`;
  this.dom.style.position = "absolute";
  this.dom.style.border = "1px solid #fff";
  this.dom.style.boxSizing = "border-box";
  this.dom.style.cursor = "pointer";
  // this.dom.style.transition = ".5s"; //css屬性變化的時候,在0.5秒中內(nèi)完成
  if (!isVisible) {
  this.dom.style.display = "none";
  }
  gameConfig.dom.appendChild(this.dom);
  this.show = function () {
  //根據(jù)當(dāng)前的left、top,重新設(shè)置div的位置
  this.dom.style.left = this.left + "px";
  this.dom.style.top = this.top + "px";
  }
  //判斷當(dāng)前方塊是否在正確的位置上
  this.isCorrect = function () {
  return isEqual(this.left, this.correctLeft) && isEqual(this.top, this.correctTop);
  }
  this.show();
  }
  /**
  * 初始化游戲
  */
  function init() {
  //1. 初始化游戲的容器
  initGameDom();
  //2. 初始化小方塊
  //2.1 準備好一個數(shù)組,數(shù)組的每一項是一個對象,記錄了每一個小方塊的信息
  initBlocksArray();
  //2.2 數(shù)組洗牌
  shuffle();
  //3. 注冊點擊事件
  regEvent();
  /**
  * 處理點擊事件
  */
  function regEvent() {
  //找到看不見的方塊
  var inVisibleBlock = blocks.find(function (b) {
  return !b.isVisible;
  });
  blocks.forEach(function (b) {
  b.dom.onclick = function () {
  if (gameConfig.isOver) {
  return;
  }
  //判斷是可以交換
  if (b.top === inVisibleBlock.top &&
  isEqual(Math.abs(b.left - inVisibleBlock.left), gameConfig.pieceWidth)
  ||
  b.left === inVisibleBlock.left &&
  isEqual(Math.abs(b.top - inVisibleBlock.top), gameConfig.pieceHeight)) {
  //交換當(dāng)前方塊和看不見的方塊的坐標位置
  exchange(b, inVisibleBlock);
  //游戲結(jié)束判定
  isWin();
  }
  //交換當(dāng)前方塊和看不見的方塊的坐標位置
  // exchange(b, inVisibleBlock);
  // //游戲結(jié)束判定
  // isWin();
  }
  })
  }
  /**
  * 游戲結(jié)束判定
  */
  function isWin() {
  var wrongs = blocks.filter(function (item) {
  return !item.isCorrect();
  });
  if (wrongs.length === 0) {
  gameConfig.isOver = true;
  //游戲結(jié)束,去掉所有邊框
  blocks.forEach(function (b) {
  b.dom.style.border = "none";
  b.dom.style.display = "block";
  });
  }
  }
  /**
  * 隨機數(shù),能取到最大值
  * @param {*} min
  * @param {*} max
  */
  function getRandom(min, max) {
  return Math.floor(Math.random() * (max + 1 - min) + min);
  }
  /**
  * 交換兩個方塊的left和top
  * @param {*} b1
  * @param {*} b2
  */
  function exchange(b1, b2) {
  var temp = b1.left;
  b1.left = b2.left;
  b2.left = temp;
  temp = b1.top;
  b1.top = b2.top;
  b2.top = temp;
  b1.show();
  b2.show();
  }
  /**
  * 給blocks數(shù)組洗牌
  */
  function shuffle() {
  for (var i = 0; i < blocks.length - 1; i++) {
  //隨機產(chǎn)生一個下標
  var index = getRandom(0, blocks.length - 2);
  //將數(shù)組的當(dāng)前項與隨機項交換left和top值
  exchange(blocks[i], blocks[index]);
  }
  }
  /**
  * 初始化一個小方塊的數(shù)組
  */
  function initBlocksArray() {
  for (var i = 0; i < gameConfig.rows; i++) {
  for (var j = 0; j < gameConfig.cols; j++) {
  //i 行號,j 列號
  var isVisible = true;
  if (i === gameConfig.rows - 1 && j === gameConfig.cols - 1) {
  isVisible = false;
  }
  var b = new Block(j * gameConfig.pieceWidth, i * gameConfig.pieceHeight, isVisible);
  blocks.push(b);
  }
  }
  }
  /**
  * 初始化游戲容器
  */
  function initGameDom() {
  gameConfig.dom.style.width = gameConfig.width + "px";
  gameConfig.dom.style.height = gameConfig.height + "px";
  gameConfig.dom.style.border = "2px solid #ccc";
  gameConfig.dom.style.position = "relative";
  }
  }
  init();


文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/128176.html

相關(guān)文章

  • 利用Vue.js實現(xiàn)拼圖游戲

    摘要:之前寫過一篇基于的表格分頁組件的文章,主要介紹了組件的編寫方法,有興趣的可以訪問這里進行閱讀前言為了進一步讓大家了解的神奇魅力,了解的一種以數(shù)據(jù)為驅(qū)動的理念,本文主要利用實現(xiàn)了一個數(shù)字拼圖游戲,其原理并不是很復(fù)雜,效果圖如下展示地址為有能力 之前寫過一篇《基于Vue.js的表格分頁組件》的文章,主要介紹了Vue組件的編寫方法,有興趣的可以訪問這里進行閱讀:https://segment...

    wh469012917 評論0 收藏0
  • 拼圖游戲

    摘要:學(xué)習(xí)小游戲開發(fā)中最常用的碰撞檢測狀態(tài)監(jiān)控刷新保持狀態(tài)的處理方法。保存縮略圖的信息是當(dāng)游戲結(jié)束后顯示源縮略圖時,根據(jù)中的內(nèi)容展示圖片。 如果您想要綜合使用javascript中canvas、原生拖拽、本地存儲等多種技術(shù)完成一個有趣的項目,那么這篇博文將非常適合您,水平有限,還望感興趣的開發(fā)人員給予更多代碼優(yōu)化建議。 1 簡介和源碼 該項目中的拼圖小游戲使用javascript原創(chuàng),相比于...

    svtter 評論0 收藏0
  • js實現(xiàn)數(shù)字拼圖代碼展示

      話不多說,直接開干?! ≈攸c:  下圖我們可以看到,游戲區(qū)分為8個div,進行游戲時需要判斷點擊的div是否可移動,移動后判斷游戲是否結(jié)束?! 〗鉀Q思路:將游戲界面看作一個div大盒子,將大盒子分為9個區(qū)域進行編號,這9個區(qū)域的位置始終不變;8個div以定位top和left控制其位置,設(shè)置9個區(qū)域的div分別可以往哪個區(qū)域移動,點擊時判斷可移動的編號區(qū)域內(nèi)是否有div,若有,則無法向該方向移動...

    3403771864 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<