进入这个页面,按编译器版本进行下载,我用的是2010,所以要下载这个。

安装就不用我教了,下面开始看我是如何导入Unity VS的。

点击Import之后我们会发现并没有发生什么,但是接下来我们按一下刷新的快捷键:Ctrl+F(F:Flush)就会看到上面多出来一个东西。 
点击Open以后就会自动打开VS了。

OK,插件安装完毕,接下来教大家如何做碰撞检测。

发生碰撞需要两个条件,碰撞体要一个具有刚体,一个具有碰撞器。

上一讲我们已经为Cube添加了碰撞器,并且选择了Is Trigger的触发器,那么我们现在开始编写碰撞检测的代码。

在Scripts文件夹下新建一个名为PlayerCollision的C#脚本。

在写代码之前,我要介绍一下碰撞检测有好多种: 
OnTriggerEnter( Collider other )当进入触发器 
OnTriggerExit( Collider other )当退出触发器 
OnTriggerStay( Collider other )当逗留触发器 
OnCollisionEnter( Collision collisionInfo ) 当进入碰撞器 
OnCollisionExit( Collision collisionInfo ) 当退出碰撞器 
OnCollisionStay( Collision collisionInfo ) 当逗留碰撞器

以上这六个方法都是MonoBehaviour里面的,因为我们的脚本都是继承的MonoBehaviour这个类。所以我们的脚本里面可以覆盖这六个方法。

因为我们勾选了Is Trigger,所以,我们覆盖OnTriggerEnter( Collider other )方法:

//当进入碰撞器的方法
public void OnTriggerEnter(Collider other)
{
//如果碰撞的GameObject不是Floor
if(!other.gameObject.name.Equals("Floor"))
{
print("报告主人:触发器成功触发!");
}
}

然后,将这段代码托给Player,运行游戏。

如图所示,碰撞的确发生了,但是Player却穿过了Cube。 
这并不是一个好现象!!! 
那么,我们换另一个方法,将碰撞器的Is Trigger取消。 
然后再将代码改为:

 public void OnCollisionEnter(Collision other)
{
//如果碰撞的GameObject不是Floor
if (!other.gameObject.name.Equals("Floor"))
{
print("报告主人:触发器成功触发!");
}
}

那么,这时候可能有人会问我,刚开始我导入的插件又有什么用呢?

现在我给大家介绍一下,我最喜换这个插件其中的一个最喜欢的功能!

在VS里编辑代码的时候,我们按下快捷键Ctrl+Shift+Q会弹出一个框框。

这里包括了我们继承了MonoBehaviour里面的所有的类。

我们在里面输入On为示范,他会自动为我们索引出一切有关On的方法:

是不是很好用呢?

那么现在我们碰撞检测可以实现了,我们应该怎么实现落在Cube上的时候使Cube停止运动呢

随便问一个不懂编程的人都会说,让他不能动不就动不了了。

对啊,我们将Cube运动的代码取消不就不能运动了,那么我们该如何在游戏运行的时候取消Cube运动的代码呢?

我们将LeftCube移动到Floor前面。只要在发生碰撞的时候我们这么写:

public void OnCollisionEnter(Collision other)
{
//定义一个字符串
string CollisionName; //如果碰撞的GameObject不是Floor
if (!other.gameObject.name.Equals("Floor"))
{
//将碰撞体的名字存在字符串中
CollisionName = other.gameObject.name; //如果碰撞体的名字是LeftCube
if(CollisionName.Equals("LeftCube"))
{
//获取LeftCube身上的LeftCubeMove脚本,并切取消此代码的执行。
other.gameObject.GetComponent<LeftCubeMove>().enabled = false;
}
}
}

这时我们再运行游戏,并使Player与LeftCube发生碰撞.:

可以看到,在碰撞的一瞬间,Cube不移动了,并且右边LeftCubeMove的脚本被取消了。

这样我们是否就可以做到落在Cube上就停止他的运动了呢?

并不然!

我们总不能每发生碰撞都判断一下碰撞体的名称然后再进行取消脚本吧。

还记得在第二讲我曾经说过:(总不会写两个吧?向左一个单独的代码,向右一个单独的代码?)

现在,我来解决这个问题。

马上新建一个命为CubeMove的C#脚本。代码如下:

public class CubeMove : MonoBehaviour {
//定义Cube的初始速度
public float Speed = 1f; void Start () { } void Update () {
//如果脚本所在模型的名字为LeftCube(Clone)或LeftCube
if (this.gameObject.name.Equals("LeftCube(Clone)") || this.gameObject.name.Equals("LeftCube"))
{
//执行移动方法
MoveLeft();
} if (this.gameObject.name.Equals("RightCube(Clone)") || this.gameObject.name.Equals("RightCube"))
{
MoveRight();
}
if (this.gameObject.name.Equals("StaticCube(Clone)") || this.gameObject.name.Equals("StaticCube"))
{
MoveStop();
}
}
//定义移动方法
void MoveLeft()
{
//使Cube的移动速度递增
Speed += 0.1f;
//移动
this.transform.Translate(Vector3.left * Speed * Time.deltaTime);
}
void MoveRight()
{
Speed += 0.1f;
this.transform.Translate(Vector3.right * Speed * Time.deltaTime);
}
void MoveStop()
{
this.transform.Translate(0,0,0);
}
}

这样,我们所有可经过的Cube就都可以公用一个脚本了。

我们将所有Cube单独控制移动的代码都取消掉,然后将CubeMove的脚本托给所有Cube,别忘了StaticCube也要给。

然后我们修改一下PlayerCollision脚本的代码:

    //当进入碰撞器的方法
public void OnCollisionEnter(Collision other)
{
//如果碰撞的GameObject不是Floor
if (!other.gameObject.name.Equals("Floor"))
{
//取消碰撞体上的CubeMove方法
other.gameObject.GetComponent<CubeMove>().enabled = false;
} }

这样,我们就可以简化代码,并且便于管理,而且任何人都能看懂你的代码!

谢谢的大家的关注,那么这一讲就到此结束,下一讲我会讲解如何使Player落在Cube上时出现下一个Cube

Unity -- 入门教程三的更多相关文章

  1. Unity入门教程(下)

    一.概要 在 Unity入门教程(上) 中我们创建了一个游戏项目,并且创建了玩家角色和小球这些游戏对象,还通过添加游戏脚本实现了小方块的弹跳.虽然功能比较简单,但是完整地表现了使用Unity开发游戏的 ...

  2. 无废话ExtJs 入门教程三[窗体:Window组件]

    无废话ExtJs 入门教程三[窗体:Window组件] extjs技术交流,欢迎加群(201926085) 1.代码如下: 1 <!DOCTYPE html PUBLIC "-//W3 ...

  3. PySide——Python图形化界面入门教程(三)

    PySide——Python图形化界面入门教程(三) ——使用内建新号和槽 ——Using Built-In Signals and Slots 上一个教程中,我们学习了如何创建和建立交互widget ...

  4. Elasticsearch入门教程(三):Elasticsearch索引&映射

    原文:Elasticsearch入门教程(三):Elasticsearch索引&映射 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文 ...

  5. RabbitMQ入门教程(三):Hello World

    原文:RabbitMQ入门教程(三):Hello World 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog. ...

  6. JasperReports入门教程(三):Paramters,Fields和Detail基本组件介绍

    JasperReports入门教程(三):Paramter,Field和Detail基本组件介绍 前言 前两篇博客带领大家进行了入门,做出了第一个例子.也解决了中文打印的问题.大家跟着例子也做出了de ...

  7. WebGL入门教程(三)-webgl动画

    前面文章: WebGL入门教程(一)-初识webgl WebGL入门教程(二)-webgl绘制三角形 WebGL动画有移动.旋转和缩放,我们将移动.旋转和缩放图形,然后将其绘制到屏幕上,称为变换(tr ...

  8. 无废话SharePoint入门教程三[创建网站集和网站]

    一.前言 前两篇文章讲解了什么是SharePoint,并且介绍了在SharePoint中一些常用的概念.但概念终究是概念,我们还是要脚踏实地的去动手实践.下面的文章对于了解SharePoint的人来说 ...

  9. Spring Cloud 入门教程(三): 配置自动刷新

    之前讲的配置管理, 只有在应用启动时会读取到GIT的内容, 之后只要应用不重启,GIT中文件的修改,应用无法感知, 即使重启Config Server也不行. 比如上一单元(Spring Cloud ...

随机推荐

  1. 解决VMware vSphere Client无法连接ESXi虚拟主机方法

    1 一般情况下重启services.sh就可以解决(或图形界面下restart management agent)services.sh restart2 若重启services.sh报错且仍然无法连 ...

  2. luogu2394 yyy loves Chemistry I

    练习 #include <iostream> #include <cstdio> using namespace std; long double a; int main(){ ...

  3. Apache 根据不同的端口 映射不同的站点

    以前,在本地新建个项目,总是在Apache的htdocs目录下新建个项目目录,今年弄了个别人写好的网站源码,因为该系统的作者假定网站是放在根目录的,放在二级目录下会出错.所以无奈,只能想办法,根据端口 ...

  4. TensorFlow学习笔记(6):TensorBoard之Embeddings

    本文基于TensorFlow官网的How-Tos写成. TensorBoard是TensorFlow自带的一个可视化工具,Embeddings是其中的一个功能,用于在二维或三维空间对高维数据进行探索. ...

  5. [python学习篇][书籍学习][python standrad library][内建函数]之[all,any,basestring,isinstance,bin,bool,@classmethod,@staticmethod,cmp,enumerate

    Python 解释器内置了一些函数,它们总是可用的.这里将它们按字母表顺序列出.     Built-in Functions     abs() divmod() input() open() st ...

  6. [转]netstat -tnl 列出监听中的连接,查看端口是否开启

    任何网络服务的后台进程都会打开一个端口,用于监听接入的请求. 这些正在监听的套接字也和连接的套接字一样,也能被 netstat 列出来. 参数 tnl, 现在我们可以看到处于监听状态的 TCP 端口和 ...

  7. maven无法下载依赖jar包—几种仓库的区别

    一.问题背景 最近这两天,感觉自己智商急剧退化,到了自己都捉急的地步,呃,有必要记录下来,以后智商被人甩几条街的时候,看看这篇文字,找找灵感也是好的! 这个项目呢,是用IDEA开发的,我一切都弄好了, ...

  8. 基于2.9.6vue-cli初始化webpack工程

    前天做了组内的分享 讲了些webpack的东西 整个流程以及build文件夹内webpack相关的一些js所有的代码 每行代码什么意思 有什么作用 都做了很详细的标明. webpack是3.6的 今天 ...

  9. 【bzoj2115】[Wc2011] Xor DFS树+高斯消元求线性基

    题目描述 输入 第一行包含两个整数N和 M, 表示该无向图中点的数目与边的数目. 接下来M 行描述 M 条边,每行三个整数Si,Ti ,Di,表示 Si 与Ti之间存在 一条权值为 Di的无向边. 图 ...

  10. IE6 IE7下li间距、高度不一致问题(转)

    http://www.phpddt.com/dhtml/926.html 问题描述:li的高度在IE6 IE7间距高度和其他浏览器不一致,即便设定了高度,IE6,7中,仍比其他浏览器要高. 解决方法: ...