Three.js 再探 - 写一个微信跳一跳极简版游戏


Posted in Javascript onJanuary 04, 2018

那么这个游戏到底是简单到什么程度,差不多就是到下面这个程度吧

源码地址:  github.com/luosijie/th…

Three.js 再探 - 写一个微信跳一跳极简版游戏

Three.js 再探 - 写一个微信跳一跳极简版游戏
Three.js 再探 - 写一个微信跳一跳极简版游戏

由于是第一次尝试写游戏, 也不知道套路对不对, 大家看着玩就好, 不要太认真, 不推荐在手机上预览, 坑还没有填好

下面是实现过程

游戏分析

首先分析一下一个这样的游戏需要什么元素

  • Three.js必备元素: 场景,灯光,摄像机
  • 一块又一块的方块
  • 会跳的那个 ,或者叫游戏者
  • 以上

游戏过程

  • 初始一个场景, 场景中有一个 会跳的那个 和 2个方块
  • 鼠标按下储存 能量值
  • 鼠标放开, 会跳的那个 根据 能量值 和 第2个方块的方向 跳出去
  • 会跳的那个 落到方块的上平面时, 根据 位置 判断这一跳是成功还是失败
  • 成功后进入下一步,失败就根据 位置 执行不同的摔倒方式

关于游戏的碰撞, 我们要考虑这几种情况

1.掉落在两个方块中央

Three.js 再探 - 写一个微信跳一跳极简版游戏  

2. 掉落在起跳方块左边上沿

Three.js 再探 - 写一个微信跳一跳极简版游戏  

3. 掉落在左边下一个方块下沿

Three.js 再探 - 写一个微信跳一跳极简版游戏  

4. 掉落在左边下一个方块上沿

Three.js 再探 - 写一个微信跳一跳极简版游戏 

5. 掉落在起跳方块右边上沿

Three.js 再探 - 写一个微信跳一跳极简版游戏 

6. 掉落在右边下一个方块下沿

Three.js 再探 - 写一个微信跳一跳极简版游戏 

7. 掉落在右边下一个方块上沿

Three.js 再探 - 写一个微信跳一跳极简版游戏 

代码

感兴趣的麻烦移步github

主体结构

var Game = function () {
 ...
}
Game.prototype = {
 init: // 初始化
 restart: // 重新开始
 addSuccessFn: // 成功进入下一步,执行外部函数, 用于更新分数
 addFailedFn: // 游戏失败, 执行外部函数, 用于显示失败弹窗
 _createJumper: // 创建 会跳的那个
 _createCube: // 创建方块
 _setLight: // Three.js设置光照
 _setCamera: // Three.js设置相机
 _setRenderer: // Three.js设置渲染器
 _render: // Three.js 执行渲染
 _createHelpers: // Three.js场景辅助工具
 _checkUserAgent: // 检测是否是移动端
 _handleWindowResize: // 窗口缩放绑定函数
 _handleMousedown: // 鼠标按下绑定函数
 _handleMouseup: // 鼠标松开绑定函数
 _fallingRotate: // 会跳的那个 摔落动画
 _falling: // 会跳的那个 摔落
 _checkInCube: // 判断落点位置
 _updateCameraPos: // 更新相机坐标参数
 _updateCamera: // 更新相机
 _setSize: // 设置画布尺寸
}

调用

var game = new Game(success,failed)
game.init()
game.addSuccessFn(success)
game.addFailedFn(failed)
...
// 游戏重新开始,执行函数
function restart () {
 ...
}
// 游戏失败执行函数
function failed(){
 ...
}
// 游戏成功,更新分数
function success (score) {
 ...
}

总结

以上所述是小编给大家介绍的Three.js 再探 - 写一个微信跳一跳极简版游戏,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
slice函数的用法 之不错的应用
Dec 29 Javascript
javascript读取RSS数据
Jan 20 Javascript
js小技巧--自动隐藏红叉叉
Aug 13 Javascript
原始XMLHttpRequest方法详情回顾
Nov 28 Javascript
node.js应用后台守护进程管理器Forever安装和使用实例
Jun 01 Javascript
jQuery实现延迟跳转的方法
Jun 05 Javascript
jQuery实现的进度条效果
Jul 15 Javascript
js判断手机系统是android还是ios
Mar 07 Javascript
微信公众号菜单配置微信小程序实例详解
Mar 31 Javascript
BootStrap Validator 根据条件在JS中添加或移除校验操作
Oct 12 Javascript
详解React中传入组件的props改变时更新组件的几种实现方法
Sep 13 Javascript
关于node-bindings无法在Electron中使用的解决办法
Dec 18 Javascript
JS实现带导航城市列表以及输入搜索功能
Jan 04 #Javascript
微信小程序实现的贪吃蛇游戏【附源码下载】
Jan 03 #Javascript
详解Angular2学习笔记之Html属性绑定
Jan 03 #Javascript
Angular2学习笔记之数据绑定的示例代码
Jan 03 #Javascript
vue、react等单页面项目应该这样子部署到服务器
Jan 03 #Javascript
AngularJS实现的2048小游戏功能【附源码下载】
Jan 03 #Javascript
浅谈node模块与npm包管理工具
Jan 03 #Javascript
You might like
PHP 上传文件的方法(类)
2009/07/30 PHP
基于PHP文件操作的详细诠释
2013/06/21 PHP
PHP数组操作类实例
2015/07/11 PHP
PHP+swoole实现简单多人在线聊天群发
2016/01/19 PHP
WordPress中的shortcode短代码功能使用详解
2016/05/17 PHP
ThinkPHP3.2.3实现分页的方法详解
2016/06/03 PHP
PHP按一定比例压缩图片的方法
2018/10/12 PHP
jquery重复提交请求的原因浅析
2014/05/23 Javascript
jquery实现简单实用的打分程序实例
2015/07/23 Javascript
解决jQuery使用JSONP时产生的错误
2015/12/02 Javascript
Js的Array数组对象详解
2016/02/22 Javascript
轻松实现js弹框显示选项
2016/09/13 Javascript
layui前段框架日期控件使用方法详解
2017/05/19 Javascript
JavaScript观察者模式原理与用法实例详解
2020/03/10 Javascript
nodeJS与MySQL实现分页数据以及倒序数据
2020/06/05 NodeJs
Python ORM框架SQLAlchemy学习笔记之数据查询实例
2014/06/10 Python
python对指定目录下文件进行批量重命名的方法
2015/04/18 Python
python django 增删改查操作 数据库Mysql
2017/07/27 Python
python基础学习之如何对元组各个元素进行命名详解
2018/07/12 Python
Python微医挂号网医生数据抓取
2019/01/24 Python
python绘制漏斗图步骤详解
2019/03/04 Python
windows上安装python3教程以及环境变量配置详解
2019/07/18 Python
Python线程threading模块用法详解
2020/02/26 Python
python GUI库图形界面开发之PyQt5打开保存对话框QFileDialog详细使用方法与实例
2020/02/27 Python
利用python实现平稳时间序列的建模方式
2020/06/03 Python
美国杂志订阅折扣与优惠网站:Magazines.com
2016/08/31 全球购物
安德玛比利时官网:Under Armour比利时
2019/08/28 全球购物
软件测试面试题
2014/01/05 面试题
房产销售经理职责
2013/12/20 职场文书
课外活动总结范文
2014/07/09 职场文书
银行党员批评与自我批评
2014/10/15 职场文书
运动与健康自我评价
2015/03/09 职场文书
员工手册董事长致辞
2015/07/29 职场文书
2019学校请假条格式及范文
2019/06/25 职场文书
七年级话题作文之执着
2019/11/19 职场文书
使用CSS实现小三角边框原理解析
2021/11/07 HTML / CSS