在Unity中,通常通过脚本为GameObject添加额外的属性。具体有2种方式:一种是通过硬编码为脚本字段赋值,另一种是通过反射在运行时给脚本字段赋值。

脚本通过字段硬编码为GameObject添加额外的属性

创建一个空的GameObject。

点击"Hierarchy"窗口下的GameObject,看到如下的"Inspector"窗口。

现在我们要为这个GameObject增加一个Count属性,该怎么做呢?

在"Project"窗口下的"Asserts"中的"_MyScripts"文件夹下创建一个名称为"MyVariable"的脚本文件。

双击"MyVariable"脚本文件,文件在Visual Studio中打开,编辑如下:

using UnityEngine;
using System.Collections;

public class MyVariable : MonoBehaviour
{

    public int Count = 1;

    // Use this for initialization
    void Start () {

    }

    // Update is called once per frame
    void Update () {

    }
}


保存"MyVariable"脚本文件,把之拖动到"Hierarchy"窗口下的GameObject上方。此时,GameObject对应的"Inspector"窗口中多了一个Count属性。

至此,通过脚本文件为GameObject添加了额外的属性。

在Unity中,如果脚本中的字段被打上[SerializeField]特性,该字段也会成为GameObject的额外属性。

using UnityEngine;
using System.Collections;

public class MyVariable : MonoBehaviour
{

    public int Count = 1;

    [SerializeField]
    private GameObject objectSerialized;

    // Use this for initialization
    void Start () {

    }

    // Update is called once per frame
    void Update () {

    }
}


在Unity中,即使是一个public的字段,如果打上[HideInInspector]特性,该字段就不会出现在Inspector窗口中。

using UnityEngine;
using System.Collections;

public class MyVariable : MonoBehaviour
{

    public int Count = 1;

    [SerializeField]
    private GameObject objectSerialized;

    [HideInInspector]
    public GameObject objectNotPublic;

    // Use this for initialization
    void Start () {

    }

    // Update is called once per frame
    void Update () {

    }
}


以上,objectNotPublic字段不会出现在Inspector窗口中。

在Unity脚本中,不仅可以声明C#的基本数据类型,还可以声明Unity独有的引用类型,比如Vector2, Vector3, Quaternion, GameObject,甚至是自定义类型,等等。

另外,当点击组件的Reset,实际上是调用了MonoBehaviour类的Reset方法,会对所有字段属性初始化。我们还可以在自定义组件中重写Reset方法。

using UnityEngine;
using System.Collections;

public class MyVariable : MonoBehaviour
{

    public int Count = 1;

    [SerializeField]
    private GameObject objectSerialized;

    [HideInInspector]
    public GameObject objectNotPublic;

    void Reset()
    {
        Count = 2;
    }

    // Use this for initialization
    void Start () {

    }

    // Update is called once per frame
    void Update () {

    }
}


当再次点击组件的Reset按钮,呈现如下:

脚本通过反射为GameObject动态添加额外属性

为Scene添加2个GameObject类型的Cube。

修改MyVariable类文件如下:

using UnityEngine;
using System.Collections;

public class MyVariable : MonoBehaviour
{

    public int Count = 1;

    [SerializeField]
    private GameObject objectSerialized;

    [HideInInspector]
    public GameObject objectNotPublic;

    void Reset()
    {
        Count = 2;
    }

    // Use this for initialization
    void Start ()
    {
        objectSerialized = GameObject.Find("Cube");
    }



    // Update is called once per frame
    void Update () {

    }
}


由于是在运行时通过反射来给MyVariable中GameObject类型的字段objectSerialized赋值,所以需要运行项目才可以看到MyVariable脚本的objectSerialized字段值。

运行。

点击"Hierarchy"窗口中GameObject,可以看到"Inspector"窗口中,通过反射为objectSerialized字段赋的值。

还可以通过GameObject的Tag名称,使用反射为字段动态赋值。

点击"Hierarch"窗口中的一个Cube,为其添加一个tag。

再次修改MyVariable类文件如下:

using UnityEngine;
using System.Collections;

public class MyVariable : MonoBehaviour
{

    public int Count = 1;

    [SerializeField]
    private GameObject objectSerialized;

    [HideInInspector]
    public GameObject objectNotPublic;

    void Reset()
    {
        Count = 2;
    }

    // Use this for initialization
    void Start ()
    {
        objectSerialized = GameObject.FindGameObjectWithTag("mycute");
    }



    // Update is called once per frame
    void Update () {

    }
}


再次运行,点击"Hierarchy"窗口中GameObject,看到如下:

参考资料:极客学院听课笔记

Unity3D实践系列05,为GameObject添加额外属性的更多相关文章

  1. Unity3D实践系列11, 组件的添加和访问

    当把一个脚本附加到一个GameObject上的时候,这个GameObject就有了脚本组件. 通过GameObject的属性获取组件 比如如下: [RequireComponent(typeof(Ri ...

  2. Unity3D实践系列04, 脚本的生命周期

    Unity3D脚本生命周期是指从脚本的最初唤醒到脚本最终销毁的整个过程.生命周期的各个方法被封装到了MonoBehaviour类中.具体来说如下: 1.In Editor Mode 编辑模式 当在编辑 ...

  3. Unity3D实践系列06,球体撞击物体游戏

    本篇实现一个球体在固定区域移动撞击Cube的游戏. 首先有1个Plane当作地面,1个Sphere当作球体,4个Cube当作墙,12个Cube当作被撞击物体,另外还有球体的撞击计算,在撞击的过程适时显 ...

  4. ASP.NET Web API实践系列05,消息处理管道

    ASP.NET Web API的消息处理管道可以理解为请求到达Controller之前.Controller返回响应之后的处理机制.之所以需要了解消息处理管道,是因为我们可以借助它来实现对请求和响应的 ...

  5. Unity3D实践系列09, 物理引擎与碰撞检测

    在Unity3D中,一个物体通常包含一个Collider和一个Rigidbody.Collider是碰撞体,一个物体是Collider,才可以进行碰撞检测.Collider组件中的"Is T ...

  6. Unity3D实践系列07,组件的启用或禁用开关,物体的的可见或不可见开关,以及相应事件

    创建一个Unity项目. 在"Project"窗口中,在"Asserts"中,添加"_MyScene"文件夹. 点击"File&q ...

  7. Unity3D实践系列03,使用Visual Studio编写脚本与调试

    在Unity3D中,只有把脚本赋予Scene中的GameObject,脚本才会得以执行. 添加Camera类型的GameObject. Unity3D默认使用"MonoDevelop&quo ...

  8. Unity3D实践系列10, Canvas画布的创建和使用

    Canvas是所有ui元素的父物体. 当添加一个Button类型的GameObject后,在"Hierarch"窗口中自动添加了一个Canvas,以及EventSystem. 在C ...

  9. Unity3D实践系列08, MonoBehaviour类的各种触发事件

    在脚本的生命周期中,有Awake, Start, FixedUpdate, Update, LateUpdate等方法,其实这些属于MonoBehaviour类的事件响应方法,是MonoBehavio ...

随机推荐

  1. mysql学习------MySQL慢查询日志

    一.什么是慢查询日志 1.当查询超过一定时间没有返回结果的时候,才会记录进慢查询日志 2.慢查询日志可以帮助dba找出执行效率缓慢的sql语句,为数据库的优化工作提供帮助 3.慢查询日志默认是不开启的 ...

  2. activeMQ安全配置及常见问题解决

    https://blog.csdn.net/dandan2zhuzhu/article/details/78461872

  3. CSS------如何让大小不一样的div顶部对齐

    方法一:(推荐) <div style="float:left;margin-right:20px"> <img src="/source/s_1701 ...

  4. Win10解决无法访问其他机器共享的问题

    Win10解决无法访问其他机器共享的问题     你不能访问此共享文件夹,因为你组织的安全策略阻止未经身份验证的来宾访问.这些策略可帮助保护你的电脑免受网络上不安全设备或恶意设备的威胁. 管理员身份执 ...

  5. 2015 ACM Amman Collegiate Programming Contest 题解

    [题目链接] A - Who Is The Winner 模拟. #include <bits/stdc++.h> using namespace std; int T; int n; s ...

  6. jenkins 整合maven,svn(配置钩子程序实现提交代码自动构建),tomcat实现热部署(windows+linux分别实现)

    springboot : https://blog.csdn.net/zjh_746140129/article/details/80904876 1 准备工作: (1)运行jenkins的tomca ...

  7. maven deploy上传私服出错

    error 内容如下 Failed to execute goal org.apache.maven.plugins:maven-deploy-plugin:2.5:  deploy (default ...

  8. 十个问题带你了解和掌握java HashMap

    十个问题带你了解和掌握java HashMap 一.前言 本篇内容是源于 " 由阿里巴巴Java开发规约HashMap条目引发的故事",并在此基础上加了自己的对HashMap更多的 ...

  9. ajax jqplot ssh实现图表的持续更新

    实现功能: 数据库有新数据图表会更新到 数据库查询使用ssh框架中的hibernate 想法: 画图表的ajaxautoruncopy.jsp利用ajax收到7-13.jsp传过来的数据 7-13.j ...

  10. 5,EasyNetQ-Send Receive

    而发布/订阅和请求/响应模式是位置透明的,因为您不需要指定消息的消费者所在的位置,发送/接收模式专门用于通过命名队列进行通信. 它也不会对可以通过队列发送的消息的类型做任何假设. 这意味着您可以通过同 ...