Suggest a change
Success!
Thank you for helping us improve the quality of Unity Documentation. Although we cannot accept all submissions, we do read each suggested change from our users and will make updates where applicable.
Close
Submission failed
For some reason your suggested change could not be submitted. Please <a>try again</a> in a few minutes. And thank you for taking the time to help us improve the quality of Unity Documentation.
Close
Your name
Your email
Suggestion*
Cancel
Switch to Manual
Declaration
public static GameObject Find(string name);
Description
Finds a GameObject by name
and returns it.
This function only returns active GameObjects. If no GameObject with name
can be found, null is returned. If name
contains a ‘/’ character, it traverses the hierarchy like a path name.
For performance reasons, it is recommended to not use this function every frame. Instead, cache the result in a member variable at startup. or use GameObject.FindWithTag.
Note: If you wish to find a child GameObject, it is often easier to use Transform.Find.
Note: If the game is running with multiple scenes then Find will search in all of them.
Приветствую Вас, дорогие разработчики. В данной статье мы научимся искать игровые объекту по его имени, и по тегу. Ведь при разработке игр нам довольно часто нужно находить игровые объекты, для дальнейшего выполнения каких-либо действий. Приступим сразу к делу.
Поиск объекта по имени
Для того, чтобы найти объект по его имени, необходимо воспользоваться методом GameObject.Find. Посмотрим реализацию данного метода на примере:
public GameObject obj;
void Awake()
{
obj = GameObject.Find("NameGameObject");
}
Обратите внимание, что в первой строке мы создали переменную obj, чтобы в ней хранить ссылку на игровой объект. А в пятой строке, воспользовавшись методом GameObject.Find, получили сам объект по его имени.
Поиск объекта по тегу
Теперь давайте получим ссылку на наш объект по тегу. Для этого воспользуемся методом GameObject.FindGameObjectWithTag:
public GameObject obj;
void Awake()
{
obj = GameObject.FindGameObjectWithTag("TagName");
}
Как видите, смысл такой же, как и в предыдущем примере. Всё очень просто. Только не забудьте указать тег для Вашего объекта, перед запуском данного скрипта. Иначе объект найден не будет.
Важно: Если в Вашей сцене находится несколько объектов с одинаковыми тегами, то метод GameObject.FindGameObjectWithTag найдёт только самый первый объект. Поэтому, существует ещё один способ, который позволит найти все объекты по указанному тегу.
Поиск массива объектов по тегу
Чтобы найти массив объектов по тегу, воспользуемся методом GameObject.FindGameObjectsWithTag. Вы наверное обратили внимание, что название данного меотда почти 1 в 1 схоже с предыдущим методом, за исключением добавленной быквы s в середине названия.
Рассмотрим пример использования метода GameObject.FindGameObjectsWithTag:
public GameObject[] obj;
void Awake()
{
obj = GameObject.FindGameObjectsWithTag("TagName");
}
Обратите внимание, что при использовании метода GameObject.FindGameObjectsWithTag, в первой строке мы должны оказать, что нам нужен массив объектов, при помощи квадратных скобок [].
When developing games in Unity, one of the most common tasks is to find and interact with game objects. Whether you need to access an active game object, search for a specific tag, or retrieve the first object that matches a certain criterion, Unity provides several methods to accomplish these tasks efficiently. In this article, we will explore different ways to find game objects in Unity using C#.
Do not use these functions in the Update method without a condition. Otherwise, it will search for the object every frame and affect the performance of the game. It’s wise to use them in the Awake or Start function.
The GameObject.Find Method:
The most straightforward method to find a game object is by using the GameObject.Find
method. This method takes a string argument, which represents the path name of the object in the hierarchy view.
For example, if you have an object named “Player” nested under an empty object named “Characters,” you can find it using GameObject.Find("Characters/Player")
. However, it’s important to note that using GameObject.Find
can impact performance, especially if used frequently or in performance-sensitive areas like the Update
function.
GameObject.FindWithTag:
To simplify the process of finding objects with a specific tag, Unity provides the GameObject.FindWithTag
method. This method takes a string argument representing a tag and returns the first active game object with that tag. Tags can be managed using the Tag Manager in the Unity editor, allowing you to assign meaningful tags to objects for easy identification and retrieval.
Transform.Find and GetComponentInChildren:
If you need to find a child game object of a specific parent object, you can use the Transform.Find
method. This method searches for a child object using its path name relative to the parent object. For instance, transform.Find("ChildObjectName")
will return the child object with the specified name.
Additionally, if you need to find a component attached to a child object, you can combine GetComponentInChildren
with Transform.Find
to retrieve the component from the child object.
Object References and Member Variables:
In many cases, you may already have a reference to a game object stored in a member variable. In such scenarios, there is no need to find the object again using any of the aforementioned methods. By assigning the game object to a variable, you can directly access its properties and components without the need for additional searches.
It’s important to mention that finding game objects during runtime incurs a performance cost, especially when performed frequently or in computationally intensive situations. To optimize your game, consider caching object references when possible or using alternative strategies to minimize the number of find operations.
In conclusion, Unity provides various methods to find game objects efficiently. Whether you choose to use the GameObject.Find
method, leverage tags and the Tag Manager, or store object references in member variables, understanding the different ways to find game objects in Unity will greatly enhance your game development workflow. Remember to consider performance reasons when determining the most suitable method for your specific use case, and optimize your code accordingly.
Finding and referencing a game object properly in Unity3D is one of the most asked questions for those who are new to Unity3D. In this article, I will write about referencing game objects, finding them according to their names, tags, and types. But let me give you the answer to the question at the title briefly.
In Unity3D, we can find game objects according to their names, tags, and types. For these purposes, we use the following methods respectively: GameObject.Find( ), GameObject.FindWithTag( ) and Object.FindObjectOfType(). These methods will return only one game object. Additionally, it is also possible to find all the game objects that have the same tag or are in the same type, using GameObject.FindGameObjectsWithTag( ) and Object.FindObjectsOfType( ). These methods will return arrays of game objects.
Contents
- Referencing game objects in Unity3D
- What is referencing?
- How do you reference a game object in Unity3D?
- How to find game objects by their names
- Finding a game object that has a specific tag
- Getting the array of all game objects that have the same tag
- Finding a game object that matches a specific type
- Getting the array of all game objects that matches a specific type
- How to find a child game object
- Further remarks
Referencing game objects in Unity3D
What is referencing?
Most of the time, we want to access other game objects and their components. Hence, we can gather information about them when it is required, send information to them, control their behaviors, or execute a method that is in a script that is attached to them. In these cases, we need an address(or let’s say a phone number) of the game object and thus, we can dial whenever we want. This is called referencing.
While developing games in Unity3D, we always reference other game objects or components. Therefore, this is a fundamental topic you should understand before you go further.
How to create references to game objects or components
First of all, we have to declare variables that will store the address of the game objects or components. And hence, whenever we would like to access the properties of these game objects or components, we use these variables.
GameObject myGameObject; GameObject herGameObject; GameObject hisGameObject;
In the code above, we declared two variables in type GameObject but we have not assigned any object them yet. You may consider this as if we are reserving empty rows in an address book that we will fill them out later.
To reference these variables, we have a couple of options. We can search the game object that we want to assign using built-in methods that are included in Unity. We will see this option in later sections of this article. Another option is to assign relevant game objects directly in the Unity editor. But to do this we have to declare the objects either public or private with [SerializeField] attribute.
GameObject myGameObject; public GameObject herGameObject; [SerializeField]private GameObject hisGameObject;
In the code above, the first variable is declared as private(you can put the private keyword in front of it as well if you want), the second variable is declared as public and the third variable is declared as private with [SerializeField] attribute. [SerializeField] attribute makes this variable visible in the editor but still inaccessible from other scripts.
Now, you can drag and drop the game objects, that you would like to assign, to the slots that are visible in the inspector.
If you would like to create references to the components that are associated with the game objects, you need to declare variables that are in the type of that component.
Rigidbody rigidbodyComponent; BoxCollider boxColliderComponent;
How to find game objects by their names
As I mentioned above, we can create references to game objects and components by searching and finding them using built-in methods in Unity. This is useful especially when you want to stay the variable private or when you want to access an object that is created during runtime.
In order to search for a game object that has a specific name in the scene, we have to use the method GameObject.Find( ). It takes a string parameter. And this parameter is the name of the game object that we want to find.
myGameObject = GameObject.Find("Sphere");
In the code above, we created a reference for the game object that has the name “Sphere”.
If you would like to access a component that is attached to this game object, you should create a reference for that component. For instance, the following creates a reference for a rigidbody component that is attached to this game object, and hence you can access the properties of this component.
rigidbodyComponent = GameObject.Find("Sphere").GetComponent<Rigidbody>();
Finding a game object that has a specific tag
In addition to finding an object by its name, we can also find it by its tag which we are able to determine objects in the scene.
To find a game object that has a specific tag, we use the method GameObject.FindWithTag( ). This method takes a string parameter and searches for it (There is one more method that does the same job. You can also use GameObject.FindGameObjectWithTag( ) for the same purpose).
myGameObject = GameObject.FindWithTag("Player");
A tag can be used either for only one object or multiple objects. If there is more than one object that has the same tag, this method returns only one of them.
Getting the array of all game objects that have the same tag
If there are multiple objects that have the same tag and we want to get them all, we need to use the method GameObject.FindGameObjectsWithTag( ). Likewise, this method also takes a string parameter and returns an array of all game objects. Therefore, we have to declare an array that will store the game objects.
GameObject[] cubes;
The following returns and assigns all objects that have the tag “Cube”.
cubes = GameObject.FindGameObjectsWithTag("Cube");
Finding a game object that matches a specific type
We can also search and find a game object that matches a specific type. In other words, for instance, we can get a game object or component that has a specific component. To do this, we use the method Object.FindObjectOfType( ). This method also returns only one of the objects.
The following one finds a light component and creates a reference to it.
Light mainLight = (Light)FindObjectOfType(typeof(Light));
Getting the array of all game objects that match a specific type
If there are multiple game objects that match a specific type, we can find all of them and create references in an array. For this purpose, we use the method Object.FindObjectsOfType( ). This is an example of how we use it:
var sphereCollider = FindObjectsOfType(typeof(SphereCollider));
How to find a child game object
In order to find a child object and create a reference to that child object we can use the method Transform.Find( ). This method takes a string parameter and returns the child game object that the name matches this parameter.
Assume that there is a game object in the scene that has a tag “Player”. And also assume that this player object has a child game object which has the name “Gun”. If we want to create a reference for the “Gun” object, we may do this as the following:
GameObject gun=GameObject.FindWithTag("Player").transform.Find("Gun");
This is useful especially if there are multiple objects that has the same name under different objects.
Further remarks
In this article, we see different ways of how we reference game objects in Unity3D. Here, I need to warn you that searching and finding methods are extremely slow and you should avoid using them in Update, FixedUpdate, or LateUpdate methods, if possible. We generally use them in Start or Awake methods. You may also consider creating references in Singleton’s to improve performances. We have various tutorials about the Unity3D Engine that you can see in this link.
Синтаксис
- public static GameObject Find (имя строки);
- public static GameObject FindGameObjectWithTag (строковый тег);
- public static GameObject [] FindGameObjectsWithTag (строковый тег);
- public static Object FindObjectOfType (тип типа);
- public static Object [] FindObjectsOfType (Тип типа);
замечания
Какой метод использовать
Будьте осторожны при поиске GameObjects во время выполнения, поскольку это может быть ресурсоемким. В частности: не запускайте FindObjectOfType или найдите в Update, FixedUpdate или, в более общем плане, в методе, называемом одним или несколькими моментами на кадр.
- Вызовите методы выполнения
FindObjectOfType
иFind
только в случае необходимости -
FindGameObjectWithTag
имеет очень хорошую производительность по сравнению с другими методами на основе строк. Unity хранит отдельные вкладки на помеченных объектах и запрашивает их вместо всей сцены. - Для «статических» GameObjects (таких как элементы пользовательского интерфейса и сборные файлы), созданных в редакторе, используйте сериализуемую ссылку GameObject в редакторе
- Храните свои списки GameObjects в списке или массивах, которыми вы управляете сами
- В общем случае, если вы создаете экземпляр множества GameObjects того же типа, взгляните на Object Pooling
- Кэш ваших результатов поиска, чтобы избежать дорогостоящих методов поиска снова и снова.
Идти глубже
Помимо методов, которые приходят с Unity, относительно легко разработать собственные методы поиска и сбора.
-
В случае
FindObjectsOfType()
вас могут быть ваши скрипты, которые хранят список вstatic
коллекции. Гораздо быстрее перебирать готовый список объектов, чем искать и проверять объекты со сцены. -
Или создайте скрипт, который хранит их экземпляры в
Dictionary
основе строк, и у вас есть простая система тегов, которую вы можете расширить.
Поиск по названию GameObject
var go = GameObject.Find("NameOfTheObject");
Pros | Cons |
---|---|
Легко использовать | Производительность ухудшается по количеству игровых объектов в сцене |
Строки – это слабые ссылки и подозрения на ошибки пользователя |
Поиск по тегам GameObject
var go = GameObject.FindGameObjectWithTag("Player");
Pros | Cons |
---|---|
Возможность поиска как отдельных объектов, так и целых групп | Строки – это слабые ссылки и подозрения на ошибки пользователя. |
Относительно быстрый и эффективный | Код не переносится, поскольку теги жестко закодированы в сценариях. |
Вставка в сценарии в режиме редактирования
[SerializeField]
GameObject[] gameObjects;
Pros | Cons |
---|---|
Отличное выступление | Коллекция объектов статическая |
Портативный код | Может ссылаться только на GameObjects с той же сцены |
Поиск GameObjects с помощью скриптов MonoBehaviour
ExampleScript script = GameObject.FindObjectOfType<ExampleScript>();
GameObject go = script.gameObject;
FindObjectOfType()
возвращаетnull
если ни один не найден.
Pros | Cons |
---|---|
Сильно напечатан | Производительность ухудшается по количеству игровых объектов, необходимых для оценки |
Возможность поиска как отдельных объектов, так и целых групп |
Transform tr = GetComponent<Transform>().Find("NameOfTheObject");
GameObject go = tr.gameObject;
Find
возвращаетnull
если ни один не найден
Pros | Cons |
---|---|
Ограниченная, четко определенная область поиска | Строки – слабые ссылки |