首页
/
每日頭條
/
遊戲
/
怎樣完成2048小遊戲
怎樣完成2048小遊戲
更新时间:2025-01-10 02:50:41

怎樣完成2048小遊戲?html:<!DOCTYPE html>,我來為大家講解一下關于怎樣完成2048小遊戲?跟着小編一起來看一看吧!

怎樣完成2048小遊戲(給大家分享一個網頁版的2048小遊戲做法)1

怎樣完成2048小遊戲

html:

<!DOCTYPE html>

<html>

<head>

<meta charset="UTF-8">

<title>網頁版2048遊戲</title>

<style>

/* 遊戲棋盤格 */

body{font-family:Arial;text-align:center;}

.game{margin:0 auto;/*margin-top:40px;*/text-align:center;display:inline-block;}

.game-score{font-size:20px;margin:20px auto;}

.game-container{background-color:#bbada0;border-radius:10px;position:relative;}

.game-cell{border-radius:6px;background-color:#ccc0b3;position:absolute;}

.game-num{width:0px;height:0px;border-radius:6px;font-weight:bold;font-size:40px;color:#fff;text-align:center;position:absolute;}

.game-num-2{background:#eee4da;color:#776e65;}

.game-num-4{background:#ede0c8;color:#776e65;}

.game-num-8{background:#f2b179;}

.game-num-16{background:#f59563;}

.game-num-32{background:#f67c5f;}

.game-num-64{background:#f65e3b;}

.game-num-128{background:#edcf72;font-size:35px;}

.game-num-256{background:#edcc61;font-size:35px;}

.game-num-512{background:#9c0;font-size:35px;}

.game-num-1024{background:#33b5e5;font-size:30px;}

.game-num-2048{background:#09c;font-size:30px;}

/*遊戲結束*/

.game-over{width:100%;height:100%;position:absolute;border-radius:10px;box-sizing:border-box;z-index:1;display:table;background:rgba(123,102,85,0.5)}

.game-over-info{display:table-cell;vertical-align:middle}

.game-over p{font-size:45px;color:#fff;margin:20px auto;}

.game-over span{cursor:pointer;background-color:rgba(103,82,65,0.6);display:block;margin:20px auto;width:180px;padding:10px 10px;font-size:25px;color:#f7f2e5;border-radius:10px;border:1px solid #978271;transition:all .2s}

.game-over span:hover{background-color:rgba(103,82,65,0.7);color:#fff}

.game-hide{display:none;}

</style>

</head>

<body>

<div id="game" class="game">

<div class="game-score">分數:<span id="game_score">0</span></div>

<div id="game_container" class="game-container">

<div id="game_over" class="game-over game-hide">

<div class="game-over-info">

<div id="game_over_info"></div>

<span id="game_restart">重新開始</span>

</div>

</div>

</div>

</div>

<script src="js/jQuery-1.12.4.min.js"></script>

<script src="js/Game2048.js"></script>

<script>

Game2048({prefix: 'game', len: 4, size: 100, margin: 20});

</script>

</body>

</html>

Game2048js文件:

(function(window, document, $) {

function Game2048(opt) {

var prefix = opt.prefix, len = opt.len, size = opt.size, margin = opt.margin;

var score = 0;

var winNum = 2048;

var isGameOver = true;

var board = new Board(len);

var view = new View(prefix, len, size, margin);

view.init();

board.onGenerate = function(e) {

view.addNum(e.x, e.y, e.num);

};

board.onMove = function(e) {

if (e.to.num >= winNum) {

isGameOver = true;

setTimeout(function() { view.win(); }, 300);

}

if (e.to.num > e.from.num) {

score = e.to.num;

view.updateScore(score);

}

view.move(e.from, e.to);

};

board.onMoveComplete = function(e) {

if (!board.canMove()) {

isGameOver = true;

setTimeout(function() { view.over(score); }, 300);

}

if (e.moved) {

setTimeout(function(){ board.generate(); }, 200);

}

};

$(document).keydown(function(e) {

if (isGameOver) {

return false;

}

switch (e.which) {

case 37: board.moveLeft(); break;

case 38: board.moveUp(); break;

case 39: board.moveRight(); break;

case 40: board.moveDown(); break;

}

});

function start() {

score = 0;

view.updateScore(0);

view.cleanNum();

board.init();

board.generate();

board.generate();

isGameOver = false;

}

$('#' prefix '_restart').click(start);

start();

};

// 數據處理

function Board(len) {

this.len = len;

this.arr = [];

}

Board.prototype = {

// 事件

onGenerate: function() {},

onMove: function() {},

onMoveComplete: function() {},

// 創建數組

init: function() {

for (var arr = [], x = 0, len = this.len; x < len; x) {

arr[x] = [];

for (var y = 0; y < len; y) {

arr[x][y] = 0;

}

}

this.arr = arr;

},

// 在随機位置增加一個随機數

generate: function() {

var empty = [];

for (var x = 0, arr = this.arr, len = arr.length; x < len; x) {

for (var y = 0; y < len; y) {

if (arr[x][y] === 0) {

empty.push({x: x, y: y});

}

}

}

if (empty.length < 1) {

return false;

}

var pos = empty[Math.floor((Math.random() * empty.length))];

this.arr[pos.x][pos.y] = Math.random() < 0.5 ? 2 : 4;

this.onGenerate({x: pos.x, y: pos.y, num: this.arr[pos.x][pos.y]});

},

// 左移

moveLeft: function() {

var canMove = false;

// 從上到下,從左到右

for (var x = 0, len = this.arr.length; x < len; x) {

for (var y = 0, arr = this.arr[x]; y < len; y) {

// 從 y 1 位置開始,向右查找

for (var next = y 1; next < len; next) {

// 如果 next 單元格是 0,找下一個不是嗎 0 的單元格

if (arr[next] === 0) {

continue;

}

// 如果 y 數字是 0,則将 next 移動到 y 位置,然後将 y 減 1 重新查找

if (arr[y] === 0) {

arr[y] = arr[next];

this.onMove({from: {x: x, y: next, num: arr[next]}, to: {x: x, y: y, num: arr[y]}});

arr[next] = 0;

canMove = true;

--y;

// 如果 y 與 next 單元格數字相等,則将 next 移動并合并給 y

} else if (arr[y] === arr[next]) {

arr[y] = arr[next];

this.onMove({from: {x: x, y: next, num: arr[next]}, to: {x: x, y: y, num: arr[y]}});

arr[next] = 0;

canMove = true;

}

break;

}

}

}

this.onMoveComplete({moved: canMove});

},

moveRight: function() {

var moved = false;

for (var x = 0, len = this.arr.length; x < len; x) {

for (var y = len - 1, arr = this.arr[x]; y >= 0; --y) {

for (var prev = y - 1; prev >= 0; --prev) {

if (arr[prev] === 0) {

continue;

}

if (arr[y] === 0) {

arr[y] = arr[prev];

this.onMove({from: {x: x, y: prev, num: arr[prev]}, to: {x: x, y: y, num: arr[y]}});

arr[prev] = 0;

moved = true;

y;

} else if (arr[y] === arr[prev]) {

arr[y] = arr[prev];

this.onMove({from: {x: x, y: prev, num: arr[prev]}, to: {x: x, y: y, num: arr[y]}});

arr[prev] = 0;

moved = true;

}

break;

}

}

}

this.onMoveComplete({moved: moved});

},

moveUp: function() {

var canMove = false;

for (var arr = this.arr, len = arr.length, y = 0; y < len; y) {

for (var x = 0; x < len; x) {

for (var next = x 1; next < len; next) {

if (arr[next][y] === 0) {

continue;

}

if (arr[x][y] === 0) {

arr[x][y] = arr[next][y];

this.onMove({from: {x: next, y: y, num: arr[next][y]}, to: {x: x, y: y, num: arr[x][y]}});

arr[next][y] = 0;

canMove = true;

--x;

} else if (arr[x][y] === arr[next][y]) {

arr[x][y] = arr[next][y];

this.onMove({from: {x: next, y: y, num: arr[next][y]}, to: {x: x, y: y, num: arr[x][y]}});

arr[next][y] = 0;

canMove = true;

}

break;

}

}

}

this.onMoveComplete({moved: canMove});

},

moveDown: function() {

var canMove = false;

for (var arr = this.arr, len = arr.length, y = 0; y < len; y) {

for (var x = len - 1; x >= 0; --x) {

for (var prev = x - 1; prev >= 0; --prev) {

if (arr[prev][y] === 0) {

continue;

}

if (arr[x][y] === 0) {

arr[x][y] = arr[prev][y];

this.onMove({from: {x: prev, y: y, num: arr[prev][y]}, to: {x: x, y: y, num: arr[x][y]}});

arr[prev][y] = 0;

canMove = true;

x;

} else if (arr[x][y] === arr[prev][y]) {

arr[x][y] = arr[prev][y];

this.onMove({from: {x: prev, y: y, num: arr[prev][y]}, to: {x: x, y: y, num: arr[x][y]}});

arr[prev][y] = 0;

canMove = true;

}

break;

}

}

}

this.onMoveComplete({moved: canMove});

},

canMove: function() {

for (var x = 0, arr = this.arr, len = arr.length; x < len; x) {

for (var y = 0; y < len; y) {

if (arr[x][y] === 0) {

return true;

}

var curr = arr[x][y], right = arr[x][y 1];

var down = arr[x 1] ? arr[x 1][y] : null;

if (right === curr || down === curr) {

return true;

}

}

}

return false;

}

};

// 視圖處理

function View(prefix, len, size, margin) {

this.prefix = prefix;

this.len = len; // 單元格單邊的數量(實際數量 len * len)

this.size = size; // 每個單元格的邊長

this.margin = margin; // 每個單元格的間距

this.score = $('#' prefix '_score');

this.container = $('#' prefix '_container');

var containerSize = len * size margin * (len 1);

this.container.css({width:containerSize , height: containerSize});

this.nums = {};

}

View.prototype = {

// 計算位置

getPos: function(n) {

return this.margin n * (this.size this.margin);

},

init: function() {

for (var x = 0, len = this.len; x < len; x) {

for (var y = 0; y < len; y) {

var $cell = $('<div class="' this.prefix '-cell"></div>');

$cell.css({

width: this.size 'px', height: this.size 'px',

top: this.getPos(x), left: this.getPos(y)

}).appendTo(this.container);

}

}

},

addNum: function(x, y, num) {

var $num = $('<div class="' this.prefix '-num ' this.prefix '-num-' num ' ">');

$num.text(num).css({

top: this.getPos(x) parseInt(this.size / 2),

left: this.getPos(y) parseInt(this.size / 2)

}).appendTo(this.container).animate({

width: this.size 'px',

height: this.size 'px',

lineHeight: this.size 'px',

top: this.getPos(x),

left: this.getPos(y)

}, 100);

this.nums[x '-' y] = $num;

},

move: function(from, to) {

var fromIndex = from.x '-' from.y, toIndex = to.x '-' to.y;

var clean = this.nums[toIndex];

this.nums[toIndex] = this.nums[fromIndex];

delete this.nums[fromIndex];

var prefix = this.prefix '-num-';

var pos = {top: this.getPos(to.x), left: this.getPos(to.y)};

this.nums[toIndex].finish().animate(pos, 200, function() {

if (to.num > from.num) {

clean.remove();

$(this).text(to.num).removeClass(prefix from.num).addClass(prefix to.num);

}

});

},

updateScore: function(score) {

this.score.text(score);

},

win: function() {

$('#' this.prefix '_over_info').html('<p>您獲勝了</p>');

$('#' this.prefix '_over').removeClass(this.prefix '-hide');

},

over: function(score) {

$('#' this.prefix '_over_info').html('<p>本次得分</p><p>' score '</p>');

$('#' this.prefix '_over').removeClass(this.prefix '-hide');

},

cleanNum: function() {

this.nums = {};

$('#' this.prefix '_over').addClass(this.prefix '-hide');

$('.' this.prefix '-num').remove();

}

};

window['Game2048'] = Game2048;

})(window, document, jQuery);

然後就是還要自己下載一個jQuery文件;

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
魔獸争霸sky一波流開局(魔獸争霸快速熟悉遊戲)
魔獸争霸sky一波流開局(魔獸争霸快速熟悉遊戲)
  shift鍵,順序執行鍵編隊鍵作用其實很簡單,說白了就是讓一個單位連續的做幾件事但這個快捷鍵的功能堪稱魔獸最多,也是玩家必修的一個快捷鍵①讓一個農民做完建築之後自動回去采礦做法是選中農民,下達建造命令以後按住shift,再用右鍵點擊木頭,或者金礦②讓一個農民連續做幾樣建築做法是選中農民,下達第一個建造命令,按住shift,能下達第二個建造命令結合第1種方...
2025-01-10
卡普空遊戲在什麼平台(卡普空上線社區類網站)
卡普空遊戲在什麼平台(卡普空上線社區類網站)
  時值公司40周年慶,卡普空上線一個叫Capcom Town的城市社區類網站,回顧和宣傳旗下IP産品。很重要的一點,玩家在浏覽器上可以遊玩一些經典遊戲。         進入Capcom Town之後,點擊右上角的街機圖标,進入街機模式。卡普空将旗下五款經典街機遊戲改成了網頁版,提供免費在線遊玩,它們分别是《洛克人1》《洛克人2》《洛克人X》《街霸2》《快...
2025-01-10
榮耀v10五小時續航測試(榮耀V10續航水平測試)
榮耀v10五小時續航測試(榮耀V10續航水平測試)
  榮耀V10已經用了将近一個月了,3750mAh的電池,比上一代V9的4000mAh小,而屏幕從5.7英寸增至5.99英寸5,因此很多人開始質疑V10的續航問題。   有網友表示,看網頁和圖片一晚上還剩19%的電量:      但很多人入手V10,肯定會用來看視頻和玩網遊,這時候續航能力還行不行?且看測試:      看視頻和玩網遊續航測試:   1、在線...
2025-01-10
騰訊這兩年出的動作闖關類遊戲(騰訊曾有一款非常好的動作遊戲卻沒珍惜)
騰訊這兩年出的動作闖關類遊戲(騰訊曾有一款非常好的動作遊戲卻沒珍惜)
  小球球之前在寫了一篇動作遊戲的文章,有很多小夥伴提到了《第九大陸》這個遊戲,仔細想來,《第九大陸》也算是動作遊戲早期赫赫有名之作了,今天就來提一提。   《第九大陸》這個遊戲是個好遊戲,涼也涼的很可惜,時至今日都有這麼多人記住它的名字,說明它是有IP爆款的潛力的。      然而最終傷仲永,當年騰訊代理的時候還以為這款遊戲如同騰訊其他遊戲一般,然後把《洛...
2025-01-10
遊戲王決鬥鍊接最值得的超量卡組(遊戲王超速決鬥)
遊戲王決鬥鍊接最值得的超量卡組(遊戲王超速決鬥)
  【遊戲王】超速決鬥最強卡組對戰重騎道的驕傲 VS 極限召喚聖所,接下來我們就來聊聊關于遊戲王決鬥鍊接最值得的超量卡組?以下内容大家不妨參考一二希望能幫到您!   遊戲王決鬥鍊接最值得的超量卡組   【遊戲王】超速決鬥!最強卡組對戰!重騎道的驕傲 VS 極限召喚聖所   油管搬運,www.youtube.com   ,
2025-01-10
Copyright 2023-2025 - www.tftnews.com All Rights Reserved