js+canvas实现纸牌游戏


Posted in Javascript onMarch 16, 2020

本文实例为大家分享了js+canvas实现纸牌游戏的具体代码,供大家参考,具体内容如下

废话不多说,先上地址

运行截图

js+canvas实现纸牌游戏

js+canvas实现纸牌游戏

最后如果完成了会有结束动画,我技术比较渣,难以玩到结束,就不上完成动画截图了。

游戏介绍

好吧,可能有些好学生在做上机实验时没有玩纸牌游戏,所以容我介绍一下这个游戏,这个游戏是win7自带的一个纸牌类游戏,游戏规则是:将牌按一定的规则码放,最终将所有的牌牌面朝上胜利。有两个地方可以用来码牌,上:以A开头,即将码放的牌的花色相同,且牌面值比原来的牌面大1,则可以码放成功;下:以K开头,即将码放的牌的颜色不同,且牌面值比原来的牌面小1,则可以成功码放。

支持的操作

点击、拖拽相比微软纸牌,增加了点击牌自动找到合适的位置的码放方式,所以整个游戏大部分操作只需要点击就可以了。

设计思路

1. 游戏运行驱动

游戏以玩家操作(鼠标点击与移动)为驱动。
点击与移动鼠标时,通过记录鼠标的位置与状态,可以得到以下四个事件(按下、移动、弹起、单击)。
首先,需要注册鼠标点击、移动和弹起事件

function BindEvent()
  {
   $(window).bind("mousedown touchstart", function (e)
   {
    e.preventDefault();
    var x;
    var y;
    if (e.type == "touchstart")
    {
     x = e.originalEvent.changedTouches[0].clientX;
     y = e.originalEvent.changedTouches[0].clientY;
    }
    else
    {
     x = e.clientX;
     y = e.clientY;
    }
    if (isPlayingAnimation)
    {
     return;
    }
    ActionDown(x, y - 50);
   });

   $(window).bind("mousemove touchmove", function (e)
   {
    e.preventDefault();
    var x;
    var y;
    if (e.type == "touchmove")
    {
     x = e.originalEvent.changedTouches[0].clientX;
     y = e.originalEvent.changedTouches[0].clientY;
    }
    else
    {
     x = e.clientX;
     y = e.clientY;
    }
    if (isPlayingAnimation)
    {
     return;
    }
    ActionMove(x, y - 50);
   });

   $(window).bind("mouseup touchend", function (e)
   {
    e.preventDefault();
    var x;
    var y;
    if (e.type == "touchend")
    {
     x = e.originalEvent.changedTouches[0].clientX;
     y = e.originalEvent.changedTouches[0].clientY;
    }
    else
    {
     x = e.clientX;
     y = e.clientY;
    }
    if (isPlayingAnimation)
    {
     return;
    }
    ActionUp(x, y - 50);
   });
  }

然后在弹起事件里面检测鼠标在弹起之前移动了多少距离,如果移动的距离很小,可以忽略不计,则认为这是一次点击操作。

注意:这里事件注册不是在每张牌上,因为52张牌实际上都画在canvas上,然而52张牌的坐标都是知道的,所以通过计算就可以知道用选择了哪些牌,正在将牌移到哪里。等玩家松手后就可以实现码放操作。

2. 界面设计

顶栏用于显示积分、时间

<div id="titleContainer">
  <div>Score:<span id="score">0</span></div>
  <div>Timer:<span id="timer">00:00:00</span></div>
</div>

接下来就是桌面

<div id="deskTop">
  <canvas id="canvasBack"></canvas>
  <canvas id="canvasFont"></canvas>
</div>

可以看到,桌面有两个canvas,一前一后,这实际上是将游戏画面分为了两层,玩家看到的画面是两个画面叠加在一起的。

之所以用两个层,主要是为了避免实时绘制整个界面,鼠标选中一些牌后将要实施移动操作,这时实际上只有被鼠标选中的那些牌的位置在变化,而桌上剩余的牌实际上没有任何变化,这时如果还实时绘制后面的没有变化的牌有些浪费。所以把鼠标选中的那些牌拿出来,放到canvasFont层里面,这样,两个层都不用实时绘制,被鼠标选中的牌在移动的时候只需要移动他们被绘制在的canvasFont就可以了。

3. 流程

js+canvas实现纸牌游戏

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

Javascript 相关文章推荐
在你的网页中嵌入外部网页的方法
Apr 02 Javascript
javascript使用prototype完成单继承
Dec 24 Javascript
JavaScript原生对象之Date对象的属性和方法详解
Mar 13 Javascript
Javascript实现字数统计
Jul 03 Javascript
JS实现选中当前菜单后高亮显示的导航条效果
Oct 15 Javascript
Google 地图API资料整理及详细介绍
Aug 06 Javascript
jQuery中$.ajax()方法参数解析
Oct 22 Javascript
原生js实现类似fullpage的单页/全屏滚动
Jan 22 Javascript
AngularJS实现的select二级联动下拉菜单功能示例
Oct 25 Javascript
vue中img src 动态加载本地json的图片路径写法
Apr 25 Javascript
Vue 用Vant实现时间选择器的示例代码
Oct 25 Javascript
基于ant design日期控件使用_仅月份的操作
Oct 27 Javascript
微信小程序利用button控制条件标签的变量问题
Mar 15 #Javascript
JS apply用法总结和使用场景实例分析
Mar 14 #Javascript
javascript事件循环event loop的简单模型解释与应用分析
Mar 14 #Javascript
原生js实现ajax请求和JSONP跨域请求操作示例
Mar 14 #Javascript
js实现的订阅发布者模式简单示例
Mar 14 #Javascript
vue插槽slot的简单理解与用法实例分析
Mar 14 #Javascript
es6中new.target的作用和使用场景简单示例分析
Mar 14 #Javascript
You might like
PHP新手上路(二)
2006/10/09 PHP
php 静态变量的初始化
2009/11/15 PHP
PHP批量删除、清除UTF-8文件BOM头的代码实例
2014/04/14 PHP
php数组键名技巧小结
2015/02/17 PHP
php file_get_contents取文件中数组元素的方法
2017/04/01 PHP
php 一维数组的循环遍历实现代码
2017/04/10 PHP
jquery实现邮箱自动填充提示功能
2015/11/17 Javascript
javacript获取当前屏幕大小
2016/06/04 Javascript
jquery选择器中的空格与大于号&gt;、加号+与波浪号~的区别介绍
2016/06/24 Javascript
jQuery autoComplete插件两种使用方式及动态改变参数值的方法详解
2016/10/24 Javascript
jQuery Easyui datagrid行内实现【添加】、【编辑】、【上移】、【下移】
2016/12/19 Javascript
canvas压缩图片转换成base64格式输出文件流
2017/03/09 Javascript
Vue.js鼠标悬浮更换图片功能
2017/05/17 Javascript
微信小程序顶部可滚动导航效果
2017/10/31 Javascript
js实现动态增加文件域表单功能
2018/10/22 Javascript
详解Vue一个案例引发「内容分发slot」的最全总结
2018/12/02 Javascript
基于JavaScript实现大文件上传后端代码实例
2020/08/18 Javascript
jquery简易手风琴插件的封装
2020/10/13 jQuery
vue使用vant中的checkbox实现全选功能
2020/11/17 Vue.js
react项目从新建到部署的实现示例
2021/02/19 Javascript
在Python中实现贪婪排名算法的教程
2015/04/17 Python
Python实现身份证号码解析
2015/09/01 Python
python线程、进程和协程详解
2016/07/19 Python
Python及PyCharm下载与安装教程
2017/11/18 Python
对Python中的@classmethod用法详解
2018/04/21 Python
利用Pycharm断点调试Python程序的方法
2018/11/29 Python
python实现网页自动签到功能
2019/01/21 Python
Tornado实现多进程/多线程的HTTP服务详解
2019/07/25 Python
python解释器pycharm安装及环境变量配置教程图文详解
2020/02/26 Python
tensorflow2.0的函数签名与图结构(推荐)
2020/04/28 Python
python 实现简单的计算器(gui界面)
2020/11/11 Python
乌克兰电子产品和家用电器购物网站:TOUCH
2019/08/09 全球购物
作文评语集锦大全
2014/04/23 职场文书
国家励志奖学金个人先进事迹材料
2014/05/04 职场文书
法定代表人授权委托书范本
2014/10/07 职场文书
在SQL Server中使用 Try Catch 处理异常的示例详解
2022/07/15 SQL Server