本文为博主原创文章,欢迎转载,请保留出处:http://blog.csdn.net/andrewfan

3.1组件 Component

组件是Unity中最核心的一个概念,它是一切编程的基础。没有组件,也就没有了Unity编程。

打开一个新Unity工程,我们在Project面板中右键可以直接创建出一个C#脚本。

脚本的内容如下:

using UnityEngine;
using System.Collections; public class NewBehaviourScript : MonoBehaviour { // Use this for initialization
void Start () { } // Update is called once per frame
void Update () { }
}

默认的脚本继承自MonoBehavior类,这个类是通常的自定义脚本组件继承类,也就是我们自己所编写的脚本的父类。而Unity内部组件,如相机等是继承自

MonoBehavior的父类Behavior或者再上层的父类Component。Unity为何要分成三个级别继承?从Component到Behavior只是增加了一个是否可以enable

的属性,用于区别有些组件是可以禁用的,而有些组件是不可以的。而从Behavior到MonoBehavior,则纯粹是为了Unity程序员准备的,因为它增加了很多响应

消息,包括上面代码中看到的Start、Update以及后面提到的LateUpdate、FixedUpdate等消息。这些消息均是为了让程序员可以方便地控制和响应组件,而这

些消息对于Unity内置组件来说它是不需要的,它内部自己知道什么时候需要进行启动、更新等等操作。

因此,我们尝试参考MonoBehavior的文档,将常见的消息响应全部都打印到控制台上,于是代码看起来是这样:

using UnityEngine;
using System.Collections;
using Assets.AndrewBox.Util; public class TestComponenets : MonoBehaviour
{ void Awake()
{
Debuger.LogAtFrame("Awake");
} void Start ()
{
Debuger.LogAtFrame("Start");
} // Update is called once per frame
void Update ()
{
//Debuger.LogAtFrame("Update");
}
void LateUpdate()
{
//Debuger.LogAtFrame("LateUpdate");
}
void FixedUpdate()
{
//Debuger.LogAtFrame("FixedUpdate");
} void OnEnable()
{
Debuger.LogAtFrame("OnEnable");
}
void OnDisable()
{
Debuger.LogAtFrame("OnDisable");
}
void OnDestroy()
{
Debuger.LogAtFrame("OnDestroy");
}
}

附加的Debuger类,用于打印消息,这里在显示消息的同时,记录了当前画面运行的帧数,以便于我们观察函数调用的次序以及时机:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using UnityEngine; namespace Assets.AndrewBox.Util
{
public static class Debuger
{
public static void LogAtFrame(string infor)
{
Debug.Log("["+Time.frameCount+"]"+infor);
}
}
}

准备好代码之后,在场景中新建一个Cube(其实任意GameObject都可以),将TestComponenets拖放其上,然后尝试启动运行,并且在Cube的TestComponenets组件上,

将勾选状态关闭再打开,可以看到控制台输出的内容。而后停止运行,将上述代码中的注释去掉,暴露出几个Update方法,再次运行以便查看结果。

最终,我们可以得出如下结论:

  • Awake 方法:当GameObject被启用时,立刻被执行,中文的字面意思就是说,组件已经苏醒,但是它还没有执行,只是准备好了而已。只执行一次。
  • OnEnable方法:当组件被启用时(如果GameObject都没启用,组件更谈不上启用),立刻执行,当多启用时反复执行。
  • OnDisable方法:与OnEnable对应,当组件被禁用时,立刻执行,当多禁用时反复执行。
  • Start方法:当组件被启用后的下一帧,才会被执行。只执行一次。【特别注意,这里是下一帧,如果不注意的话,在资源加载方面可能会出现问题】
  • OnDestroy方法:当组件被销毁时执行。
  • Update:每帧执行一次,每秒刷新次数取决于硬件图像的刷新速度。
  • LateUpdate:每帧执行一次,后于Update执行,这里一般用作绘制到屏幕的最后处理(如无此特殊需要,用Update即可)。
  • FixedUpdate:默认按每隔0.02秒(具体时间可以设置)执行一次,与图像刷新率无关,用于物理逻辑计算。

正常情况下,执行的顺序是如下图:

也就是说,在Awake、OnEnable、Start之后开始几种Update循环。

一般OnEnable用作处理开启和关闭组件时的开关量转换,那么对于此组件的初始化我们可以写在Awake和Start中。

由于Awake是加载和启用GameObject后立刻执行的,因此,如果本组件跟随GameObject加载后,应该立刻初始化本组件的共有成员,如果这些成员需要被其它代码所访问的话。

因为如果放在Start中初始化的话,那么还需要等待一帧,而这一帧过程中,很可能已经发生了对这些共有成员的访问,而此时尚未初始化。所以应该避免这种情况出现。

我们暂时将其成为二阶段初始化,以便更好的记忆。在后续的章节中我们会有更多的体现。

本文为博主原创文章,欢迎转载,请保留出处:http://blog.csdn.net/andrewfan

Unity编程标准导引-3.1 Component 组件脚本及其基本生命周期的更多相关文章

  1. Unity编程标准导引-3.2 MonoBehavior 组件父类重构

    本文为博主原创文章,欢迎转载.请保留博主链接:http://blog.csdn.net/andrewfan 3.2MonoBehavior 组件父类重构 为了让我们的组件类用起来更方便,我们将上一节的 ...

  2. Unity编程标准导引-3.4 Unity中的对象池

    本文为博主原创文章,欢迎转载.请保留博主链接http://blog.csdn.net/andrewfan Unity编程标准导引-3.4 Unity中的对象池 本节通过一个简单的射击子弹的示例来介绍T ...

  3. Unity编程标准导引-2.2Unity中的基本概念

    2.2Unity中的基本概念 上述介绍提到了几个概念:游戏对象.场景.资源.相机,这个小节我们来深入了解,同时进行一些实践性操作.不过首先,我们需要大概了解一下Unity的工程文件夹. 2.2.1工程 ...

  4. Unity编程标准导引-Unity中的基本概念-2.1界面概览

    Unity中的基本概念 本文我们介绍Unity中的基本概念,包括:场景.游戏对象.组件.预制件.资源等. 2.1.界面概览 打开Unity之后,我们大概可以看到以上画面,以上画面中即显示了我们最常用到 ...

  5. Unity编程标准导引-1.2官方资源介绍

    1.2.官方资源介绍 Unity官方提供了丰富的学习和参考资源,有以下类别: Unity手册以及API文档 Unity的官方教程 AssetStore 1.2.1 Unity手册以及API文档 前述文 ...

  6. Unity编程标准导引-3.3 Transform

    本文为博主原创文章,欢迎转载.请保留博主链接http://blog.csdn.net/andrewfan 每个游戏对象(GameObject),其存在于游戏世界,都有一个位置.朝向.大小等基本定位信息 ...

  7. Unity编程标准导引-1.1下载和安装Unity

    本文为博主原创文章,欢迎转载,请保留出处:http://blog.csdn.net/andrewfan 1.1.下载和安装Unity 1.1.1 选取版本 首先找到Unity官方网站https://s ...

  8. React Native组件的结构和生命周期

    React Native组件的结构和生命周期 一.组件的结构 1.导入引用 可以理解为C++编程中的头文件. 导入引用包括导入react native定义的组件.API,以及自定义的组件. 1.1 导 ...

  9. .Net组件程序设计之对象生命周期

    .Net组件程序设计之对象生命周期 .NET 垃圾回收 IDisposable() Using语句 .NET 垃圾回收 是CLR管理着垃圾回收器,垃圾回收器监控着托管堆,而我们使用的对象以及系统启动是 ...

随机推荐

  1. Vagrant 手册之多个虚拟机 multi-machine

    原文地址 Vagrant 可以通过一个 Vagrantfile 定义并控制多个客户机.这就是所谓的"multi-machine"多虚拟机环境. 这些机器通常可以协同工作,或者互相关 ...

  2. 阅读笔记05-架构师必备最全SQL优化方案(1)

    一.优化的哲学 1.优化可能带来的问题? 优化不总是对一个单纯的环境进行,还很可能是一个复杂的已投产的系统: 优化手段本来就有很大的风险,只不过你没能力意识到和预见到: 任何的技术可以解决一个问题,但 ...

  3. JavaScript.Remove

    Array.prototype.remove = function (from, to) {     var rest = this.slice((to || from) + 1 || this.le ...

  4. 初识内存分配ByteBuf

    初识ByteBuf: ByteBuf 是Netty 整个结构里面最为底层的模块,主要负责把数据从底层IO 里面读到ByteBuf,然后传递给应用程序,应用程序处理完成之后再把数据封装成ByteBuf ...

  5. FireFox浏览器导出文件名乱码

    解决方案1 String codedFileName = "导出文件名.xls"; String agent = request.getHeader("USER-AGEN ...

  6. [Codeforces 639F] Bear and Chemistry (Tarjan+虚树)(有详细注释)

    [Codeforces 639F] Bear and Chemistry(Tarjan+虚树) 题面 给出一个n个点,m条边的无向图(不保证连通,可能有自环和重边),有q次询问,每次询问给出p个点和q ...

  7. 如何学习 websocket ?

    如何学习 websocket ? 使用 HTML https://github.com/phoboslab/jsmpeg MPEG1 进行播放 https://w3c.github.io/media- ...

  8. JavaScript给动态插入的元素添加事件绑定

    由于实际的需要,有时需要往网页中动态的插入HTML内容,并在插入的节点中绑定事件处理函数.我们知道,用Javascript向HTML文档中 插入内容,有两种方法, 一种是在写HTML代码写入JS,然后 ...

  9. XMPP即时通讯协议使用(二)——基于Smack相关操作

    package com.test; import java.util.ArrayList; import java.util.Collection; import java.util.Iterator ...

  10. 64-基于TMS320C6455、XC5VSX95T 的6U CPCI无线通信处理平台

    基于TMS320C6455.XC5VSX95T 的6U CPCI无线通信处理平台   1. 板卡概述 本板卡由我公司自主研发,基于CPCI架构,符合PICMG2.0 D3.0标准,包含双TI TMS3 ...