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 相关文章推荐
jquery 仿QQ校友的DIV模拟窗口效果源码
Mar 24 Javascript
javascript放大镜效果的简单实现
Dec 09 Javascript
用Node.js通过sitemap.xml批量抓取美女图片
May 28 Javascript
js实现表单Radio切换效果的方法
Aug 17 Javascript
原生js三级联动的简单实现代码
Jun 07 Javascript
Vue.js 父子组件通讯开发实例
Sep 06 Javascript
微信小程序 新建登录页并实现tabBar隐藏
Jun 13 Javascript
Vue.js常用指令的使用小结
Jun 23 Javascript
BootStrap给table表格的每一行添加一个按钮事件
Sep 07 Javascript
在vue项目中集成graphql(vue-ApolloClient)
Sep 08 Javascript
小程序getLocation需要在app.json中声明permission字段
Apr 04 Javascript
javascript设计模式 ? 单例模式原理与应用实例分析
Apr 09 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
动态网站web开发 PHP、ASP还是ASP.NET
2006/10/09 PHP
PHP中去掉字符串首尾空格的方法
2012/05/19 PHP
PHP获取文件夹大小函数用法实例
2015/07/01 PHP
PHP实现上传图片到 zimg 服务器
2016/10/19 PHP
php cli模式下获取参数的方法
2017/05/05 PHP
阿里云Win2016安装Apache和PHP环境图文教程
2018/03/11 PHP
PHP根据key删除数组中指定的元素
2019/02/28 PHP
JavaScript 编程引入命名空间的方法与代码
2007/08/13 Javascript
js cookies实现简单统计访问次数
2009/11/24 Javascript
HTML Dom与Css控制方法
2010/10/25 Javascript
jQuery实现长文字部分显示代码
2013/05/13 Javascript
JavaScript调试技巧之console.log()详解
2014/03/19 Javascript
详细分析JavaScript变量类型
2015/07/08 Javascript
微信小程序 缓存(本地缓存、异步缓存、同步缓存)详解
2017/01/17 Javascript
Vue header组件开发详解
2018/01/26 Javascript
在iFrame子页面里实现模态框的方法
2018/08/17 Javascript
Node.js npm命令运行node.js脚本的方法
2018/10/10 Javascript
在layui中对table中的数据进行判断(0、1)转换为提示信息的方法
2019/09/28 Javascript
15分钟学会vue项目改造成SSR(小白教程)
2019/12/17 Javascript
解决小程序无法触发SESSION问题
2020/02/03 Javascript
python 读写文件,按行修改文件的方法
2018/07/12 Python
python 接收处理外带的参数方法
2018/12/03 Python
python获取txt文件词向量过程详解
2019/07/05 Python
基于h5py的使用及数据封装代码
2019/12/26 Python
使用遗传算法求二元函数的最小值
2020/02/11 Python
Python pip配置国内源的方法
2020/02/14 Python
python数据预处理 :样本分布不均的解决(过采样和欠采样)
2020/02/29 Python
CSS3 优势以及网页设计师如何使用CSS3技术
2009/07/29 HTML / CSS
全方位了解CSS3的Regions扩展
2015/08/07 HTML / CSS
同步和异步有何异同,在什么情况下分别使用他们?举例说明
2014/02/27 面试题
个人教师自我评价范文
2013/12/02 职场文书
超市端午节活动方案
2014/01/23 职场文书
进口业务员岗位职责
2014/04/06 职场文书
《一个小村庄的故事》教学反思
2014/04/13 职场文书
导游词之杭州西湖
2019/09/19 职场文书
python 解决微分方程的操作(数值解法)
2021/05/26 Python