原生JS+Canvas实现五子棋游戏

本文实例为大家分享了JS  Canvas实现五子棋游戏的具体代码,供大家参考,具体内容如下

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8" />
    <title>五子棋</title>
    <style type='text/css'>
      canvas {
        display: block;
        margin: 50px auto;
        box-shadow: -2px -2px 2px #efefef, 5px 5px 5px #b9b9b9;
        cursor: pointer;
      }
      .btn-wrap {
        display: flex;
        flex-direction: row;
        justify-content:center;
      }
      .btn-wrap div {
        margin: 0 10px;
      }
      div>span {
        display: inline-block;
        padding: 10px 20px;
        color: #fff;
        background-color: #EE82EE;
        border-radius: 5px;
        cursor: pointer;
      }
      div.unable span {
        background: #D6D6D4;
        color: #adacaa;
      }
      #result-wrap {text-align: center;}
    </style>
  </head>
  <body>
    <h3 id="result-wrap">--益智五子棋--</h3>
    <canvas id="chess" width="450px" height="450px"></canvas>
    <div class="btn-wrap">
      <div id='restart' class="restart">
        <span>重新开始</span>
      </div>
      <div id='goback' class="goback unable">
        <span>悔棋</span>
      </div>
      <div id='return' class="return unable">
        <span>撤销悔棋</span>
      </div>
    </div>
    <script type="text/javascript" charset="utf-8">
      var over = false;
      var me = true; //我
      var _nowi = 0, _nowj = 0; //记录自己下棋的坐标
      var _compi = 0, _compj = 0; //记录计算机当前下棋的坐标
      var _myWin = [], _compWin = []; //记录我,计算机赢的情况
      var backAble = false, returnAble = false;
      var resultTxt = document.getElementById('result-wrap');
      var chressBord = [];//棋盘
      for(var i = 0; i < 15; i++){
        chressBord[i] = [];
        for(var j = 0; j < 15; j++){
          chressBord[i][j] = 0;
        }
      }
      //赢法的统计数组
      var myWin = [];
      var computerWin = [];
      //赢法数组
      var wins = [];
      for(var i = 0; i < 15; i++){
        wins[i] = [];
        for(var j = 0; j < 15; j++){
          wins[i][j] = [];
        }
      }
      var count = 0; //赢法总数
      //横线赢法
      for(var i = 0; i < 15; i++){
        for(var j = 0; j < 11; j++){
          for(var k = 0; k < 5; k++){
            wins[i][j+k][count] = true;
          }
          count++;
        }
      }
      //竖线赢法
      for(var i = 0; i < 15; i++){
        for(var j = 0; j < 11; j++){
          for(var k = 0; k < 5; k++){
            wins[j+k][i][count] = true;
          }
          count++;
        }
      }
      //正斜线赢法
      for(var i = 0; i < 11; i++){
        for(var j = 0; j < 11; j++){
          for(var k = 0; k < 5; k++){
            wins[i+k][j+k][count] = true;
          }
          count++;
        }
      }
      //反斜线赢法
      for(var i = 0; i < 11; i++){
        for(var j = 14; j > 3; j--){
          for(var k = 0; k < 5; k++){
            wins[i+k][j-k][count] = true;
          }
          count++;
        }
      }
      // debugger;
      for(var i = 0; i < count; i++){
        myWin[i] = 0;
        _myWin[i] = 0;
        computerWin[i] = 0;
        _compWin[i] = 0;
      }
      var chess = document.getElementById("chess");
      var context = chess.getContext('2d');
      context.strokeStyle = '#bfbfbf'; //边框颜色
      var backbtn = document.getElementById("goback");
      var returnbtn = document.getElementById("return");
      window.onload = function(){
        drawChessBoard(); // 画棋盘
      }
      document.getElementById("restart").onclick = function(){
        window.location.reload();
      }
      // 我,下棋
      chess.onclick = function(e){
        if(over){
          return;
        }
        if(!me){
          return;
        }
        // 悔棋功能可用
        backbtn.className = backbtn.className.replace( new RegExp( "(\\s|^)unable(\\s|$)" )," " );
        var x = e.offsetX;
        var y = e.offsetY;
        var i = Math.floor(x / 30);
        var j = Math.floor(y / 30);
        _nowi = i;
        _nowj = j;
        if(chressBord[i][j] == 0){
          oneStep(i,j,me);
          chressBord[i][j] = 1; //我,已占位置     

          for(var k = 0; k < count; k++){ // 将可能赢的情况都加1
            if(wins[i][j][k]){
              // debugger;
              myWin[k]++;
              _compWin[k] = computerWin[k];
              computerWin[k] = 6;//这个位置对方不可能赢了
              if(myWin[k] == 5){
                // window.alert('你赢了');
                resultTxt.innerHTML = '恭喜,你赢了!';
                over = true;
              }
            }
          }
          if(!over){
            me = !me;
            computerAI();
          }
        }
      }
      // 悔棋
      backbtn.onclick = function(e){
        if(!backAble) { return;}
        over = false;
        me = true;
        // resultTxt.innerHTML = 'o(╯□╰)o,悔棋中';
        // 撤销悔棋功能可用
        returnbtn.className = returnbtn.className.replace( new RegExp( "(\\s|^)unable(\\s|$)" )," " );
        // 我,悔棋
        chressBord[_nowi][_nowj] = 0; //我,已占位置 还原
        minusStep(_nowi, _nowj); //销毁棋子
        for(var k = 0; k < count; k++){ // 将可能赢的情况都减1
          if(wins[_nowi][_nowj][k]){
            myWin[k]--;
            computerWin[k] = _compWin[k];//这个位置对方可能赢
          }
        }
        // 计算机相应的悔棋
        chressBord[_compi][_compj] = 0; //计算机,已占位置 还原
        minusStep(_compi, _compj); //销毁棋子
        for(var k = 0; k < count; k++){ // 将可能赢的情况都减1
          if(wins[_compi][_compj][k]){
            computerWin[k]--;
            myWin[k] = _myWin[i];//这个位置对方可能赢
          }
        }
        resultTxt.innerHTML = '--益智五子棋--';
        returnAble = true;
        backAble = false;
      }
      // 撤销悔棋
      returnbtn.onclick = function(e){
        if(!returnAble) { return; }
          // 我,撤销悔棋
        chressBord[_nowi][_nowj] = 1; //我,已占位置
        oneStep(_nowi,_nowj,me);
        for(var k = 0; k < count; k++){
          if(wins[_nowi][_nowj][k]){
            myWin[k]++;
            _compWin[k] = computerWin[k];
            computerWin[k] = 6;//这个位置对方不可能赢
          }
          if(myWin[k] == 5){
            resultTxt.innerHTML = '恭喜,你赢了!';
            over = true;
          }
        }
        // 计算机撤销相应的悔棋
        chressBord[_compi][_compj] = 2; //计算机,已占位置
        oneStep(_compi,_compj,false);
        for(var k = 0; k < count; k++){ // 将可能赢的情况都减1
          if(wins[_compi][_compj][k]){
            computerWin[k]++;
            _myWin[k] = myWin[k];
            myWin[k] = 6;//这个位置对方不可能赢
          }
          if(computerWin[k] == 5){
            resultTxt.innerHTML = 'o(╯□╰)o,计算机赢了,继续加油哦!';
            over = true;
          }
        }
        returnbtn.className += ' '+ 'unable';
        returnAble = false;
        backAble = true;
      }
      // 计算机下棋
      var computerAI = function (){
        var myScore = [];
        var computerScore = [];
        var max = 0;
        var u = 0, v = 0;
        for(var i = 0; i < 15; i++){
          myScore[i] = [];
          computerScore[i] = [];
          for(var j = 0; j < 15; j++){
            myScore[i][j] = 0;
            computerScore[i][j] = 0;
          }
        }
        for(var i = 0; i < 15; i++){
          for(var j = 0; j < 15; j++){
            if(chressBord[i][j] == 0){
              for(var k = 0; k < count; k++){
                if(wins[i][j][k]){
                  if(myWin[k] == 1){
                    myScore[i][j] += 200;
                  }else if(myWin[k] == 2){
                    myScore[i][j] += 400;
                  }else if(myWin[k] == 3){
                    myScore[i][j] += 2000;
                  }else if(myWin[k] == 4){
                    myScore[i][j] += 10000;
                  } 

                  if(computerWin[k] == 1){
                    computerScore[i][j] += 220;
                  }else if(computerWin[k] == 2){
                    computerScore[i][j] += 420;
                  }else if(computerWin[k] == 3){
                    computerScore[i][j] += 2100;
                  }else if(computerWin[k] == 4){
                    computerScore[i][j] += 20000;
                  }
                }
              } 

              if(myScore[i][j] > max){
                max = myScore[i][j];
                u = i;
                v = j;
              }else if(myScore[i][j] == max){
                if(computerScore[i][j] > computerScore[u][v]){
                  u = i;
                  v = j;
                }
              } 

              if(computerScore[i][j] > max){
                max = computerScore[i][j];
                u = i;
                v = j;
              }else if(computerScore[i][j] == max){
                if(myScore[i][j] > myScore[u][v]){
                  u = i;
                  v = j;
                }
              } 

            }
          }
        }
        _compi = u;
        _compj = v;
        oneStep(u,v,false);
        chressBord[u][v] = 2; //计算机占据位置
        for(var k = 0; k < count; k++){
          if(wins[u][v][k]){
            computerWin[k]++;
            _myWin[k] = myWin[k];
            myWin[k] = 6;//这个位置对方不可能赢了
            if(computerWin[k] == 5){
              resultTxt.innerHTML = 'o(╯□╰)o,计算机赢了,继续加油哦!';
              over = true;
            }
          }
        }
        if(!over){
          me = !me;
        }
        backAble = true;
        returnAble = false;
        var hasClass = new RegExp('unable').test(' ' + returnbtn.className + ' ');
        if(!hasClass) {
          returnbtn.className += ' ' + 'unable';
        }
      }
      //绘画棋盘
      var drawChessBoard = function() {
        for(var i = 0; i < 15; i++){
          context.moveTo(15 + i * 30 , 15);
          context.lineTo(15 + i * 30 , 435);
          context.stroke();
          context.moveTo(15 , 15 + i * 30);
          context.lineTo(435 , 15 + i * 30);
          context.stroke();
        }
      }
      //画棋子
      var oneStep = function(i,j,me) {
        context.beginPath();
        context.arc(15 + i * 30, 15 + j * 30, 13, 0, 2 * Math.PI);// 画圆
        context.closePath();
        //渐变
        var gradient = context.createRadialGradient(15 + i * 30 + 2, 15 + j * 30 - 2, 13, 15 + i * 30 + 2, 15 + j * 30 - 2, 0);
        if(me){
          gradient.addColorStop(0,'#0a0a0a');
          gradient.addColorStop(1,'#636766');
        }else{
          gradient.addColorStop(0,'#d1d1d1');
          gradient.addColorStop(1,'#f9f9f9');
        }
        context.fillStyle = gradient;
        context.fill();
      }
      //销毁棋子
      var minusStep = function(i,j) {
        //擦除该圆
        context.clearRect((i) * 30, (j) * 30, 30, 30);
        // 重画该圆周围的格子
        context.beginPath();
        context.moveTo(15+i*30 , j*30);
        context.lineTo(15+i*30 , j*30 + 30);
        context.moveTo(i*30, j*30+15);
        context.lineTo((i+1)*30 , j*30+15); 

        context.stroke();
      }
    </script>
  </body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • javascript 初学教程及五子棋小程序的简单实现

    一.JavaScript简介 JavaScript一种直译式脚本语言,是一种动态类型.弱类型.基于原型的语言,内置支持类型.它的解释器被称为JavaScript引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在HTML(标准通用标记语言下的一个应用)网页上使用,用来给HTML网页增加动态功能. 二.hbulider工具的使用 1) hbulider的特点: 1.飞快的编码速度 2.HBuilder直接创建移动App,打包为ios或Android原生安装包 3.HTML5语法.HTML5+

  • 原生JS+Canvas实现五子棋游戏实例

    一.功能模块 先看下现在做完的效果: 线上体验:https://wj704.github.io/five_game.html 主要功能模块为: 1.人机对战功能 2.悔棋功能 3.撤销悔棋功能 二.代码详解 2.1 人机对战功能实现 从效果图可以看到,棋盘的横竖可以放的位置为15*15,通过canvas画棋盘: //绘画棋盘 var drawChessBoard = function(){ for(var i = 0; i < 15; i++){ context.moveTo(15 + i *

  • 纯JS实现五子棋游戏兼容各浏览器(附源码)

    纯JS五子棋(各浏览器兼容) 效果图:  代码下载 HTML代码 复制代码 代码如下: <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html;"> <title>五子棋</title> <link rel="stylesheet" type="text/

  • Javascript和HTML5利用canvas构建Web五子棋游戏实现算法

    这只是一个简单的JAVAscript和HTML5小程序,没有实现人机对战. 五子棋棋盘落子点对应的二维数组.数组的元素对应落子点.比如数组元素值为0表示该元素对应的落子点没有棋子,数组元素值为1表示该元素对应的落子点有白棋子,数组元素值为2表示该元素对应的落子点有黑棋子: 判断五子棋赢棋的算法是通过对五子棋棋盘落子点对应的二维数组的操作来实现的. 判断五子棋赢棋算法 下边的函数可以实现判断五子棋赢棋的算法,也可以按照教材中相应的算法实现. 其中函数的参数xx.yy为数组下标,chess数组实现五

  • JS+canvas实现的五子棋游戏【人机大战版】

    本文实例讲述了JS+canvas实现的五子棋游戏.分享给大家供大家参考,具体如下: 运行效果图: html代码如下: <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>五子棋</title> <link rel="stylesheet" type="text/css" href="css

  • 原生JS+Canvas实现五子棋游戏

    本文实例为大家分享了JS  Canvas实现五子棋游戏的具体代码,供大家参考,具体内容如下 <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>五子棋</title> <style type='text/css'> canvas { display: block; margin: 50px auto; box-shadow: -2p

  • JS+Canvas实现五子棋游戏

    本文实例为大家分享了JS+Canvas实现五子棋游戏的具体代码,供大家参考,具体内容如下 布局+样式部分代码 : <style type='text/css'> canvas { display: block; margin: 50px auto; box-shadow: -2px -2px 2px #efefef, 5px 5px 5px #b9b9b9; cursor: pointer; } .btn-wrap { display: flex; flex-direction: row; j

  • 利用js canvas实现五子棋游戏

    本文实例为大家分享了canvas实现五子棋游戏的具体代码,供大家参考,具体内容如下 html部分 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> &l

  • js+canvas实现五子棋小游戏

    本文实例为大家分享了js+canvas实现五子棋小游戏的具体代码,供大家参考,具体内容如下 效果展示: 源码展示: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>五子棋</title> <style> * { margin: 0; padding: 0; } body { margin-to

  • 使用原生js+canvas实现模拟心电图的实例

    从2015年2月转行进入IT行业,到现在也有将近两年的时间了,从最开始的java到现在的前端,前进的路上一直靠自己摸索,一路走到现在,前端大神是绝对谈不上的,最多算一只刚入门的菜鸟. 从最开始的懵懵懂懂,到现在学着开始写github.写博客,其实技术上没有太多可写的,毕竟自己也才刚刚入门,只能说是按照自己的兴趣,写点有意思的小项目,项目上存在的问题,也希望大神能够予以指正,目前这个demo的功能已经实现,后期我会对样式.代码等方面进行优化. 项目运行效果: 项目简介:使用原生js+canvas制

  • JS canvas绘制五子棋的棋盘

    本文为大家分享了JS canvas绘制五子棋棋盘的具体代码,供大家参考,具体内容如下 box-shadow:给元素块周边添加阴影效果. 语法:box-shadow: h-shadow v-shadow blur spread color inset: h-shadow: (必须)阴影的水平偏移量,如果是正值,则阴影在元素块右边:如果是负值,则阴影在元素块左边. v-shadow: (必须)阴影的垂直偏移量,如果是正值,则阴影在元素块底部:如果是负值,则阴影在元素块顶部. blur: (可选)阴影

  • js+canvas实现纸牌游戏

    本文实例为大家分享了js+canvas实现纸牌游戏的具体代码,供大家参考,具体内容如下 废话不多说,先上地址 运行截图 最后如果完成了会有结束动画,我技术比较渣,难以玩到结束,就不上完成动画截图了. 游戏介绍 好吧,可能有些好学生在做上机实验时没有玩纸牌游戏,所以容我介绍一下这个游戏,这个游戏是win7自带的一个纸牌类游戏,游戏规则是:将牌按一定的规则码放,最终将所有的牌牌面朝上胜利.有两个地方可以用来码牌,上:以A开头,即将码放的牌的花色相同,且牌面值比原来的牌面大1,则可以码放成功:下:以K

  • JavaScript+canvas实现五子棋游戏

    本文实例为大家分享了JavaScript+canvas实现五子棋游戏的具体代码,供大家参考,具体内容如下 效果截图: 代码实现: <!DOCTYPE html> <html lang="en"> <head>     <meta charset="UTF-8">     <meta name="viewport" content="width=device-width, initia

  • 利用js+canvas实现扫雷游戏

    本文实例为大家分享了用js+canvas实现扫雷游戏的具体代码,供大家参考,具体内容如下 记录js学习后制作的第一关小游戏. 这里的代码还不够精简,许多地方偷懒没有封装,逻辑也有许多可以优化. <body>       胜利条件,找出所有地雷并标记     <form action="javaScript:createContent()">         <div id="message" style="color: red

随机推荐