Html5最简单的游戏Demo——Canvas绘图的弹弹球
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>弹弹球</title>
<script type="text/ecmascript">
var drawWorker;//重绘的事件
var result = 0;//整形,游戏坚持的时间,秒
var record = 0;//整形,游戏的记录
var timeWorker;//计时的事件,每秒一次 var pointRadius = 10;//球的半径
var pointX = 20;//球的圆心x坐标
var pointY = 20;//球的圆心y坐标 var speedX = 10;//球向右移动的速度
var speedY = 5;//球向下移动的速度 var panelX = 0;//小方块的最左边的x坐标
var panelY = 280;//小方块的最上端的y坐标
var panelHeight = 20;
var panelWidth = 100; var wholeWidth = 500;
var wholeHeight = 300; var canvas;
var ctx; function Init() {
canvas=document.getElementById("myCanvas");
ctx = canvas.getContext("2d"); ctx.strokeRect(0, 0, wholeWidth, wholeHeight);
} function DrawBall() {
var ctx = document.getElementById("myCanvas").getContext("2d"); ctx.clearRect(1, 1, wholeWidth-2, wholeHeight-2); //清理矩形范围 pointX = pointX + speedX;//新的圆心x坐标
pointY = pointY + speedY;//新的圆心y坐标 ctx.beginPath(); //弹弹球
ctx.arc(pointX, pointY, pointRadius, 0, Math.PI * 2);
ctx.closePath();
ctx.fill(); ctx.fillRect(panelX, panelY, panelWidth, panelHeight); //小方块
} function MoveBall() {
if (pointY >= wholeHeight - panelHeight) {
if (pointX < panelX || pointX > panelX + panelWidth) { EndGame(); //越过小方块,游戏结束
return;
}
else {
speedX = speedX > 0 ? speedX + 5 : speedX - 5; //碰到小方块,小球加速
speedY = speedY > 0 ? speedY + 5 : speedY - 5;
}
} if (pointX >= wholeWidth || pointX<=0) { //接触到边界,对应的方向转向
speedX = speedX - 2 * speedX;
} if (pointY >= wholeHeight - panelHeight || pointY <= 0) {
speedY = speedY - 2 * speedY;
} DrawBall(); } function MovePanel(event) {
panelX = event.pageX - (panelWidth / 2);
} function AddResult() {
result = result + 1;
var resultLabel = document.getElementById("currentLabel");
resultLabel.textContent = result;
} function Play() {
pointX =Math.floor( Math.random() * 20) + 10;//球的圆心x坐标
pointY = Math.floor(Math.random() * 20) + 10;//球的圆心y坐标 speedX = 20;//球向右移动的速度
speedY = 10;//球向下移动的速度 result = 0; drawWorker = setInterval(MoveBall, 100); //每100毫秒就重绘小球跟小方块位置
timeWorker = setInterval(AddResult, 1000); //每秒更新结果 canvas.addEventListener("mousemove", MovePanel, false); //开始玩,需要将所有相关参数都再初始化 } function EndGame() { //游戏结束
clearInterval(timeWorker); //停止两个定时任务
clearInterval(drawWorker); canvas.removeEventListener("mousemove", MovePanel, false); //移除鼠标移动事件的处理 if (result > record) {
record = result;
var recordLabel = document.getElementById("recordLabel");
recordLabel.textContent = result;
}
result = 0;
}
</script>
</head>
<body onload="Init();">
<canvas id="myCanvas" width="500" height="300">your broswer does not support canvas.</canvas>
<br />
<input type="button" value="play" onclick="Play();" />
<br />
<label>本次结果:</label>
<label id="currentLabel">0</label>
<br />
<label>最高纪录:</label>
<label id="recordLabel">0</label>
</body>
</html>
上文代码实现了一个很基本的弹弹球游戏。
按下Play按钮,在Canvas范围内左右移动鼠标,滑块会随之移动。如果成功接住落下的小球则小球加速并且变向。当小球落在底框的时候游戏结束。游戏将会记录坚持的时间。
Html5最简单的游戏Demo——Canvas绘图的弹弹球的更多相关文章
- Html5最简单的游戏Demo——Canvas绘图的骰子
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <t ...
- Html5 学习系列(五)Canvas绘图API快速入门(1)
引言:Canvas绘图API快速入门 在接触HTML5的初学者包括我都在很多地方见到非常炫的一些页面,甚至好多学习HTML5的开发者都是冲着Web端的页游去的,那么HTML5那么绚丽的页面效果以及游戏 ...
- HTML5 学习总结(四)——canvas绘图、WebGL、SVG
一.Canvas canvas是HTML5中新增一个HTML5标签与操作canvas的javascript API,它可以实现在网页中完成动态的2D与3D图像技术.<canvas> 标记和 ...
- HTML5 学习笔记(四)——canvas绘图、WebGL、SVG
一.Canvas canvas是HTML5中新增一个HTML5标签与操作canvas的javascript API,它可以实现在网页中完成动态的2D与3D图像技术.<canvas> 标记和 ...
- Html5 学习系列(五)Canvas绘图API快速入门(2)
Canvas绘图API Demos 上一篇文章中,笔者已经给大家演示了怎么快速用Canvas的API绘制一个矩形出来.接下里我会在本文中给各位介绍Canvas的其他API:绘制线条.绘制椭圆.绘制图片 ...
- HTML5 十大新特性(四)——Canvas绘图
H5引入了canvas标签,默认是一个300*150的inline-block.canvas的宽高只能用它自身的width和height属性来指定,而不能使用css样式中的width.height. ...
- 【HTML5】炫丽的时钟效果Canvas绘图与动画基础练习
源自慕课网 效果如下: 全部代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" " ...
- HTML5学习总结——canvas绘制象棋(canvas绘图)
一.HTML5学习总结——canvas绘制象棋 1.第一次:canvas绘制象棋(笨方法)示例代码: <!DOCTYPE html> <html> <head> & ...
- 怎样用HTML5 Canvas制作一个简单的游戏
原文连接: How To Make A Simple HTML5 Canvas Game 自从我制作了一些HTML5游戏(例如Crypt Run)后,我收到了很多建议,要求我写一篇关于怎样利用HTML ...
随机推荐
- 数学对象Math ceil()、floor()、round()方法
Math.ceil() 功能:对一个数进行上取整. 语法:Math.ceil(x) 参数: x:一个数值. 返回值:返回大于或等于x,并且与之最接近的整数. 注:如果x是正数,则把小数“入”: ...
- C# 最简单的递归
public void AddTree(int ParentID, TreeNode pNode) { TreeNode tn1 = new TreeNode(); DataView dvTree = ...
- Windows phone 8 学习笔记(5) 图块与通知(转)
基于metro风格的Windows phone 8 应用提到了图块的概念,它就是指启动菜单中的快速启动图标.一般一个应用必须有一个默认图块,还可以有若干个次要图块.另外,通知与图块的关系比较密切,我们 ...
- iOS 8.3 JB ready
Hi, I've been waiting for a very very long time..Now iOS 8.3 is ready. http://www.taig.com/ You guys ...
- Android IOS WebRTC 音视频开发总结(三九)-- win10升级为何要p2p
本文主要介绍webrtc p2p的应用场景,文章来自博客园RTC.Blacker,支持原创,转载请说明出处. P2P最简单的解释就是两个客户端之间直接进行数据交互,不经过服务端转发. 最早接触P2P是 ...
- 关于ADO.NET的基本介绍
关于ADO.NET ADO.NET是微软提供的一种数据库访问方式.他使得.NET程序员对于不同的数据库都能采用相同的访问方式. Connection 连接 Connection是一个数据库连接类,他负 ...
- CentOS 5.X安装LAMP最高版本环境
#------------CentOS 5.X安装LAMP最高版本环境------------------#! /bin/sh #安装Apacheyum install httpd -y#1.关闭se ...
- PHP mysql 事务处理实例
事务是必须满足4个条件(ACID):原子性(Autmic).一致性(Consistency).隔离性(Isolation).持久性(Durability) 原子性(Autmic):事务在执行性,要做到 ...
- LtUpload上传组件
<?php/** * The Upload class * @author Alex Lee <iuyes@qq.com> * @license http://opensource. ...
- Oracle中建表空间以及用户
第一步:创建临时表空间 --创建临时表空间-- CREATE TEMPORARY TABLESPACE JSYCCS_TEMP ---'JSYCCS_TEMP'临时表空间名 TEMPFILE 'E ...