网页版2048小游戏

网页版2048小游戏

使用jquery3.3.1 进行的一次开发,各文件源码如下:

2048.css

.div_2048{
	background-color: #FFFAF0;
	width:1000px;
	height:700px;
	padding-left: 20px;
	padding-top: 20px;	
}
.div1{
	background-color: #CDC5BF;
	width:500px;
	height:500px;
	border-radius: 20px;
	padding-left: 20px;
	padding-top: 20px;
	position:relative;
	float:left;
}
.div_num{
	background-color: #CFCFCF;
	width: 100px;
	height: 100px;
	border-radius: 20px;
	margin:10px;
	position:relative;
	float:left;
}
.number-cell{
	width: 100px;
	height:100px;
	border-radius: 20px;
	font-family: Arial;
	font-weight:bold;
	font-size:40px;
	line-height:100px;
	text-align: center;
	position: absolute;
}
.div_header{
	background-color: #FFFAF0;
	width:500px;
	height:100px;
	border-radius: 10px;
	padding-left: 20px;
	padding-top: 20px;
	position:relative;
	float:left;
}
.div_ico{
	background-color:#FFFAF0;
	width: 180px;
	height: 90px;
	font-family: Arial;
	font-weight:bold;
	font-size:80px;
	text-align: center;
	position:relative;
	float:left;
}
.div_score{
	margin-left: 10px;
	margin-top: 15px;
	background-color: #FFFAF0;
	border-radius: 10px;
	width: 150px;
	height: 40px;
	font-family: Arial;
	font-weight:bold;
	font-size:25px;
	text-align: left;
	position:relative;
	float:left;
}
.div_button{
	margin-left: 30px;
	margin-top: 5px;
	background-color: #FFFAF0;
	width: 200px;
	height: 35px;
	font-family: Arial;
	font-weight:bold;
	font-size:25px;
	border-radius: 10px;
	border-color: #FFFAF0;
	text-align: center;
	position:relative;
	float:left;
	cursor:pointer;
}
.div_rank{
	width: 250px;
	height: 620px;
	background-color: #E3E3E3;
	margin:30px;
	border-radius: 10px;
	float:left;
	position:relative;	
}
.rank_num{
	font-family: Arial;
	font-weight:bold;
	font-size:25px;
	line-height: 25px;
	text-align:left;
}
.div_inform{
	background-color: #5f9ea0;
	width: 400px;
	height: 150px;
	border-radius: 10px;
	padding-top: 40px;
	text-align:center;
	font-family: Arial;
	font-weight:bold;
	font-size:50px;
	position: absolute;
	visibility: hidden;	
}

game.js

//jquery准备函数
$(document).ready(function(){
	init();
	init_rank();
});
//创建一个二维数组,用来存储所有的数字
var number_cell=new Array();
var score=0;
var best=0;
var w=0;
//排行榜分数
var rank_num=new Array(10);

//初始化排名
function init_rank(){
	for(var i=0;i<10;i++){
		rank_num[i]=0;
		$("#num_"+(i+1)).html(' No.'+(i+1)+':  '+rank_num[i]);
	}	
}
//更新排行榜
function update_rank(num){
		if(rank_num[9]<num)
			rank_num[9]=num;
		else
		return;
		for(var i=9;i>0;i--){
			if(rank_num[i]>rank_num[i-1]){
				var t=rank_num[i];
				rank_num[i]=rank_num[i-1];
				rank_num[i-1]=t;
			}
		}
		for(var i=0;i<10;i++){
			$("#num_"+(i+1)).html(' No.'+(i+1)+':  '+rank_num[i]);
		}	
}

//初始化数字格
function init(){
	w=0;
	score=0;
	for(var i=0;i<4;i++){
		number_cell[i]=new Array(4);
		for(var j=0;j<4;j++){
			number_cell[i][j]=0;
		}
	}
	suiji();
	suiji();
	update_number_cell();
	hide_inform();
}
//更新数字格
function update_number_cell(){
	$(".number-cell").remove();
	for(var i=0;i<4;i++){
		for(var j=0;j<4;j++){
			$(".div1" ).append("<div class='number-cell' id='number-cell-"+i+"-"+j+"'></div>");
			//通过数字格的id来设置其显示的内容;
			$("#number-cell-"+i+"-"+j).css("top",30+i*120);
			$("#number-cell-"+i+"-"+j).css("left",30+j*120);
			if(number_cell[i][j]!=0)
			{
				$("#number-cell-"+i+"-"+j).css("color",getColor(number_cell[i][j]));
				$("#number-cell-"+i+"-"+j).css("background-color","#F5F5DC");
				$("#number-cell-"+i+"-"+j).html(number_cell[i][j]);
			}
		}
	}
	if(score>best)best=score;
	$("#name1").html("Score:  "+score);
	$("#name2").html("Best:  "+best);
}
//产生随机数
function suiji(){
	//产生随机格子数的坐标
	do{
		var ran_x=Math.floor(Math.random()*4);
		var ran_y=Math.floor(Math.random()*4);
	}while(number_cell[ran_x][ran_y]!=0)
	
	number_cell[ran_x][ran_y]=Math.random()<0.5?2:4;
}
//获得字体颜色
function getColor(number){
	switch(number){
		case 2:return "#8B658B";break;
		case 4:return "#FF8247";break;
		case 8:return "#FF7F24";break;
		case 16:return "#FF0000";break;
		case 32:return "#B03060";break;
		case 64:return "#9400D3";break;
		case 128:return "#6959CD";break;
		case 256:return "#B23AEE";break;
		case 512:return "#8B008B";break;
		case 1024:return "#8B7E66";break;
		case 2048:return "#8B0000";break;
	}
}

//响应键盘事件
$(document).keydown(function(even){
		switch(even.keyCode){
			case 37:{
				if(canMoveLeft()){
					move_left();
					suiji();
					update_number_cell();
				}
				break;
			}
			case 38:{
				if(canMoveUp()){
					move_up();
					suiji();
					update_number_cell();
				}
				break;
			}
			case 39:{
				if(canMoveRight()){
					move_right();
					suiji();
					update_number_cell();
				}
				break;
			}
			case 40:{
				if(canMoveDown()) {
					move_down();
					suiji();
					update_number_cell();
				}
				break;
			}
		}
		inform();
	}); 
//判定是否能左移
function canMoveLeft(){
	for(var i=0;i<4;i++){
		for(var j=1;j<4;j++){
			if(number_cell[i][j]!=0){
 				if(number_cell[i][j-1]==0||number_cell[i][j]==number_cell[i][j-1]){
					return true;
				}
			}
		}
	}
	return false;
}
//判定是否能右移
function canMoveRight(){
	for(var i=0;i<4;i++){
		for(var j=2;j>=0;j--){
			if(number_cell[i][j]!=0){
				if(number_cell[i][j+1]==0||number_cell[i][j]==number_cell[i][j+1]){
					return true;
				}
			}
		}
	}
	return false;
}
//判定是否能上移
function canMoveUp(){
	for(var j=0;j<4;j++){
		for(var i=1;i<4;i++){
			if(number_cell[i][j]!=0){
				if(number_cell[i-1][j]==0||number_cell[i][j]==number_cell[i-1][j]){
					return true;
				}
			}
		}
	}
	return false;
}
//判定是否能下移
function canMoveDown(){
	for(var j=0;j<4;j++){
		for(var i=2;i>=0;i--){
			if(number_cell[i][j]!=0){
				if(number_cell[i+1][j]==0||number_cell[i][j]==number_cell[i+1][j]){
					return true;
				}
			}
		}
	}
}

//下移
function move_left(){
	
	for(var i=0;i<4;i++){
		var f=0;
		for(var j=0;j<4;j++){
			if(number_cell[i][j]!=0){
				
				//判断前面第几个是空格
				for(var k=f;k<j;k++){
					if(number_cell[i][k]==0){
						number_cell[i][k]=number_cell[i][j];
						number_cell[i][j]=0;
						number_animate(i,j,i,k);
					}
					else if(number_cell[i][k]==number_cell[i][j]){
						var temp=0;
						for(var t=k+1;t<j;t++){
							temp+=number_cell[i][t];
						}
						if(temp==0){
							number_cell[i][k]+=number_cell[i][j];
							score+=number_cell[i][k];
							number_cell[i][j]=0;
							number_animate(i,j,i,k);
							f=k+1;
						}
					}
				}
			}	
		}
	}
}
//右移
function move_right(){
	
	for(var i=0;i<4;i++){
		var f=3;
		for(var j=3;j>=0;j--){
			if(number_cell[i][j]!=0){
				//判断后面第几个是空格
				for(var k=f;k>j;k--){
					if(number_cell[i][k]==0){
						number_cell[i][k]=number_cell[i][j];
						number_cell[i][j]=0;
						number_animate(i,j,i,k);
					}
					else if(number_cell[i][k]==number_cell[i][j]){
						var temp=0;
						for(var t=k-1;t>j;t--){
							temp+=number_cell[i][t];
						}
						if(temp==0){
							number_cell[i][k]+=number_cell[i][j];
							score+=number_cell[i][k];
							number_cell[i][j]=0;
							number_animate(i,j,i,k);
							f=k-1;
						}
					}
				}
			}	
		}
	}
}
//上移
function move_up(){
	
	for(var j=0;j<4;j++){
		var f=0;
		for(var i=0;i<4;i++){
			if(number_cell[i][j]!=0){
				//判断上面第几个是空格
				for(var k=f;k<i;k++){
					if(number_cell[k][j]==0){
						number_cell[k][j]=number_cell[i][j];
						number_cell[i][j]=0;
						number_animate(i,j,k,j);
					}
					else if(number_cell[k][j]==number_cell[i][j]){
						var temp=0;
						for(var t=k+1;t<i;t++){
							temp+=number_cell[t][j];
						}
						if(temp==0){
							number_cell[k][j]+=number_cell[i][j];
							score+=number_cell[k][j];
							number_cell[i][j]=0;
							number_animate(i,j,k,j);
							f=k+1;
						}	
					}
				}
			}	
		}
	}
}
//下移
function move_down(){
	for(var j=0;j<4;j++){
		var f=3;
		for(var i=3;i>=0;i--){
			if(number_cell[i][j]!=0){
				//判断下面第几个是空格
				for(var k=f;k>i;k--){
					if(number_cell[k][j]==0){
						number_cell[k][j]=number_cell[i][j];
						number_cell[i][j]=0;
						number_animate(i,j,k,j);
					}
					else if(number_cell[k][j]==number_cell[i][j]){
						var temp=0;
						for(var t=k-1;t>i;t--){
							temp+=number_cell[t][j];
						}
						if(temp==0){
							number_cell[k][j]+=number_cell[i][j];
							score+=number_cell[k][j];
							number_cell[i][j]=0;
							number_animate(i,j,k,j);
							f=k-1;
						}
						
					}
				}
			}	
		}
	}
}

//动画
function number_animate(formX,formY,toX,toY){
	//获得原始单元格对象
	var num_cell=$("#number-cell-"+formX+"-"+formY);
	//开始动画
	num_cell.animate({
		left:30+toY*120,
		top:30+toX*120
	},"",function(){update_number_cell()});
}
//判定是否结束游戏
function fail(){
	if(canMoveLeft()||canMoveRight()||canMoveUp()||canMoveDown())
	    return false;
	else
	    return true;
}
//判定游戏胜利
function win(){
	for(var i=0;i<4;i++){
		for(var j=0;j<4;j++){
			if(number_cell[i][j]==2048){
				return true;
			}
		}
	}
	return false;	
}
//显示通知
function inform(){

	if(fail()&&score!=0){
		update_rank(score);
		$(".div_inform").css("top",300);
		$(".div_inform").css("left",650);
		$(".div_inform").css("visibility","visible");
		$(".div_inform").html("Game Over!"+"<br/>"+score);
		score=0;
	}
	if(w==1){
		hide_inform();
	}
	if(win()&&w==0){
		$(".div_inform").css("top",300);
		$(".div_inform").css("left",650);
		$(".div_inform").css("visibility","visible");
		$(".div_inform").html("Victory!");
		w=1;
	}
	
	
}
//隐藏通知
function hide_inform(){
	$(".div_inform").css("visibility","hidden");
}

效果图:

在这里插入图片描述

资源地址:

https://download.csdn.net/download/qq_37746978/14925964

下载后解压,执行 index.html 即可

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值