js五子棋游戏
//code
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style>
#mycanvas{
position: absolute;
left: 0;
top: 0;
bottom:0;
right: 0;
background: #eee;
margin: auto;
border:1px solid #333;
box-shadow: 0 0 20px black;
}
</style>
</head>
<body>
<canvas width="600" id='mycanvas' height="600"></canvas>
<script>
(function(){
var arr=[];
var mycanvas=document.getElementById('mycanvas');
var context=mycanvas.getContext('2d');
var witch=true
var win=false
for(var i=0;i<15;i++){
arr[i]=[];
context.moveTo(i*40,0);
context.lineTo(i*40,600);
context.stroke()
context.moveTo(0,i*40);
context.lineTo(600,i*40);
context.stroke()
for(var j=0;j<15;j++){
arr[i][j]={
haschress:false,
who:""
};
}
// console.log(arr)
}
function drawarc(i,j,r){
if(arr[i][j].haschress||i==0||j==0||win){
return
}
context.beginPath();
context.arc(i*40,j*40 ,10,0,Math.PI*2);
context.fillStyle=(witch?'#fff':'#333');
context.fill();
context.stroke();
context.closePath();
arr[i][j].haschress=true;
arr[i][j].who=witch;
witch=!witch;
whowin(i,j)
}
function whowin(i,j,){
//水平
var count =0;
var current=arr[i][j].who;
for(var n=0;n<15;n++){
// console.log(arr[n][j].who)
if(arr[n][j].who===!witch){
count++;
if(count==5){
win=true;
!witch?alert('白棋赢了'):alert('黑棋赢了')
retutn
}
}else{
count=0
}
}
//垂直
count=0;
for(var n=0;n<15;n++){
console.log(arr[i][n].who)
if(arr[i][n].who===!witch){
count++;
if(count==5){
win=true;
!witch?alert('白棋赢了'):alert('黑棋赢了')
return
}
}else{
count=0
}
}
//左上
count=0;
// alert(i)
// alert(j)
//alert(1-(-1))
var num=Math.abs(j-i)
for(var n=0;n<15-num;n++){
if(arr[num-(-n)][n].who===!witch){
// alert(423432)
count++;
// alert(count)
if(count==5){
win=true;
!witch?alert('白棋赢了'):alert('黑棋赢了')
return
}
}else{
count=0
}
}
//左下
// debugger
count = 0
num=j-(-i);
for(var n=0;n<num;n++){
if(arr[n][num-n].who===!witch){
// alert(423432)
count++;
// alert(count)
if(count==5){
win=true;
!witch?alert('白棋赢了'):alert('黑棋赢了')
return
}
}else{
count=0
}
}
}
mycanvas.addEventListener('click',function(e){
var ev=e||window.event;
// var target=e.target||e.srcElement;
console.log(ev)
var i=(ev.offsetX/40).toFixed(0);
var j=(ev.offsetY/40).toFixed(0);;
drawarc(i,j);
})
})()
</script>
</body>
</html>
js五子棋游戏的更多相关文章
- js五子棋游戏代码分享
HTML代码 <canvas id="game"></canvas> CSS代码 * { margin: 0; padding: 0; } #game { ...
- 原生JS+Canvas实现五子棋游戏
一.功能模块 先看下现在做完的效果: 线上体验:https://wj704.github.io/five_game.html 主要功能模块为: 1.人机对战功能 2.悔棋功能 3.撤销悔棋功能 二.代 ...
- 【微信小程序项目实践总结】30分钟从陌生到熟悉 web app 、native app、hybrid app比较 30分钟ES6从陌生到熟悉 【原创】浅谈内存泄露 HTML5 五子棋 - JS/Canvas 游戏 meta 详解,html5 meta 标签日常设置 C#中回滚TransactionScope的使用方法和原理
[微信小程序项目实践总结]30分钟从陌生到熟悉 前言 我们之前对小程序做了基本学习: 1. 微信小程序开发07-列表页面怎么做 2. 微信小程序开发06-一个业务页面的完成 3. 微信小程序开发05- ...
- 基于Blazor写一个简单的五子棋游戏
写这个五子棋游戏,其实主要目的是想尝试一下微软新作Blazor.Blazor对于那些搞.NET的程序员,又想做一些前端工作,真的挺友好,不用一句JS就可搞定前端交互,美哉.现在已经有很流行的前端框架, ...
- Pomelo:网易开源基于 Node.js 的游戏服务端框架
Pomelo:网易开源基于 Node.js 的游戏服务端框架 https://github.com/NetEase/pomelo/wiki/Home-in-Chinese
- 自定义View实现五子棋游戏
成功的路上一点也不拥挤,因为坚持的人太少了. ---简书上看到的一句话 未来请假三天顺带加上十一回家结婚,不得不说真是太坑了,去年婚假还有10天,今年一下子缩水到了3天,只能赶着十一办事了. 最近还在 ...
- Android实训案例(八)——单机五子棋游戏,自定义棋盘,线条,棋子,游戏逻辑,游戏状态存储,再来一局
Android实训案例(八)--单机五子棋游戏,自定义棋盘,线条,棋子,游戏逻辑,游戏状态存储,再来一局 阿法狗让围棋突然就被热议了,鸿洋大神也顺势出了篇五子棋单机游戏的视频,我看到了就像膜拜膜拜,就 ...
- 一个js小游戏----总结
花了大概一天左右的功夫实现了一个js小游戏的基本功能,类似于“雷电”那样的小游戏,实现了随即怪物发生器,碰撞检测,运动等等都实现了,下一个功能是子弹轨迹,还有其他一些扩展功能,没有用库,也没有用web ...
- js canvas游戏初级demo-躲避障碍物
在线演示地址 http://200ok.fun:3100/html/game_demo.html 继上次js canvas游戏初级demo-上下左右移动(https://www.cnblogs.com ...
随机推荐
- <亲测>阿里云centos7安装redis
安装redis yum install redis 启动redis systemctl start redis.service 设置redis开机启动 systemctl enable redis.s ...
- CSS 鼠标选中文字后改变背景色的实现代码
废话不多说,直接上代码 ::-moz-selection{background:#93C; color:#FCF;} ::selection {background:#93C; color:#FCF; ...
- ribbon的注解使用报错--No instances available for [IP]
使用RestTemplate类调用其他系统的url的时候,加上ribbon的注解@LoadBalanced上这个注解之后访问,就报错了. 报错如下: 因为这里你不能直接访问地址,需要把地址改成你所调用 ...
- Ubuntu 14.10 下Eclipse操作HBase
环境介绍 64位Ubuntu14.10,Hadoop 2.5.0 ,HBase 0.99.0 准备环境 1 安装Hadoop 2.5.0,可参考http://www.cnblogs.com/liuch ...
- PAT 乙级 1010 一元多项式求导 (25) C++版
1010. 一元多项式求导 (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 设计函数求一元多项式的导数.(注:xn(n为整数)的一 ...
- C语言强化——排序
1.完成堆排,对比堆排和qsort在排序1亿数的时间差异 #include<stdio.h> #include<time.h> #include<stdlib.h> ...
- C语言怎么简单测试为大小端模式
作者:Slience_J 原文地址:https://blog.csdn.net/slience_j/article/details/52048267 1.什么是大小端模式? 大端模式,是指数据的高字节 ...
- centos 7扩展磁盘分区容量
一.fdisk -l 查看磁盘空间大小 二. 1.fdisk /dev/sda 增加分区 2.判断应增加的分区号 键入n,增加一个分区 3.键入p,主分区,并键入(编号) 4.起始扇区和结束扇区(默认 ...
- re模块小结
一.引子: 文件err.txt中有如下内容: 要求提取出所有的电话号码来. 方法一:文件操作法: f = open('eer.txt','r',encoding='utf-8') l = [] for ...
- [UE4]Set Skeletal Mesh,在蓝图中设置骨骼模型