unity 如何脚本间交互

简介: 如何脚本间交互:方法1:通过在编辑器里面拖动,来持有这个对象去调用对应的函数,这个方法比较简单。在编辑器中新建2个脚本。我们写一个a脚本public class Ascript : MonoBehaviour {// Use this for initializationvoid St...

如何脚本间交互:
方法1:

通过在编辑器里面拖动,来持有这个对象去调用对应的函数,这个方法比较简单。

在编辑器中新建2个脚本。

我们写一个a脚本

public class Ascript : MonoBehaviour {

// Use this for initialization

void Start () {

}

// Update is called once per frame

void Update () {

}

public void DoSomething()

{

Debug.LogWarning ("Ascript .. DoSomething .. Call");

}

}

我们想Main脚本去调用A脚本。我们就在Main 写一个A对象。

public Ascript ascript_;

这个是在代码编写的时候已经可以调用A对象的public 函数。

if (ascript_)

ascript_.DoSomething ();

但其实这个ascript_ 对象是空的,我们要对它赋值。这个时候我们在编辑器拖一个有a脚本的实体对象上去就可以了。

我们看见Debug.LogWarning ("Ascript .. DoSomething .. Call");有执行。

方法2:

我们把上面的直接调用改成

if (ascript_)

ascript_.SendMessage ("DoSomething");

我们把a脚本里面的DoSomething函数的public 去掉。

我们看见Debug.LogWarning ("Ascript .. DoSomething .. Call");有执行。

我们尝试给函数加一些参数,看看结果。

我们对A脚本的 DoSomething 进行修改。

void DoSomething(int param1)

{

Debug.LogWarning (string.Format("{0} {1}","Ascript .. DoSomething .. Call",param1));

}

如果我们脚本中有2个同名的函数会怎么样呢。

测试结果是谁在上面谁就会被调用。

可以在后面加一个参数。

if (ascript_) ascript_.SendMessage("DoSomething",2,SendMessageOptions.RequireReceiver);

我们把 a脚本的 DoSomething 函数删掉。

结果报错了......

我们把参数换了试试。

if (ascript_) ascript_.SendMessage("DoSomething",2,SendMessageOptions.DontRequireReceiver);

我们发现不报错了。

Public static
我们a脚本的DoSomething函数改成

public static void DoSomething()

{

Debug.LogWarning(string.Format("{0} {1}","Ascript .. DoSomething .. Call","static function"));

}

我们直接 Ascript.DoSomething ();调用就可以了。

我们再在这个基础上面改成下面这个样子。

public class Ascript : MonoBehaviour {

public static Ascript aStatic;

// Use this for initialization

void Start () {

aStatic = this;

}

// Update is called once per frame

void Update () {

}

public void DoSomething()

{

Debug.LogWarning(string.Format("{0} {1}","Ascript .. DoSomething .. Call","static Object"));

}

}

我们把调用的改成,Ascript.aStatic.DoSomething ();

我们这个时候已经不持有这个对象了。

但是场景一定要这个对象,如果没有的话会报错。

如果我们场景里面有很多这个对象,他会找到这个对象最早生成的那个,注意不是你创建的实体对象而是第一个拖上这个脚本的对象。

如何脚本间交互:
方法1:

通过在编辑器里面拖动,来持有这个对象去调用对应的函数,这个方法比较简单。

在编辑器中新建2个脚本。

我们写一个a脚本

public class Ascript : MonoBehaviour {

// Use this for initialization

void Start () {

}

// Update is called once per frame

void Update () {

}

public void DoSomething()

{

Debug.LogWarning ("Ascript .. DoSomething .. Call");

}

}

我们想Main脚本去调用A脚本。我们就在Main 写一个A对象。

public Ascript ascript_;

这个是在代码编写的时候已经可以调用A对象的public 函数。

if (ascript_)

ascript_.DoSomething ();

但其实这个ascript_ 对象是空的,我们要对它赋值。这个时候我们在编辑器拖一个有a脚本的实体对象上去就可以了。

我们看见Debug.LogWarning ("Ascript .. DoSomething .. Call");有执行。

方法2:

我们把上面的直接调用改成

if (ascript_)

ascript_.SendMessage ("DoSomething");

我们把a脚本里面的DoSomething函数的public 去掉。

我们看见Debug.LogWarning ("Ascript .. DoSomething .. Call");有执行。

我们尝试给函数加一些参数,看看结果。

我们对A脚本的 DoSomething 进行修改。

void DoSomething(int param1)

{

Debug.LogWarning (string.Format("{0} {1}","Ascript .. DoSomething .. Call",param1));

}

如果我们脚本中有2个同名的函数会怎么样呢。

测试结果是谁在上面谁就会被调用。

可以在后面加一个参数。

if (ascript_) ascript_.SendMessage("DoSomething",2,SendMessageOptions.RequireReceiver);

我们把 a脚本的 DoSomething 函数删掉。

结果报错了

我们把参数换了试试。

if (ascript_) ascript_.SendMessage("DoSomething",2,SendMessageOptions.DontRequireReceiver);

我们发现不报错了。

Public static
我们a脚本的DoSomething函数改成

public static void DoSomething()

{

Debug.LogWarning(string.Format("{0} {1}","Ascript .. DoSomething .. Call","static function"));

}

我们直接 Ascript.DoSomething ();调用就可以了。

我们再在这个基础上面改成下面这个样子。

public class Ascript : MonoBehaviour {

public static Ascript aStatic;

// Use this for initialization

void Start () {

aStatic = this;

}

// Update is called once per frame

void Update () {

}

public void DoSomething()

{

Debug.LogWarning(string.Format("{0} {1}","Ascript .. DoSomething .. Call","static Object"));

}

}

我们把调用的改成,Ascript.aStatic.DoSomething ();

我们这个时候已经不持有这个对象了。

但是场景一定要这个对象,如果没有的话会报下面的错。

如果我们场景里面有很多这个对象,他会找到这个对象最早生成的那个,注意不是你创建的实体对象而是第一个拖上这个脚本的对象。

单例模式

public class MyClass : MonoBehaviour {

void Awake () {

Debug.Log(Manager.Instance.myGlobalVar);

}}

public class Manager : Singleton {

protected Manager () {} // guarantee this will be always a singleton only - can't use the constructor!

public string myGlobalVar = "whatever";}

using UnityEngine;

///
/// Be aware this will not prevent a non singleton constructor
/// such as T myT = new T();
/// To prevent that, add protected T () {} to your singleton class.
///
/// As a note, this is made as MonoBehaviour because we need Coroutines.
///
public class Singleton : MonoBehaviour where T : MonoBehaviour
{
private static T _instance;

private static object _lock = new object();

public static T Instance
{
get
{
if (applicationIsQuitting) {
Debug.LogWarning("[Singleton] Instance '"+ typeof(T) +
"' already destroyed on application quit." +
" Won't create again - returning null.");
return null;
}

lock(_lock)
{
if (_instance == null)
{
_instance = (T) FindObjectOfType(typeof(T));

if ( FindObjectsOfType(typeof(T)).Length > 1 )
{
Debug.LogError("[Singleton] Something went really wrong " +
" - there should never be more than 1 singleton!" +
" Reopening the scene might fix it.");
return _instance;
}

if (_instance == null)
{
GameObject singleton = new GameObject();
_instance = singleton.AddComponent();
singleton.name = "(singleton) "+ typeof(T).ToString();

DontDestroyOnLoad(singleton);

Debug.Log("[Singleton] An instance of " + typeof(T) +
" is needed in the scene, so '" + singleton +
"' was created with DontDestroyOnLoad.");
} else {
Debug.Log("[Singleton] Using instance already created: " +
_instance.gameObject.name);
}
}

return _instance;
}
}
}

private static bool applicationIsQuitting = false;
///
/// When Unity quits, it destroys objects in a random order.
/// In principle, a Singleton is only destroyed when application quits.
/// If any script calls Instance after it have been destroyed,
/// it will create a buggy ghost object that will stay on the Editor scene
/// even after stopping playing the Application. Really bad!
/// So, this was made to be sure we're not creating that buggy ghost object.
///
public void OnDestroy () {
applicationIsQuitting = true;
}
}

更多unity2018的功能介绍请到paws3d爪爪学院查找。

相关文章
|
8月前
|
存储 人工智能 Java
Unity优化——脚本优化策略4
Unity优化——脚本优化策略4
128 0
|
4月前
|
前端开发 图形学 开发者
【独家揭秘】那些让你的游戏瞬间鲜活起来的Unity UI动画技巧:从零开始打造动态按钮,提升玩家交互体验的绝招大公开!
【9月更文挑战第1天】在游戏开发领域,Unity 是最受欢迎的游戏引擎之一,其强大的跨平台发布能力和丰富的功能集让开发者能够迅速打造出高质量的游戏。优秀的 UI 设计对于游戏至关重要,尤其是在手游市场,出色的 UI 能给玩家留下深刻的第一印象。Unity 的 UGUI 系统提供了一整套解决方案,包括 Canvas、Image 和 Button 等组件,支持添加各种动画效果。
268 3
|
4月前
|
设计模式 存储 人工智能
深度解析Unity游戏开发:从零构建可扩展与可维护的游戏架构,让你的游戏项目在模块化设计、脚本对象运用及状态模式处理中焕发新生,实现高效迭代与团队协作的完美平衡之路
【9月更文挑战第1天】游戏开发中的架构设计是项目成功的关键。良好的架构能提升开发效率并确保项目的长期可维护性和可扩展性。在使用Unity引擎时,合理的架构尤为重要。本文探讨了如何在Unity中实现可扩展且易维护的游戏架构,包括模块化设计、使用脚本对象管理数据、应用设计模式(如状态模式)及采用MVC/MVVM架构模式。通过这些方法,可以显著提高开发效率和游戏质量。例如,模块化设计将游戏拆分为独立模块。
270 3
|
4月前
|
vr&ar 图形学 API
Unity与VR控制器交互全解:从基础配置到力反馈应用,多角度提升虚拟现实游戏的真实感与沉浸体验大揭秘
【8月更文挑战第31天】虚拟现实(VR)技术迅猛发展,Unity作为主流游戏开发引擎,支持多种VR硬件并提供丰富的API,尤其在VR控制器交互设计上具备高度灵活性。本文详细介绍了如何在Unity中配置VR支持、设置控制器、实现按钮交互及力反馈,结合碰撞检测和物理引擎提升真实感,助力开发者创造沉浸式体验。
241 0
|
4月前
|
图形学 开发者 UED
Unity游戏开发必备技巧:深度解析事件系统运用之道,从生命周期回调到自定义事件,打造高效逻辑与流畅交互的全方位指南
【8月更文挑战第31天】在游戏开发中,事件系统是连接游戏逻辑与用户交互的关键。Unity提供了多种机制处理事件,如MonoBehaviour生命周期回调、事件系统组件及自定义事件。本文介绍如何有效利用这些机制,包括创建自定义事件和使用Unity内置事件系统提升游戏体验。通过合理安排代码执行时机,如在Awake、Start等方法中初始化组件,以及使用委托和事件处理复杂逻辑,可以使游戏更加高效且逻辑清晰。掌握这些技巧有助于开发者更好地应对游戏开发挑战。
196 0
|
5月前
|
开发者 图形学 Java
Unity物理引擎深度揭秘:从刚体碰撞到软体模拟,全面解析实现复杂物理交互的技巧与秘诀,助你打造超真实游戏体验
【8月更文挑战第31天】物理模拟在游戏开发中至关重要,可让虚拟世界更真实。Unity作为强大的跨平台游戏引擎,内置物理系统,支持从刚体碰撞到布料模拟的多种功能。通过添加Rigidbody组件,可实现物体受力和碰撞;使用AddForce()施加力;通过关节(如Fixed Joint)连接刚体以模拟复杂结构。Unity还支持软体物理,如布料和绳索模拟,进一步增强场景丰富度。掌握这些技术,可大幅提升游戏的真实感和玩家体验。
241 0
|
5月前
|
图形学 C# 开发者
全面掌握Unity游戏开发核心技术:C#脚本编程从入门到精通——详解生命周期方法、事件处理与面向对象设计,助你打造高效稳定的互动娱乐体验
【8月更文挑战第31天】Unity 是一款强大的游戏开发平台,支持多种编程语言,其中 C# 最为常用。本文介绍 C# 在 Unity 中的应用,涵盖脚本生命周期、常用函数、事件处理及面向对象编程等核心概念。通过具体示例,展示如何编写有效的 C# 脚本,包括 Start、Update 和 LateUpdate 等生命周期方法,以及碰撞检测和类继承等高级技巧,帮助开发者掌握 Unity 脚本编程基础,提升游戏开发效率。
156 0
|
5月前
|
图形学 iOS开发
Unity与IOS⭐最基础的交互演示
Unity与IOS⭐最基础的交互演示
|
7月前
|
存储 图形学
【unity小技巧】unity事件系统创建通用的对象交互的功能
【unity小技巧】unity事件系统创建通用的对象交互的功能
85 0
|
7月前
|
人工智能 图形学
【unity小技巧】使用动画状态机脚本实现一个简单3d敌人AI功能
【unity小技巧】使用动画状态机脚本实现一个简单3d敌人AI功能
75 0