明霞山资源网 Design By www.htccd.com
本文实例为大家分享了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>
图片资源:
背景图片:
更多有趣的经典小游戏实现专题,分享给大家:
C++经典小游戏汇总
python经典小游戏汇总
python俄罗斯方块游戏集合
JavaScript经典游戏 玩不停
java经典小游戏汇总
javascript经典小游戏汇总
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
标签:
js,五子棋
明霞山资源网 Design By www.htccd.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
明霞山资源网 Design By www.htccd.com
暂无评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。



