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 相关文章推荐
html数组字符串拼接的最快方法
Sep 16 Javascript
jQuery页面滚动浮动层智能定位实例代码
Aug 23 Javascript
jQuery数据缓存功能的实现思路及简单模拟
May 27 Javascript
JS日期和时间选择控件升级版(自写)
Aug 02 Javascript
js(JavaScript)实现TAB标签切换效果的简单实例
Feb 26 Javascript
原生js编写焦点图效果
Dec 08 Javascript
React中ES5与ES6写法的区别总结
Apr 21 Javascript
Vue+axios实现统一接口管理的方法
Jul 23 Javascript
JS实现的图片选择顺序切换和循环切换功能示例【测试可用】
Dec 28 Javascript
mpvue微信小程序开发之实现一个弹幕评论
Nov 24 Javascript
JS正则表达式验证密码强度
Mar 18 Javascript
谈谈JavaScript中的垃圾回收机制
Sep 17 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 八种基本的数据类型小结
2011/06/01 PHP
PHP中用hash实现的数组
2011/07/17 PHP
解析php中curl_multi的应用
2013/07/17 PHP
php设置静态内容缓存时间的方法
2014/12/01 PHP
CI框架源码解读之利用Hook.php文件完成功能扩展的方法
2016/05/18 PHP
使用swoole 定时器变更超时未支付订单状态的解决方案
2019/07/24 PHP
jquery ajax 检测用户注册时用户名是否存在
2009/11/03 Javascript
JavaScript 字符串处理函数使用小结
2010/12/02 Javascript
关于jquery ajax 调用带参数的webservice返回XML数据一个小细节
2012/07/31 Javascript
IE8提示Invalid procedure call or argument 异常的解决方法
2012/09/30 Javascript
js浏览器本地存储store.js介绍及应用
2014/05/13 Javascript
动态加载jQuery的两种方法实例分析
2015/07/17 Javascript
基于JS组件实现拖动滑块验证功能(代码分享)
2016/11/18 Javascript
Node.js获取前端ajax提交的request信息
2017/02/20 Javascript
解决v-for中使用v-if或者v-bind:class失效的问题
2018/09/25 Javascript
详解如何在vue项目中使用eslint+prettier格式化代码
2018/11/10 Javascript
checkbox在vue中的用法小结
2018/11/13 Javascript
基于JavaScript实现每日签到打卡轨迹功能
2018/11/29 Javascript
一看就会的vuex实现登录验证(附案例)
2020/01/09 Javascript
Javascript Symbol原理及使用方法解析
2020/10/22 Javascript
更改Python命令行交互提示符的方法
2015/01/14 Python
python在windows下实现ping操作并接收返回信息的方法
2015/03/20 Python
python读取各种文件数据方法解析
2018/12/29 Python
Python Numpy,mask图像的生成详解
2020/02/19 Python
Python预测2020高考分数和录取情况
2020/07/08 Python
DERMAdoctor官网:美国著名皮肤护理品牌
2019/07/06 全球购物
德国家用电器购物网站:Premiumshop24
2019/08/22 全球购物
服装公司总经理岗位职责
2013/11/30 职场文书
高中毕业自我鉴定
2013/12/16 职场文书
如何写自我鉴定
2014/03/19 职场文书
农民工工资承诺书范文
2014/03/31 职场文书
消防验收申请报告
2015/05/15 职场文书
2015年度高中教师工作总结
2015/05/26 职场文书
音乐之声观后感
2015/06/04 职场文书
Prometheus 监控MySQL使用grafana展示
2021/08/30 MySQL
ORACLE中dbms_output.put_line输出问题的解决过程
2022/06/28 Oracle