五子棋小游戏

这个五子棋小游戏,没有写成人机模式。

但大家可以尝试下自己饰演两个角色的五子棋,嘻嘻嘻

效果图片

ios h5小游戏优化_javascript


ios h5小游戏优化_ios h5小游戏优化_02

效果

ios h5小游戏优化_ios h5小游戏优化_03


ios h5小游戏优化_html5_04

代码

index.html

<!doctype html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>简易五子棋游戏</title>
  <link rel="stylesheet" href="css/main.css">
  <script type="text/javascript" src="js/jquery.min.js"></script>
</head>
<body>
<h1>简易版五子棋小游戏</h1>
<h6>说明:体验下自己饰演两个角色的五子棋吧,嘻嘻。</h6>

<!--canvas是个画布,需要修改的是尺寸,不是修改样式-->
  <canvas id="canvas" width="450" height="450"></canvas>
  <div class="mol-main">
    <div class="mol-header">
      <h2>五子棋小游戏</h2>
    </div>
    <div class="mol-success white">
      白棋获胜
    </div>
    <div class="mol-success black">
      黑棋获胜
    </div>
    <br>
    <div>
      <button class="btn">关闭</button>
    </div>
  </div>
</body>
<script type="text/javascript" src="js/main.js"></script>
<script>
  $('.btn').click(function () {
    $('.mol-main').css('display','none');

  });
</script>
</html>

main.css

body{
    margin:0;
    background: #ccc;
}
h1{
    text-align: center;
}

h6{
    text-align: center;
    color: darkslategray;
}

/*------------棋盘-------------------------*/
#canvas{
    display: block;
    margin: 20px auto;

    background:#fff;
}
.mol-main{
    width:180px;
    height: 160px;
    margin: 0 auto;
    padding: 10px;

    background:#eee;
    border-radius: 10px;
    opacity: 0.9;

    position: absolute;
    top:25%;
    left: 40%;

    display: none;
}
.mol-header h2{
    text-align: left;
    font-weight: bold;
}
.mol-success{
    color: firebrick;
    font-weight: bold;
}

.white{
    display: none;
}
.black{
    display: none;
}

.btn{
    cursor: pointer;
    width: 70px;
    height: 30px;
    border-radius: 5px;
    text-align: center;
    font-weight: bold;;
    background: cadetblue;
    color: #000;
}
.btn:hover{
    background: lightseagreen;
    color: #fff;
}

main,js

/*
*1、绘制棋盘
    *1.1绘制棋盘中直线
* 2、绘制棋子
    *2.1绘制棋子
    * 2.2实现交互,点击下棋
    * 2.3黑白子棋交替操作
    * 2.4棋子落在棋盘交叉点上
    * 2.5设置已下棋处不得再进行操作
* 3、游戏胜负判断
    *当前所下的棋子参与到胜负判断中,此时下棋的人要么赢,要么不赢(输/继续进行)
    * 此时所下棋子的位置应当作为判断点
    * 一条线上左右颜色连续累加超过5,那么这个颜色就获胜
 */
//----------------------------------------------------

//获取到html的canvas标签
var canvas=document.querySelector('#canvas');
//获取绘制环境
var ctx =canvas.getContext('2d');

//创建棋子颜色数组
var chessColor=['#000','#fff'];

//棋盘数组
var maparr=[];

//判断哪方赢
var mode=[
    [1,0],//水平方向
    [0,1],//垂直方向
    [1,1],//右下 左上
    [1,-1]//右上 左下
];

//----------------------------------
//将棋盘上所有交叉点创建全为0的数组
//如果当数组为1时,说明已经有棋子了
for(var i=0;i<14;i++){
    maparr[i]=[];
    for(var j=0;j<14;j++){
        maparr[i][j]=0;
    }
}


//---设置游戏进行的步数-----为了实现黑白棋子交替进行操作--
var step=0;
/*----------绘制棋盘中直线--------------
*描述绘制路径
* 开始绘制
*/
function init() {
    //----------绘制15条垂直和水平直线---------------------
    for(var i=1;i<15;i++){
        //----绘制15条垂直直线------
        //在格子(30,30)处开始画线
        ctx.moveTo(30*i,30);
        //线画到(30,420)的位置
        ctx.lineTo(30*i,420);

        //----绘制15条水平直线-----
        //在格子(30,30)处开始画线
        ctx.moveTo(30,30*i);
        //线画到(420,30)的位置
        ctx.lineTo(420,30*i);
    }
    //-----开始绘制线--------------
    ctx.stroke();
}

init();

//--------绘制棋子---------------------
function drawChess(x,y,color){
    //修改填充颜色
    ctx.fillStyle=color;
    //画圆---圆心坐标轴(x,y)--半径15--起始点角度0--终点角度为2派---
    ctx.beginPath();
    ctx.arc(x,y,15,0,Math.PI*2,false);

    //ctx.fill()填充
    ctx.fill();
    ctx.stroke();
}


//-----下棋----并使棋子都在起哦安交叉线上-----------------------------
canvas.addEventListener('click',function(e){
    // console.log('点击棋盘');


    //--------------------------------------

    //e.offsetX和offsetY可以获取到点击时的坐标
    // console.log(e.offsetX,e.offsetY);

//--------实现所有棋子都在棋盘的交叉线上---------
    //math.floor()向下取整
    //+15---点下去的位置向右偏移15-----
    //----即使得在一个小正方形象限内位置任意点棋子都在那个交叉点出
    var dx =Math.floor((e.offsetX+15)/30)*30;
    var dy =Math.floor((e.offsetY+15)/30)*30;

    //点击落下棋子
    if(dx == 0 || dy == 0 || dx == 450 || dy == 450){
        return false;
    }

    //避免已有棋子的点再下一次
    if(maparr[dx/30-1][dy/30-1]==0){
        drawChess(dx,dy,chessColor[step%2]);
        maparr[dx/30-1][dy/30-1]=chessColor[step%2];

        checkSuccess(dx/30-1,dy/30-1,chessColor[step%2],mode[0]);
        checkSuccess(dx/30-1,dy/30-1,chessColor[step%2],mode[1]);
        checkSuccess(dx/30-1,dy/30-1,chessColor[step%2],mode[2]);
        checkSuccess(dx/30-1,dy/30-1,chessColor[step%2],mode[3]);

        step++;
    }
});

//-----------判断哪方赢------要么黑赢要么白赢--------------------
// var mode=[
//     [1,0],//水平方向
//     [0,1],//垂直方向
//     [1,1],//右下 左上
//     [1,-1]//右上 左下
// ];

//------根据mode数组检测不用方向-------------
function checkSuccess(x,y,color,mode) {
    // console.log(x,y,color);
    var count=0;
    for(var i=1;i<5;i++){
        if(maparr[x+i]*mode[0]){
            if(maparr[x+i*mode[0]][y+i*mode[1]]==color){
                count++;
            }else{
                break;
            }
        }
    }
    for(var i=1;i<5;i++){
        if(maparr[x-i]){
            if(maparr[x-i*mode[0]][y-i*mode[1]]==color){
                count++;
            }else{
                break;
            }
        }
    }
    // console.log('水平方向有',count+1,'个',color);
    if(count>=4){
        if(color=='#000'){
            //显示黑棋获胜框
            $('.mol-main').css('display','block');
            $('.black').css('display','block');

            // alert('黑棋获胜');
        }else{
            //显示白棋获胜框
            $('.mol-main').css('display','block');
            $('.white').css('display','block');

            // alert('白棋获胜');
        }
    }
}