JS canvas绘制五子棋的棋盘


Posted in Javascript onMay 28, 2020

本文为大家分享了JS canvas绘制五子棋棋盘的具体代码,供大家参考,具体内容如下

box-shadow:给元素块周边添加阴影效果。
语法:box-shadow: h-shadow v-shadow blur spread color inset;
h-shadow: (必须)阴影的水平偏移量,如果是正值,则阴影在元素块右边;如果是负值,则阴影在元素块左边。
v-shadow: (必须)阴影的垂直偏移量,如果是正值,则阴影在元素块底部;如果是负值,则阴影在元素块顶部。
blur: (可选)阴影的模糊半径,其值大于等于0;为0时阴影不具有模糊效果,值越大阴影边缘越模糊。
spread: (可选)阴影扩展半径,值为正,整个阴影都扩大;值为负,整个阴影都缩小。
color: (可选)阴影颜色。
insert: (可选)不设值则默认为外部阴影,取insert则投影为内阴影。

代码如下

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>五子棋</title>
 <style type="text/css">
 canvas{
 display: block;
 margin: 50px auto;
 box-shadow: -2px -2px 2px #F3F2F2, 5px 5px 5px #6F6767;
 }
 </style>
</head>
<body>
 <canvas id="mycanvas" width="450px" height="450px"></canvas>
 <script type="text/javascript">
 var chess = document.getElementById("mycanvas");
 var context = chess.getContext('2d');
 var me = true;
 var chessBox = [];//用于存放棋盘中落子的情况
 for(var i=0;i<15;i++){
  chessBox[i]=[];
  for(var j=0;j<15;j++){
  chessBox[i][j]=0;//初始值为0
  }
 }
 function drawChessBoard(){
  for(var i=0;i<15;i++){
  context.strokeStyle="#D6D1D1";
  context.moveTo(15+i*30,15);//垂直方向画15根线,相距30px;
  context.lineTo(15+i*30,435);
  context.stroke();
  context.moveTo(15,15+i*30);//水平方向画15根线,相距30px;棋盘为14*14;
  context.lineTo(435,15+i*30);
  context.stroke();
  }
 }
 drawChessBoard();//绘制棋盘
 function oneStep(i,j,k){
  context.beginPath();
  context.arc(15+i*30,15+j*30,13,0,2*Math.PI);//绘制棋子
  var g=context.createRadialGradient(15+i*30,15+j*30,13,15+i*30,15+j*30,0);//设置渐变
  if(k){    //k=true是黑棋,否则是白棋
  g.addColorStop(0,'#0A0A0A');//黑棋
  g.addColorStop(1,'#636766');
  }else {
  g.addColorStop(0,'#D1D1D1');//白棋
  g.addColorStop(1,'#F9F9F9');
  }
  context.fillStyle=g;
  context.fill();
  context.closePath();
 }
 chess.onclick=function(e){
  var x = e.offsetX;//相对于棋盘左上角的x坐标
  var y = e.offsetY;//相对于棋盘左上角的y坐标
  var i = Math.floor(x/30);
  var j = Math.floor(y/30);
  if( chessBox[i][j] == 0 ) {
  oneStep(i,j,me);
  if(me){
   chessBox[i][j]=1;
  }else{
   chessBox[i][j]=2;
  }
  me=!me;//下一步白棋
  }
 }
 </script>
</body>
</html>

效果图是这样的

JS canvas绘制五子棋的棋盘

更多有趣的经典小游戏实现专题,分享给大家:

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

Javascript 相关文章推荐
用 JSON 处理缓存
Apr 27 Javascript
javascript 同时在IE和FireFox获取KeyCode的代码
Feb 07 Javascript
jQuery ajax BUG:object doesn't support this property or method
Jul 06 Javascript
移动Web中图片自适应的两种JavaScript解决方法
Jun 18 Javascript
jquery图片倾斜层叠切换特效代码分享
Aug 27 Javascript
AngularJS基础 ng-if 指令用法
Aug 01 Javascript
javascript基础知识讲解
Jan 11 Javascript
vue移动端轻量级的轮播组件实现代码
Jul 12 Javascript
微信小程序获取用户信息的两种方法wx.getUserInfo与open-data实例分析
May 03 Javascript
p5.js临摹旋转爱心
Oct 23 Javascript
Vue CLI4 Vue.config.js标准配置(最全注释)
Jun 05 Javascript
解决ant Design中this.props.form.validateFields未执行的问题
Oct 27 Javascript
在vue中解决提示警告 for循环报错的方法
Sep 28 #Javascript
H5+C3+JS实现五子棋游戏(AI篇)
May 28 #Javascript
解决微信小程序防止无法回到主页的问题
Sep 28 #Javascript
在vue中更换字体,本地存储字体非引用在线字体库的方法
Sep 28 #Javascript
H5+C3+JS实现双人对战五子棋游戏(UI篇)
May 28 #Javascript
Vue2.x中利用@font-size引入字体图标报错的解决方法
Sep 28 #Javascript
vue element table 表格请求后台排序的方法
Sep 28 #Javascript
You might like
php下载远程文件类(支持断点续传)
2008/11/14 PHP
php删除一个路径下的所有文件夹和文件的方法
2018/02/07 PHP
实例说明js脚本语言和php脚本语言的区别
2019/04/04 PHP
JS Timing
2007/04/21 Javascript
js类的静态属性和实例属性的理解
2009/10/01 Javascript
js动态修改input输入框的type属性(实现方法解析)
2013/11/13 Javascript
js实现按一下删除键删除整个单词附demo
2014/09/05 Javascript
JavaScript中的全局对象介绍
2015/01/01 Javascript
javascript限制文本框输入值类型的方法
2015/05/07 Javascript
ECMAScript6轮播图实践知识总结
2016/08/17 Javascript
jQuery实现的放大镜效果示例
2016/09/13 Javascript
JS实现表单验证功能(验证手机号是否存在,验证码倒计时)
2016/10/11 Javascript
JavaScript箭头函数_动力节点Java学院整理
2017/06/28 Javascript
JavaScript之DOM_动力节点Java学院整理
2017/07/03 Javascript
vuejs手把手教你写一个完整的购物车实例代码
2017/07/06 Javascript
详解vue 组件之间使用eventbus传值
2017/10/25 Javascript
JavaScript类数组对象转换为数组对象的方法实例分析
2018/07/24 Javascript
使用webpack将ES6转化ES5的实现方法
2019/10/13 Javascript
微信小程序实现上传多个文件 超过10个
2020/03/30 Javascript
用Python实现斐波那契(Fibonacci)函数
2016/03/25 Python
Python Requests模拟登录实现图书馆座位自动预约
2018/04/27 Python
Python实现的直接插入排序算法示例
2018/04/29 Python
Python批量生成特定尺寸图片及图画任意文字的实例
2019/01/30 Python
python 定时器每天就执行一次的实现代码
2019/08/14 Python
CSS3中Animation动画属性用法详解
2016/07/04 HTML / CSS
浅谈CSS3 动画卡顿解决方案
2019/01/02 HTML / CSS
HTML5 canvas标签实现刮刮卡效果
2015/04/24 HTML / CSS
英国虚拟主机服务商:eUKhost
2016/08/16 全球购物
数据库基础的一些面试题
2012/02/25 面试题
社团招新策划书
2014/02/04 职场文书
《谁的本领大》教后反思
2014/04/25 职场文书
法制宣传口号
2014/06/16 职场文书
学校师德师风整改措施
2014/10/27 职场文书
银行客户经理岗位职责
2015/04/09 职场文书
食品安全责任书范本
2015/05/09 职场文书
百日宴上的祝酒词
2015/08/10 职场文书