jQuery贪吃蛇--jQuery学习
我用JQuery有一段时间了,越来越体会到其强大之处,于是自己尝试写了一个贪吃蛇小游戏,拿来与网友分享一下。
1. 了解JQuery.Timers
除用到了jQuery1.5.1之外,我还用到了jQuery.timers-1.2,作为定时器。它比Js的setInterval函数提供了更友好的接口。
JQuery Timers提供了三个函数:
1. everyTime(时间间隔, [定时器名称], 函式名称, [次数限制], [等待函式程序完成])
2. oneTime(时间间隔, [定时器名称], 呼叫的函式)
3. stopTime ([定时器名称], [函式名称])
示例:
$('body').everyTime(300, 'MainTimer', function () {
//do something every 300ms.
}
把定时器放到body上,确保定时器不会随被移除。
这样就能定时的更新贪吃蛇的位置,并且做一些逻辑判断。
2. 键盘响应
jquery提供了一系列的键盘事件函数:
1、keydown()
keydown事件会在键盘按下时触发.
2、keyup()
keyup事件会在按键释放时触发,也就是你按下键盘起来后的事件
3、keypress()
keypress事件会在敲击按键时触发,我们可以理解为按下并抬起同一个按键
可以通过回调函数的参数event.keyCode来获取
$(document).keydown(function(event){
if(event.keyCode == 37){//左方向键
//do somethings;
}else if (event.keyCode == 39){//右方向键
//do somethings;
}
});
所有的键盘代码表,可参考这篇博文
3. 创建、移动蛇身
蛇身是一系列的img标记,使用一个小的方形图片,为了能固定位置,需要将样式设置为:
.game{
position: fixed;
/* 为了兼容IE7 */
_position: absolute;
}
一个蛇身节点就是:
<img id="node1" class="game" src="Images/node.ico" />
在定时器回调中,当要更新蛇身位置时,从后往前遍历节点,逐一设置为上一个节点的位置,即实现了向前移动:
var i;
for (i = snakeLength - 1; i > 0; i--) {
$("#node" + i).css("left", $("#node" + (i - 1)).css("left"));
$("#node" + i).css("top", $("#node" + (i - 1)).css("top"));
}
其他的大家应该就明白了,主要实现食物、越界判断、撞自己判断、吃食物判断、变长、变快、记分等。
上代码:
<html>
<head>
<title>Snaker</title>
<link rel="stylesheet" href="style/style.css" type="text/css" />
<script type="text/javascript" src="js/jquery-1.5.1.min.js"></script>
<script type="text/javascript" src="js/jquery.timers-1.2.js"></script>
<script type="text/javascript">
var x = 0;
var y = 0;
var step = 20;
var dir = "right";
var initNodeCount = 4;
var snakeLength;
//生成新节点
function getNewNode(id) {
return $('<img id="' + id + '" class="game" src="Images/node.ico" />');
};
//判断是否位置相同,即碰撞测试
function isSamePosition(id1, id2) {
//alert(id1 + "_" + id2);
return ($('#' + id1).css("left") == $('#' + id2).css("left") && $("#" + id1).css("top") == $('#' + id2).css("top"));
};
//初始化节点
function initPositions() {
var i;
for (i = initNodeCount - 1; i >= 0; i--) {
getNewNode('node' + i).appendTo("body");
$("#node" + i).css("left", 100 - step * i);
$("#node" + i).css("top", 0);
}
snakeLength = initNodeCount;
};
//更新节点位置
function updatePositions() {
var i;
for (i = snakeLength - 1; i > 0; i--) {
$("#node" + i).css("left", $("#node" + (i - 1)).css("left"));
$("#node" + i).css("top", $("#node" + (i - 1)).css("top"));
}
$("#node0").css("top", y);
$("#node0").css("left", x);
if (x < 0 || x > window.innerWidth || y < 0 || y > window.innerHeight) {
alert("你一头撞到屏幕边缘上了!有木有!!!");
location.reload();
}
for (i = snakeLength - 1; i > 0; i--) {
if (isSamePosition("node" + i, "node0")) {
alert("你一口咬到自己屁屁上了!有木有!!!");
location.reload();
}
}
};
//吃掉食物
function eatFood() {
if (isSamePosition("node0", "food")) {
getNewNode('node' + snakeLength).appendTo('body');
$(('#node' + snakeLength)).css("left", -100);
snakeLength = snakeLength + 1;
createFood(false);
};
};
//创建新食物
function createFood(isNew) {
var fx = Math.random();
fx = Math.round(fx * 20) * 20;
var fy = Math.random();
fy = Math.round(fy * 20) * 20;
if (isNew) {
$('<img id="food" class="game" src="Images/food.ico" />').appendTo('body');
}
$('#food').css("left", fx);
$('#food').css("top", fy);
};
//启动定时器
function startTimer() {
$('body').everyTime(300, 'MainTimer', function () {
//alert(dir);
if (dir == "right") {
x = x + step;
} else if (dir == "left") {
x = x - step;
} else if (dir == "down") {
y = y + step;
} else if (dir == "up") {
y = y - step;
}
updatePositions();
eatFood();
});
};
$(function () {
initPositions();
createFood(true);
//暂停、继续
$('#startStop').toggle(
function () {
$('body').stopTime('MainTimer');
},
function () {
startTimer();
}
);
//定时器
startTimer();
//键盘响应
$(document).keydown(function (event) {
event = event || window.event;
if (event.keyCode == 38 && dir != "down") {
dir = "up";
} else if (event.keyCode == 37 && dir != "right") {
dir = "left";
} else if (event.keyCode == 39 && dir != "left") {
dir = "right";
} else if (event.keyCode == 40 && dir != "up") {
dir = "down";
};
});
}); </script>
</head>
<body>
<button type="button" id="startStop">
开始/停止</button>
</body>
</html>
初学jQuery,经验尚浅,有很多做的不好的地方,希望大家批评指正。
jQuery贪吃蛇--jQuery学习的更多相关文章
- WebSocket贪吃蛇例子学习
在Tomcat7.0.64下的examples文件夹内,有多人贪吃蛇的例子. Multiplayer snake 这是一个多人在线小游戏,客户端通过操作上下左右键指挥自己的蛇,如果碰到别的蛇就死掉.还 ...
- QT下的贪吃蛇
QT写的贪吃蛇,学习于https://www.devbean.net/2012/12/qt-study-road-2-snake-1/ 建议就学习一下开发思想,开发游戏还是用专门的编译器. 多加了墙, ...
- Jquery练手之-贪吃蛇
记得以前刚出来工作的时候,什么都不懂.老板让用Jquery写一个功能,我不会写,然后跟老板说,我就是个.net程序员,为什么要写Jquery...后面我们老大给我写了!现在我才知道net程序员要会多少 ...
- 小菜学习Winform(一)贪吃蛇2
前言 上一篇<小菜学习Winform(一)贪吃蛇>中实现了简单版的贪吃蛇,在文章末也提到需要优化的地方,比如使用oo.得分模式.速度加快模式和减少界面重绘.因为是优化篇,实现方式上一篇有, ...
- 小菜学习Winform(一)贪吃蛇
前言 说到贪吃蛇,大家可能小时候都玩过,小菜最近在整理Winfrom的学习系列,那我觉得有兴趣才会有学习,就从这个小游戏讲起吧. 实现 其实我刚开始学习编程的时候,感觉写个贪吃蛇的程序会很难,因为涉及 ...
- 从零开始学习jQuery (四) 使用jQuery操作元素的属性与样式
本系列文章导航 从零开始学习jQuery (四) 使用jQuery操作元素的属性与样式 一.摘要 本篇文章讲解如何使用jQuery获取和操作元素的属性和CSS样式. 其中DOM属性和元素属性的区分值得 ...
- 从零开始学习jQuery (三) 管理jQuery包装集
本系列文章导航 从零开始学习jQuery (三) 管理jQuery包装集 一.摘要 在使用jQuery选择器获取到jQuery包装集后, 我们需要对其进行操作. 本章首先讲解如何动态的创建元素, 接着 ...
- 以小时候玩的贪吃蛇为例,对于Java图像界面的学习感悟
简介 正文 01.JFrame是啥? 02.JPanel 03. KeyListener 04.Runnable 05.游戏Running 06.游戏初始类编写 07.main 简介: 一直以来用代码 ...
- jQuery学习-什么是jquery? Js与jquery之间的关系 Jquery选择器
1. 什么是jQuery以及学习的意义等 jQuery是一个js库 JS库是什么? 把常用的方法,进行封装,封装到一个单独的js文件当中,要用的时候直接调用. 学习jQuery主要学什么? 学习jQ ...
随机推荐
- loadrunner监控linux服务器
参考http://www.cnblogs.com/yangxia-test/archive/2012/11/27/2790771.html http://www.cnblogs.com/candle8 ...
- MATLAB不运行也不报错
今天本来挺激动找到能运行的好几个程序 MATLAB忙到busy也是停不下来 本来不以为然 结果呢 吃了个水果 一杯水都喝下去了 还没结果(⊙o⊙) 这时候解决办法只有一个 Ctrl+c
- Microsoft Visual Studio 2010 已安装的模板 没有 “ADO.NET实体数据模型”
2010 sp1才包括entity framework. 装一个补丁即可 地址为:http://www.microsoft.com/zh-CN/download/details.aspx?id=236 ...
- Javac 手动编译时,出现乱码或编码格式问题
使用Javac进行手动编译时,出现乱码或编码格式问题,原因如下:现象:编译时出现乱码或编译错误 即使改成UTF-8仍然会出错 原因如下:某些编辑器会往utf8文件中添加utf8标记(editplus称 ...
- Boost 安装
1.下载boost Windows版,如:boost_1_55_0: 2.运行boostrap.bat,会生成bjam.exe: 3.运行bjam.exe(时间会比较长),会生成一个stage目录里面 ...
- Android ExpandableListView
ExpandableListView 结合SimpleExpandableListAdapter用法 最终实现效果: activity_main.xml <?xml version=" ...
- C#的winform编程入门简单介绍
C#中事件.事件委托.事件的订阅 例子: using System.Timers; Timer t1 = new Timer(); t1.Tick += new EventHandler(XX); p ...
- Ubuntu之root权限的获取
方案一: Ubuntu的root密码在没有设置之前是随机的,即在每一次开机的时候他的密码都不同,但是由于在安装Ubuntu的时候需要建立一个账户,而这个招呼又属于admin组,因此它可以对root进行 ...
- 团队spring会议1
一.我们在近期进行了第一次计划会议,会议过程大致如下: 1.确定所做项目的方向: 2.将调查问卷的结果进行统计,做了需求分析,大致了解了用户的想法: 3.确定了团队计划backlog: 4.将任务进行 ...
- STC12C5A60S2笔记2(存储)
STC12C5A60S2单片机分为4个物理上独立的存储区域: 1. 程序flash存储器(60KB) 程序Flash存储器用以存储用户程序及数据.单片机复位后默认从0000H单元开始执行指令. 1) ...