我們看看js實現簡單拼圖游戲的詳細代碼,HTML僅有一個id為game的div,也不錯編寫CSS,僅要img文件夾中放置一個圖片文件就行,此處我放置的是LOL皇子的圖片,圖片名為'lol.png'
<div id="game"> </div>
下面展示具體效果
多的不說,直接上js代碼
/** * 游戲配置 */ var gameConfig = { width: 500, height: 500, rows: 3, //行數 cols: 3, //列數 isOver: false, //游戲是否結束 imgurl: "img/lol.png", //圖片路徑,注意:相對的是頁面路徑 dom: document.getElementById("game") //游戲的dom對象 }; //每一個小塊的寬高 gameConfig.pieceWidth = gameConfig.width / gameConfig.cols; gameConfig.pieceHeight = gameConfig.height / gameConfig.rows; //小塊的數量 gameConfig.pieceNumber = gameConfig.rows * gameConfig.cols; var blocks = []; //包含小方塊信息的數組 function isEqual(n1, n2) { return parseInt(n1) === parseInt(n2); } /** * 小方塊的構造函數 * @param {*} left * @param {*} top * @param {*} isVisible 是否可見 */ function Block(left, top, isVisible) { this.left = left; //當前的橫坐標 this.top = top; //當前的縱坐標 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秒中內完成 if (!isVisible) { this.dom.style.display = "none"; } gameConfig.dom.appendChild(this.dom); this.show = function () { //根據當前的left、top,重新設置div的位置 this.dom.style.left = this.left + "px"; this.dom.style.top = this.top + "px"; } //判斷當前方塊是否在正確的位置上 this.isCorrect = function () { return isEqual(this.left, this.correctLeft) && isEqual(this.top, this.correctTop); } this.show(); } /** * 初始化游戲 */ function init() { //1. 初始化游戲的容器 initGameDom(); //2. 初始化小方塊 //2.1 準備好一個數組,數組的每一項是一個對象,記錄了每一個小方塊的信息 initBlocksArray(); //2.2 數組洗牌 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)) { //交換當前方塊和看不見的方塊的坐標位置 exchange(b, inVisibleBlock); //游戲結束判定 isWin(); } //交換當前方塊和看不見的方塊的坐標位置 // exchange(b, inVisibleBlock); // //游戲結束判定 // isWin(); } }) } /** * 游戲結束判定 */ function isWin() { var wrongs = blocks.filter(function (item) { return !item.isCorrect(); }); if (wrongs.length === 0) { gameConfig.isOver = true; //游戲結束,去掉所有邊框 blocks.forEach(function (b) { b.dom.style.border = "none"; b.dom.style.display = "block"; }); } } /** * 隨機數,能取到最大值 * @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數組洗牌 */ function shuffle() { for (var i = 0; i < blocks.length - 1; i++) { //隨機產生一個下標 var index = getRandom(0, blocks.length - 2); //將數組的當前項與隨機項交換left和top值 exchange(blocks[i], blocks[index]); } } /** * 初始化一個小方塊的數組 */ 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();
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/128176.html
摘要:之前寫過一篇基于的表格分頁組件的文章,主要介紹了組件的編寫方法,有興趣的可以訪問這里進行閱讀前言為了進一步讓大家了解的神奇魅力,了解的一種以數據為驅動的理念,本文主要利用實現了一個數字拼圖游戲,其原理并不是很復雜,效果圖如下展示地址為有能力 之前寫過一篇《基于Vue.js的表格分頁組件》的文章,主要介紹了Vue組件的編寫方法,有興趣的可以訪問這里進行閱讀:https://segment...
話不多說,直接開干?! ≈攸c: 下圖我們可以看到,游戲區分為8個div,進行游戲時需要判斷點擊的div是否可移動,移動后判斷游戲是否結束?! 〗鉀Q思路:將游戲界面看作一個div大盒子,將大盒子分為9個區域進行編號,這9個區域的位置始終不變;8個div以定位top和left控制其位置,設置9個區域的div分別可以往哪個區域移動,點擊時判斷可移動的編號區域內是否有div,若有,則無法向該方向移動...
閱讀 561·2023-03-27 18:33
閱讀 750·2023-03-26 17:27
閱讀 647·2023-03-26 17:14
閱讀 603·2023-03-17 21:13
閱讀 537·2023-03-17 08:28
閱讀 1823·2023-02-27 22:32
閱讀 1315·2023-02-27 22:27
閱讀 2199·2023-01-20 08:28