版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、最新html5游戏开发入门教程知识分享html5嬉戏制作彻低指南简介你想用法html5的canvas制作一款嬉戏吗?跟着这个教程,你将立即上道儿。阅读该教程需要起码认识javascript相关学问。你可以先玩这款嬉戏或者挺直阅读文章并且下载嬉戏源码。创建画布在画任何东西之前,我们必需创建一个画布。由于这是彻低指南,并且我们将用到jquery.var canvas_width=480;var canvas_height=320;var canvaselement=$("");var canvas=canvaselement.get(0)。getcontext(
2、"2d");canvaselement.appendto(&39;body&39;);嬉戏循环为了展现给玩家连贯流畅的嬉戏动画,我们要频繁地渲染画布来哄骗玩家的眼睛。var fps=30;setinterval(function() update();draw();, 1000/fps);现在我们先不管update和draw里面的实现,重要的是我们要知道setinterval()会周期性的执行update和drawhello world现在我们已经搭建好了一个循环的架子,我们去修改update和draw办法来写一些文字到屏幕。function
3、 draw() canvas.fillstyle="000" / set color to blackcanvas.filltext("sup bro!", 50, 50);专家提示: 当你略微更改了一些代码的时候就执行一下程序,这样可以更快的找到程序出错地方。静止文字正常的显示出来了。由于我们已经有了循环,所以我们可以很简单地让文字动起来——var textx=50;var texty=50;function update() textx +=1;texty +=1;functio
4、n draw() canvas.fillstyle="000"canvas.filltext("sup bro!", textx, texty);执行程序。假如你一步一步照着上面做下来,可以看到文字移动。但是上一次的文字却还留在屏幕上,由于我们没有擦除画布。现在我们在draw办法中加入擦除办法。function draw() canvas.clearrect(0, 0, canvas_width, canvas_height);canvas.fillstyle="000"canvas.f
5、illtext("sup bro!", textx, texty);现在你可以看到文字在屏幕上移动了,它已经算是一个真正意义上的嬉戏,只不过是个半成品。创建player创建一个包含player全部信息的对象,并且要有draw办法。这里创建了一个容易的对象包含了全部的player信息。var player=color: "00a",x: 220,y: 270,width: 32,height: 32,draw: function() canvas.fillstyle=this.color;canvas.fillrect(th
6、is.x, this.y, this.width, this.height);我们现在用一个纯色的矩形来代表player.当我们把它加入嬉戏当中的时候,我们需要清除画布并且画上player.function draw() canvas.clearrect(0, 0, canvas_width, canvas_height);player.draw();键盘控制用法jquery hotkeysjquery hotkeys plugin在处理键盘行为的时候,可以越发简单的兼容不同的扫瞄器。让开发者不用由于不同扫瞄器之间的keycode andcharcode不同而烦恼,我们这样绑定大事:$(doc
7、ument)。bind("keydown", "left", function() );移动playerfunction update() if (keydown.left) player.x -=2;if (keydown.right) player.x +=2;是不是感觉移动不够快?那么我们来提高它的移动速度。function update() if (keydown.left) player.x -=5;if (keydown.right) player.x +=5;player.x=player.x.clamp(0
8、, canvas_width - player.width);我们可以很简单的添加其他元素,比如炮弹:function update() if (keydown.space) player.shoot();if (keydown.left) player.x -=5;if (keydown.right) player.x +=5;player.x=player.x.clamp(0, canvas_width - player.width);player.shoot=function() console.log("pew pew");/ :) well at
9、least adding the key binding was easy;添加更多嬉戏元素炮弹我们开头真正意义上的添加炮弹,首先,我们需要一个集合来存储它:var playerbullets=;然后,我们需要一个构造器来创建炮弹:function bullet(i) i.active=true;i.xvelocity=0;i.yvelocity=-i.speed;i.width=3;i.height=3;i.color="000"i.inbounds=function() return i.x >=0 && i.x =
10、0 && i.y =0 && i.x =0 && i.y b.x &&a.y b.y;function handlecollisions() playerbullets.foreach(function(bullet) enemies.foreach(function(enemy) if (collides(bullet, enemy) enemy.explode();bullet.active=false;););enemies.foreach(function(e
11、nemy) if (collides(enemy, player) enemy.explode();player.explode(););function update() handlecollisions();function enemy(i) i.explode=function() this.active=false;/ extra credit: add an explosion graphic;return i;player.explode=function() this.active=false;/ extra credit: add an explosion graphic and then end the game;加入声音function enemy(i) i.explode=function() this.active=
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 项目进度与风险控制工具包
- 社区环保责任及贡献承诺函(4篇)
- 基础梁模板安装施工方案
- 可持续发展项目推进承诺书范文7篇
- 企业流程优化与诊断工具
- 市场竞争力提升承诺责任书范文5篇
- 企业职工守则遵守承诺函8篇
- 护理实践中的患者教育
- 公益慈善活动真诚承诺函3篇范文
- 企业内训课程开发流程及模板工具
- 2026年马鞍山师范高等专科学校单招综合素质考试题库附答案详解(完整版)
- 2026河北衡水恒通热力有限责任公司招聘28人笔试参考题库及答案解析
- 2026江苏苏州市昆山市自然资源和规划局招聘编外人员8人笔试备考试题及答案解析
- 2026东北三省三校高三下学期一模考试生物试卷和答案
- 2026年未成年人救助保护中心下属事业单位选聘考试试题(附答案)
- 2026年浙江省公安厅招聘警务辅助人员笔试试题(含答案)
- 2025中国水产科学研究院长江水产研究所招聘笔试历年常考点试题专练附带答案详解
- 2026年广东辅警招聘考试历年真题含答案
- 2025-2030中国陶瓷茶具市场运营风险及发展趋势前景展望研究报告
- (2025年)防洪防汛安全教育测试题含答案
- 名侦探柯南化学知识
评论
0/150
提交评论