基于js canvas实现五子棋小游戏

发布时间:2024-05-15 点击:106
本文实例为大家分享了js canvas实现五子棋小游戏的具体代码,供大家参考,具体内容如下
效果展示:
<!doctype html><html lang="en"><head> <meta charset="utf-8"> <title>五子棋</title> <style> * { margin: 0; padding: 0; } body { margin-top: 20px; margin-left: 20px; } canvas { background-image: url("img/bak.jpg"); border: 1px solid #000; } </style></head><body><canvas width="600" height="600" onclick="play(event)"></canvas><script> /*准备工作: 1获取画布,获取画笔对象 */ var mcanvas = document.queryselector("canvas"); var ctx = mcanvas.getcontext("2d"); /*准备工作:2创建一个二维数组 用来定义绘制棋盘线*/ var count = 15;//用来定义棋盘的行数和列数 var map = new array(count); for (var i = 0; i < map.length; i ) { map[i] = new array(count); for (var j = 0; j < map[i].length; j ) { map[i][j] = 0; } } /*准备工作:3初始化棋子*/ var black = new image(); var white = new image(); black.src = "img/black.png"; white.src = "img/white.png"; //开始绘制 1绘制棋盘线 ctx.strokestyle = "#fff"; var rectwh = 40; //设置绘制矩形的大小 for (var i = 0; i < map.length; i ) { for (var j = 0; j < map[i].length; j ) { ctx.strokerect(j * rectwh, i * rectwh, rectwh, rectwh); } } // 用来进行黑白子的切换 var isblack = true; //开始绘制 2下子 function play(e) { //获取点击canvas的位置值默认,canvas的左上角为(0,0) 点 var leftoffset = 20;//body 的margin var x = e.clientx - leftoffset; var y = e.clienty - leftoffset; // console.log(x " " y); // 设置点击点后棋子下在哪里,获取点击的位置进行判断如果超过格子的一半则绘制到下一个点如果小于 则绘制在上一个点上 var xv = (x - rectwh / 2) / rectwh; var yv = (y - rectwh / 2) / rectwh; var col = parseint(xv) 1; var row = parseint(yv) 1; console.log(xv " " yv " , " col " " row); //严格点需要验证 ,验证所输入的点是否在数组中已经存在 ,如果存在 则返回 if (map[row][col] != 0) { alert("咋的,还想往我身上下啊!瞎啊!没看见已经有棋子了!!!"); return; } // 切换绘制黑白子 if (isblack) { ctx.drawimage(black, col * 40 - 20, row * 40 - 20); isblack = false; map[row][col] = 1; yes(1, row, col); } else { ctx.drawimage(white, col * 40 - 20, row * 40 - 20); isblack = true; map[row][col] = 2; yes(2, row, col); } } //算法验证,查看谁赢 tag :1 :黑子 2 :白子 function yes(t, row, col) { console.log(1); var orgrow = row; var orgcol = col; var total = 1; // 判断依据,以当前下的棋子为圆心,水平方向左右寻找和自己想通的值 ,最后判断如果大于5个则表示胜利 // 1水平方向判断 while (col - 1 > 0 && map[row][col - 1] == t) { //判断下一个值 注意一定是:col-1 total ; col--; } row = orgrow; col = orgcol; while (col 1 < 15 && map[row][col 1] == t) { col ; total ; } if (total >= 5) { if (t == 1){ alert("黑子赢"); } else{ alert("白子赢"); } return;//判断出输赢结束后续判断 } // 2垂直方向判断 row = orgrow; col = orgcol; total = 1; while (row - 1 > 0 && map[row - 1][col] == t) { row--; total ; } row = orgrow; col = orgcol; while (row 1 < 15 && map[row 1][col] == t) { row ; total ; } if (total >= 5) { if (t == 1){ alert("黑子赢"); } else{ alert("白子赢"); } return;//判断出输赢结束后续判断 } //左下 右上 row = orgrow; col = orgcol; total = 1; while (row 1 < 15 && col - 1 > 0 && map[row 1][col - 1] == t) { row ; col--; total ; } row = orgrow; col = orgcol; while (row - 1 > 0 && col 1 < 15 && map[row - 1][col 1] == t) { row--; col ; total ; } if (total >= 5) { if (t == 1){ alert("黑子赢"); } else{ alert("白子赢"); } return;//判断出输赢结束后续判断 } //左上右下 row = orgrow; col = orgcol; total = 1; while (row - 1 > 0 && col - 1 > 0 && map[row - 1][col - 1] == t) { row--; col--; total ; } row = orgrow; col = orgcol; while (row 1 < 15 && col 1 < 15 && map[row 1][col 1] == t) { row ; col ; total ; } if (total >= 5) { if (t == 1){ alert("黑子赢"); } else{ alert("白子赢"); } return;//判断出输赢结束后续判断 } } /*功能扩充: 1当胜利后 弹框:a是否在来一局 b 精彩回复 a 如果点击在来一句 清空数据重新开始 b 精彩回放将棋盘黑白子按照下棋的顺序进行棋子编号2悔棋功能 3对算法的扩充 a如果是双三 则直接弹出胜利 b若是桶四 则直接弹出胜利 */</script></body></html>图片

手机域名是什么及注册手机域名的优势
服务器IP重定向到一个默认网站操作步骤
手机网站怎么做适应不同设备浏览
阿里云服务器购买是否提供数据库
怎么做电商网站有助于转化
cebtos云服务器如何看
网站建设的规划意义 网站规划有什么特点
需要什么申请域名的相关资料