正文
html5游戏制作,html5制作游戏界面
小程序:扫一扫查出行
【扫一扫了解最新限行尾号】
复制小程序
【扫一扫了解最新限行尾号】
复制小程序
如何开发一个简单的html5小游戏
创建画布
// Create the canvas
var canvas = document.createElement("canvas");
var ctx = canvas.getContext("2d");
canvas.width = 512;
canvas.height = 480;
document.body.appendChild(canvas);
首先我们需要创建一张画布作为游戏的舞台。这里通过JS代码而不是直接在HTML里写一个canvas元素目的是要说明代码创建也是很方便的。有了画布后就可以获得它的上下文来进行绘图了。然后我们还设置了画布大小,最后将其添加到页面上。
准备图片
// 背景图片
var bgReady = false;
var bgImage = new Image();
bgImage.onload = function () {
bgReady = true;
};
bgImage.src = "images/background.png";
游戏嘛少不了图片的,所以我们先加载一些图片先。简便起见,这里仅创建简单的图片对象,而不是专门写一个类或者Helper来做图片加载。bgReady这个变量用来标识图片是否已经加载完成从而可以放心地使用了,因为如果在图片加载未完成情况下进行绘制是会报错的。
整个游戏中需要用到的三张图片:背景,英雄及怪物我们都用上面的方法来处理。
游戏对象
// 游戏对象
var hero = {
speed: 256, // 每秒移动的像素
x: 0,
y: 0
};
var monster = {
x: 0,
y: 0
};
var monstersCaught = 0;
现在定义一些对象将在后面用到。我们的英雄有一个speed属性用来控制他每秒移动多少像素。怪物游戏过程中不会移动,所以只有坐标属性就够了。monstersCaught则用来存储怪物被捉住的次数。
处理用户的输入
// 处理按键
var keysDown = {};
addEventListener("keydown", function (e) {
keysDown[e.keyCode] = true;
}, false);
addEventListener("keyup", function (e) {
delete keysDown[e.keyCode];
}, false);
现在开始处理用户的输入(对初次接触游戏开发的前端同学来说,这部分开始可能就需要一些脑力了)。在前端开发中,一般是用户触发了点击事件然后才去执行动画或发起异步请求之类的,但这里我们希望游戏的逻辑能够更加紧凑同时又要及时响应输入。所以我们就把用户的输入先保存下来而不是立即响应。
为此,我们用keysDown这个对象来保存用户按下的键值(keyCode),如果按下的键值在这个对象里,那么我们就做相应处理。
开始一轮游戏
// 当用户抓住一只怪物后开始新一轮游戏
var reset = function () {
hero.x = canvas.width / 2;
hero.y = canvas.height / 2;
// 将新的怪物随机放置到界面上
monster.x = 32 + (Math.random() * (canvas.width - 64));
monster.y = 32 + (Math.random() * (canvas.height - 64));
};
reset方法用于开始新一轮和游戏,在这个方法里我们将英雄放回画布中心同时将怪物放到一个随机的地方。
更新对象
// 更新游戏对象的属性
var update = function (modifier) {
if (38 in keysDown) { // 用户按的是↑
hero.y -= hero.speed * modifier;
}
if (40 in keysDown) { // 用户按的是↓
hero.y += hero.speed * modifier;
}
if (37 in keysDown) { // 用户按的是←
hero.x -= hero.speed * modifier;
}
if (39 in keysDown) { // 用户按的是→
hero.x += hero.speed * modifier;
}
// 英雄与怪物碰到了么?
if (
hero.x = (monster.x + 32)
monster.x = (hero.x + 32)
hero.y = (monster.y + 32)
monster.y = (hero.y + 32)
) {
++monstersCaught;
reset();
}
};
这就是游戏中用于更新画面的update函数,会被规律地重复调用。首先它负责检查用户当前按住的是中方向键,然后将英雄往相应方向移动。
有点费脑力的或许是这个传入的modifier 变量。你可以在main 方法里看到它的来源,但这里还是有必要详细解释一下。它是基于1开始且随时间变化的一个因子。例如1秒过去了,它的值就是1,英雄的速度将会乘以1,也就是每秒移动256像素;如果半秒钟则它的值为0.5,英雄的速度就乘以0.5也就是说这半秒内英雄以正常速度一半的速度移动。理论上说因为这个update 方法被调用的非常快且频繁,所以modifier的值会很小,但有了这一因子后,不管我们的代码跑得快慢,都能够保证英雄的移动速度是恒定的。
现在英雄的移动已经是基于用户的输入了,接下来该检查移动过程中所触发的事件了,也就是英雄与怪物相遇。这就是本游戏的胜利点,monstersCaught +1然后重新开始新一轮。
渲染物体
// 画出所有物体
var render = function () {
if (bgReady) {
ctx.drawImage(bgImage, 0, 0);
}
if (heroReady) {
ctx.drawImage(heroImage, hero.x, hero.y);
}
if (monsterReady) {
ctx.drawImage(monsterImage, monster.x, monster.y);
}
// 计分
ctx.fillStyle = "rgb(250, 250, 250)";
ctx.font = "24px Helvetica";
ctx.textAlign = "left";
ctx.textBaseline = "top";
ctx.fillText("Monsterrs caught: " + monstersCaught, 32, 32);
};
之前的工作都是枯燥的,直到你把所有东西画出来之后。首先当然是把背景图画出来。然后如法炮制将英雄和怪物也画出来。这个过程中的顺序是有讲究的,因为后画的物体会覆盖之前的物体。
这之后我们改变了一下Canvas的绘图上下文的样式并调用fillText来绘制文字,也就是记分板那一部分。本游戏没有其他复杂的动画效果和打斗场面,绘制部分大功告成!
主循环函数
// 游戏主函数
var main = function () {
var now = Date.now();
var delta = now - then;
update(delta / 1000);
render();
then = now;
// 立即调用主函数
requestAnimationFrame(main);
};
上面的主函数控制了整个游戏的流程。先是拿到当前的时间用来计算时间差(距离上次主函数被调用时过了多少毫秒)。得到modifier后除以1000(也就是1秒中的毫秒数)再传入update函数。最后调用render 函数并且将本次的时间保存下来。
关于游戏中循环更新画面的讨论可参见「Onslaught! Arena Case Study」。
关于循环的进一步解释
// requestAnimationFrame 的浏览器兼容性处理
var w = window;
requestAnimationFrame = w.requestAnimationFrame || w.webkitRequestAnimationFrame || w.msRequestAnimationFrame || w.mozRequestAnimationFrame;
如果你不是完全理解上面的代码也没关系,我只是觉得拿出来解释一下总是极好的
为了循环地调用main函数,本游戏之前用的是setInterval。但现今已经有了更好的方法那就是requestAnimationFrame。使用新方法就不得不考虑浏览器兼容性。上面的垫片就是出于这样的考虑,它是Paul Irish 博客原版的一个简化版本。
启动游戏!
// 少年,开始游戏吧!
var then = Date.now();
reset();
main();
总算完成了,这是本游戏最后一段代码了。先是设置一个初始的时间变量then用于首先运行main函数使用。然后调用 reset 函数来开始新一轮游戏(如果你还记得的话,这个函数的作用是将英雄放到画面中间同时将怪物放到随机的地方以方便英雄去捉它)。
到此,相信你已经掌握了开发一个简单H5小游戏需要的基本功了。玩玩这个游戏或者下载代码自己研究研究吧 :)
Feel free to repost but keep the link to this page please!
怎么用HTML5制作一款小游戏?
用HTML5制作一款小游戏首先肯定得学会HTML,然后推荐可以考虑先去学习别人的成品游戏,借鉴甚至模仿出来,再去构思自己的游戏就很简单了,我目前就在云创动力华中区学习游戏制作,感觉用HTML5制作游戏真的并不难。
怎么用html5开发游戏?
比如使用html5的画布标签canvas开发一个简单的类似qq游戏你画我猜的游戏:首先你要学会canvas标签的基本用法,画线,画笔大小,画笔,截图保存等,然后结合你的js功底在画布上要画出连续的平滑的线条,然后别人就可以根据画的图,猜词语了,猜中了就给分。然后排名什么的。这就是一个简单的html5游戏了.网上有很多列子的,你可以下一个源码看看
h5小游戏怎么制作?
H5的小游戏其实就是用基于HTML5技术制作的小游戏,常见的HTML5游戏制作,如果不考虑游戏策划,如果你关心的更多的是制作的话,
那么按照制作方式可以分为两种:
1、原生开发
就是自己写HTML5代码(HTML/CSS/Javascript),或者使用第三方引擎,例如国内常见的白鹭、Cocos2d-Js,以及国外的,这个极力推荐,虽然国内用的人不多。
2、第三工具
另外就是通过一些第三方工具来实现游戏的生成与定制。
这里也可以分为两类
A 套模版
有简单的直接套模版,替换素材,游戏音乐音效即可直接完成的,例如我们做的24好玩平台即是其中之一,类似的还有极点互动、微播盈趣、凡科互动等等。
B 工具编辑器
也有一些高级的工具类似于H5互动编辑器MAKA,我知道的有国外的Construct,如果你想学,不想从0开始学代码,这个是一个略微高级的学法。
南京未墨广告有限公司,拥有10技术开发经验,价格低,速度快
如何在微信公众平台上做HTML5游戏
微信公众平台上做HTML5游戏,基本的有三个法子。
1 阅读原文中添加链接。但,如果这样坐引导的文章一定要做好来,不然转换率会很低的。千万要走心一点,不要平白无故的就放在阅读原文,谁看?反正俺是不会看的。
2 图片的形式,在图片中添加入h5的二维码。别人只要长按就可识别二维码跳转到你的h5去,什么图片你随意,例如植入到节日的场景啊、各种动漫图片均可。同样要做好引导,才能引发转化。
3 最直接的形式,你们大部分可能都实现不了,以前公众号有一种功能可以开通,叫直接跳转,也就是只要点击标题就可以直接看到h5,但据我所知现在这个功能申请不了,也就是大多数人都实现不了,原来申请通过的才可以。
另外需要了解HTML5用什么软件制作的,一般的有maka、易企秀、兔展。
选择毋庸赘述,可以都尝试一下,都是较为简单上手的,如果你觉得逼格不够,可以用互动大师。用这些软件如果自己有一定的设计能力做出简易的h5页面基本是没有问题啦。
但如果是很复杂炫技的h5,一些是可以在前面提及的平台的模板处购买,一些是找第三方公司做的。
制作的小贴士:
1 不要用原生字体、真的好hi丑,自己选好看的字体然后做成png格式,然后放进去。
2 如果你有设计能力,最好把图层分开放进去,才能设置每个不同的动态动画。也就是不要做整张图放进去,其实一页可能是好几张图甚至十来张图。
3 如果你自己没有设计能力,那还是在平台上找模板吧。。。然后配合自己的文案。尤其是节日类的h5,模板一搜一大堆,但即便是用模板,也请走走心,不要全特么照搬过来一句话不改。
4 如果不会用ps,去练习用美图秀秀,基础效果基本没多大问题。
5 如果你连png都不会做,艺术字体在线生成器 艺术字转换器 这个神器送给你,大把字体你挑。
6 如何插入报名表 免费制作报名网页 报名表设置后可在后台查看以及下载excel模式。
7 文字尽量少而美,没人愿意看你长篇大论,尤其是h5.
8 文字太多、页面太复杂要注意,很可能造成打开的时候回很卡。
如何快速开发html5游戏?
我不知道题主是什么意思,“如何快速开放html5 游戏 ”?是指简单的换皮 游戏 还是高质量的 游戏 呢?我最近也在学习各种引擎,对于 游戏 开发还是有一些了解的。(虽然作为新人开发者实在找不到合适的工作,难受。)
html5 游戏 开发,也可以说是H5 游戏 ,是时下最火热的 游戏 类型之一。其简单快捷的开放方式深受开发者喜爱。
HTML5是用于取代1999年所制定的 HTML 4.01 和 XHTML 1.0 标准的 HTML 标准版本,现在仍处于发展阶段,但大部分浏览器已经支持某些 HTML5 技术。HTML 5有两大特点:首先,强化了 Web 网页的表现性能。其次,追加了本地数据库等 Web 应用的功能。
对比与HTML4来说,H5的语法更加简单,新增了许多标签,拥有全新的表单,更加方便初学者上手。
对于题主所说的如何快速开发H5 游戏 ,如果是为了让阅历上多添加几个项目,可以选择去网络上搜索相应的教程学习,根据案例来编写,最后修改一部分参数和图片,如此重复修改,可以制作出简单的换皮 游戏 。
但是要制作剧情,操作,玩法等各种方面新颖的 游戏 ,还是需要慢慢的沉淀下来才行。