Unity项目 - 捡苹果 Apple Picker
项目展示
Github项目地址:Apple Picker
涉及知识
- 正投视图
- 3D场景内树与苹果的图层
- 记录最高分到本地
准备工作
模型制作:
- 基本模型创建
- 树叶:sphere 拉伸为椭圆形,绿色材质球
- 树干:cylinde 修改为合适尺寸,棕色材质球
- 苹果:sphere 附加深红金属光泽球
- 篮筐:cube 修改为合适尺寸,黄色材质球
- 位置、层级关系
- 调整树叶树干的位置搭配,呈现简单树木形态
- 另设的空物体
AppleTree
包含着树叶和树干
- 标签、图层
- 新建标签Apple标记苹果物体
- 新建图层 AppleTree、Apple和Basket,后在Edit->Project Setting->Physics内取消Apple与AppleTree图层的碰撞。后修正对应物体图层
- 相机及预制体
- 调整主摄像机为正投影(Orthographic),移动到合适位置
- 创建苹果的预制体
游戏逻辑
- 苹果树:
- 每帧都以一定的速度移动,当碰到左右边界则转向,且在左右移动过程中有概率改变运动方向
- 每一定时间间隔落下一个苹果
- 苹果:
- 从树叶位置实例化并落下(本例采用rigidbody重力)
- 与篮筐产生碰撞即被销毁
- 若篮筐未与其碰撞,则当苹果下落到一定距离就自动销毁
- 篮筐:
- 开局有3个篮筐,且均实例化出来
- 篮筐跟随鼠标限制在界面的x轴方向移动
- 篮筐用于接住苹果,与苹果碰撞后销毁苹果
- 当漏接苹果(也就是当苹果下降到自行销毁的底线时),罗筐数减少(相当于玩家的生命值)
- 机制:
- 开局,苹果树左右移动,生成苹果下落
- 玩家操作鼠标使篮筐左右移动
- 接到苹果时得分增加,超过历史分值就刷新记录
- 当没接到苹果时,篮筐数减少(生命值减少),且场景内还在下落中的苹果消失
- 当3个篮筐都没了,游戏结束,几秒后自动重新开局
代码相关
- AppleTree.cs:绑定于苹果树AppleTree
- Apple.cs:绑定于苹果Apple
- Basket.cs:绑定于篮筐Basket
- ApplePicker.cs:绑定于主摄像机;BasketPrefab 挂载Basket,EndUI 挂载Canvas->End
- HighScore.cs:绑定于 Canvas->HighScore
问题探讨
苹果树移动时概率转向问题:
- 问题分析:在AppleTree.cs内,原计划实现每秒转向概率为
chanceToChangeDirecyions=0.02
(如下原版代码),但是发现,在FixedUpdate()内,每秒执行50次,也就会导致AppleTree平均每秒改变一次方向:(设概率为t) 50 x (t/1) = 1 ,因此需要修改。 - 解决方案:对随机数Random.value进行修改,即 Random.value/Time.deltaTime,此时每秒转向概率为: 50 x (t / (1/0.02)) = 50 x 0.02(t/1) = 0.02 ,至此解决问题
- 其他:但试验下来0.02概率过低,我已调为0.4,且速度为5
private void FixedUpdate()
{
/*-----原版-----*/
//随机改变运动方向,概率为 chanceToChangeDirecyions
if ((Random.value) < chanceToChangeDirecyions)
speed *= -1;
/*-----修正版-----*/
if ((Random.value / Time.deltaTime) < chanceToChangeDirecyions)
speed *= -1;
}
苹果下落被销毁就不再生成问题:
- 问题分析:当第二个苹果还未实例化,第一个实例化的苹果就因下降越线被销毁或者被篮筐接住销毁,此刻场景内就再无Apple预制体,也就是说,AppleTree脚本 就失去对象applePrefab,无法再实例化产生苹果
- 解决方案:围绕保证场景内任意时刻存在一个applePrefab
- 调高树的高度(本例方案)
- 缩短实例化苹果的间隔
- 先隐藏再延时销毁苹果(理论可行,但感觉大材小用)
参考
- 《游戏设计、原型于开发》 - Jeremy Gibson
- unity如何调用另一个脚本中的变量
- Unity5.x的GUIText被UI Text所取代
Unity项目 - 捡苹果 Apple Picker的更多相关文章
- 为Unity项目生成文档(二)
Unity项目生成文档 接着上篇文章:为Unity项目生成文档(一) .Net项目可在VS配置XML 我们可以在VS中通过配置来生成xml文件,但是unity的project,就算同样配置了xml文档 ...
- unity项目实现“再按一次退出程序”提示功能
unity项目,再按一次退出程序,按第一次做提示,再按一次,程序退出. float _waitTime = 2f;//前后两次按退出间隔时间 void OnGUI() { ) { GUI.Label( ...
- Unity学习笔记(二)——第一个Unity项目Hello Unity
保留版权,转载请注明出处:http://blog.csdn.net/panjunbiao/article/details/9318811 在这一篇文章里,参照宣雨松的<Unity 3D游戏开发& ...
- 关于Unity项目中创建项目遇到的一些问题
1.Unity调用Android的方法默认不是在UI线程执行,所以在Android上写一些页面的重绘的方法,让Unity去调用时,注意要在Android中添加对应的runOnUiThread才可以: ...
- 使用Slua框架开发Unity项目的重要步骤
下载与安装 下载地址 GitHub 安装过程1.下载最新版,这里, 解压缩,将Assets目录里的所有内容复制到你的工程中,对于最终产品,可以删除slua_src,例子,文档等内容,如果是开发阶段则无 ...
- 2017最新苹果 APPLE ID注册流程
不管你是苹果开发者还是苹果爱好者,只要你手中有苹果的终端(IPHONE .IPAD .ITouch,MAC电脑) 你想用苹果的一些服务,你就必须要申请苹果APPLE ID,才能享受到苹果提供高品质的服 ...
- Unity项目开发过程中常见的问题,你遇到过吗?
最近看到有朋友问一个unity游戏开发团队,需要掌握哪些知识之类的问题.事实上Unity引擎是一个很灵活的引擎,根据团队开发游戏类型的不同,对人员的要求也有差异,所以不能一概而论.但是,一些在Unit ...
- 用好lua+unity,让性能飞起来——关于《Unity项目常见Lua解决方案性能比较》的一些补充
<Unity项目常见Lua解决方案性能比较>,这篇文章对比了现在主流几个lua+unity的方案 http://blog.uwa4d.com/archives/lua_perf.html ...
- Unity项目中的资源管理
这是我在2017金山技术开放日分享的部分内容.从贴图资源格式配置的介绍开始,引申出资源配置工具,最后再谈谈一整套项目资源管理方案.在GitHub上可以获取到资源配置工具的代码,是基于下面理念的一份简单 ...
随机推荐
- Educational Codeforces Round 57 (Rated for Div. 2) 前三个题补题
感慨 最终就做出来一个题,第二题差一点公式想错了,又是一波掉分,不过我相信我一定能爬上去的 A Find Divisible(思维) 上来就T了,后来直接想到了题解的O(1)解法,直接输出左边界和左边 ...
- laravel 开发辅助工具
laravel 开发辅助工具 配置 添加服务提供商 将下面这行添加至 config/app.php 文件 providers 数组中: 'providers' => [ ... App\Plug ...
- buf.writeUIntBE()函数详解
buf.writeUIntBE(value, offset, byteLength[, noAssert]) buf.writeUIntLE(value, offset, byteLength[, n ...
- Java核心技术 卷一 复习笔记(乙
1.字符串从概念上讲,Java字符串就是Unicode字符序列.Java没有内置的字符串类型,而是在标准Java类库中提供了一个预定义类,叫String. 每个用双引号括起来的字符串都是 String ...
- convert images to a video (Ubuntu)
use =avconv= package e.g. to convert images (v_1.png, v_2.png ...) to 'velocity.mp4' >>> a ...
- SSM+Shiro
1) 表名:用户表(Sys_Users) Salt:盐(佐料).为避免被黑客等进行攻击(暴力密码破解),所以一般在注册用户信息时,系统会随机生成一个随机码.在验证时会将密码和随机码进行运算,以验证密码 ...
- 如何通过js在子页面调用父页面元素的click事件
//获取父页面的某个元素var node = window.parent.document.getElementById("btnReturn");//调用该元素的Click事件 ...
- 【Codeforces 369C】 Valera and Elections
[链接] 我是链接,点我呀:) [题意] 给你一棵树 让你选择若干个修理点. 这些修理点被选中之后,节点i到1号节点之间的所有"坏路"都会被修好 问最少需要选择多少个点才能将所有的 ...
- nyoj 19 擅长排列的小明(深搜,next_permutation)
擅长排列的小明 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 小明十分聪明,而且十分擅长排列计算.比如给小明一个数字5,他能立刻给出1-5按字典序的全排列,如果你想 ...
- HDU 1228 字符串到数字的转化
一道水题,练练字符串的输入输出 #include <cstdio> #include <cstring> using namespace std; ] , s2[]; int ...