• Unity -- 入门教程三


    进入这个页面,按编译器版本进行下载,我用的是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

  • 相关阅读:
    IO多路复用
    事件驱动模型
    协程
    进程
    py2与py3的编码问题
    Linux Centos7 网卡无法启动
    监控的法则
    如何优雅的采集activeMQ性能指标
    一分钟性能分析
    beta版 tomcat 应用监控指标
  • 原文地址:https://www.cnblogs.com/mafeng/p/7597242.html
Copyright © 2020-2023  润新知