SchultzGames
Para tirar dúvidas, crie um tópico especifico na área "Dúvidas em Geral" e aguarde ser respondido. Evite comentar em tópicos não relacionados a sua dúvida :D
TÓPICOS RECENTES:
Tópico:
Postado em:
Postado por:
Mini Quarteirão com Texturas 3D VENDA
Controle do braço e cabeça no fps
Jogo multiplayer com steam
PRECISO FAZER QUE MEU GAME FIQUE ONLINE
Como resolver vazamento de memoria?
Procuro Pessoas para Projeto
Ativar o objeto correto em Clones.
[TUTORIAL] Como fazer um interruptor simples (Unity 2018)
Unity-RawImages e Renderizção c/ Câmera Jogo Lento e travnado. Alguém pfv?!
Preciso de 20 testadores jogo mobile
O Labirinto II - Trailer Oficial
Ue posso divulgar meu game que ainda esta em criaçao aqui no forum?
[RESOLVIDO] Inverter o sprite para a direçao que o personagem anda.
Set Active não a reabiilitado C#
Build APK VR Google Cardbord com video.
[PROGRAMADOR FREELA] $$
Mais Um jogo!
Collider (mesh?)
[TUTORIAL] Deformar mesh com batidas (para objetos, veículos, etc)
WW2 Low poly Pack (Free)
Procuro freelancer
Novo Teaser do jogo Dark Age
Unity Admob Erro
DEATH ISLAND 0.2.5 SURVIVAL GAME 4 ANOS EM DESENVOLVIMENTO
Player travando na colisão com o chão Unity 2D
Sombras estão quadradas na build
nao consigo fazer o player sentar no sofa alguem me ajuda
Unity - Ao mudar de scene, todas as Lights são deletadas
210 Linhas de código para inimigo é muito grande?
modelar avatar e skins para um jogo web
ShapeKeys do Blender para a Unity altera áreas próximas
COMO EVITAR QUE UM OBJETO (PLAYER,ITEM ETC...) ATRAVESSE UMA PAREDE.
Ajuda em Script de Verificação de Ação e Reação
unity Failed to load PlayerSettings (internal index #0). Most likely data f
Materiais do Blander não aparecem no MeshRendere do Objeto na Unity
Repetiçoes de Textura no Terreno
SERVER IS DOWN - UNITY+MSQL
Procuro programadores - Novo jogo
Problema com o MS VEHICLES
Preciso de ajuda com a Unity
Problema com vídeo em 360° na Unity
Problemas no MS Vehicles
unity- eventos na Animação com Armature/Bones vinda do blender não funciona
ajuda exibir resultados simulados em uma liga Game Unity
Unity - ParticleSystem não é redirecionado no rawimage no canvas
Como resolver o problema de "face orientation" no Blender.
[DÚVIDA] Tive um problema com meu Canvas
erro na Directional Light
Problemas com o Directional Light da Unity 3D
Novo jogo da franquia Sphere game em desenvolvimento
malha da roda não girando com wheel collider unity
Problemas com ambiguidade
Touch mobile
INVALID TOKEN
Como acessar o "HD Render Pipeline" do HDRP por script?
CHAT GPT PRA JOGO DE TIRO? comentem
Tutorial script inimigo segue e foge do player
Ainda vale a pena lançar Asset na Asset Store?
Ajuda com tabela de historico de pontuaçao.
[TUTORIAL] Entrar no carro estilo GTA
Como derrapar um Whell Collider
Como altertar o valor do "Asymptote Value" do Whell Collider via Script
Preciso de ajuda para substituir valor de variavel em outro script
Ajuda com Top Down Shooter utilizando Photon
Duvida com Netcode
[RESOLVIDO] Unity - Movendo a Câmera na Horizontal/Vertical com Touch
Alguém me ajuda com os anúncios pfv
Segundo Trailer do jogo Dark Age, Feliz Natal a todos!
Unity - ScrollRect, Viewport, Content - O Conteúdo ñ inicia no topo
Coleta de itens
Unity - Cadastro do email do jogador
[GRATIS] PACK DE MODELOS 3D PARA JOGO DE TERROR
Onde Conseguir músicas para meu Jogo?
error CS0246 em Script
Alguem teve ja esse problema?
[Projeto em Andamento] Draug, um jogo de hordas
DISPONIVEL PARA FAZER MODELOS 3D
Unity-Loja.Como os Jogadores terão acesso aos ítens comprados na PlayStore?
Bugando depois do Build.
Primeiro Trailer do jogo Dark Age
Problema com sombra
Mesh e Material do objeto trocando para uma instancia no inicio do jogo
[RESOLVIDO] Unity - RawImages_Layer_Camera
INVESTIMENTO EM JOGOS E BANCO DE TALENTO
Teaser do meu novo projeto pessoal, Dark Age
Preciso de ajuda com mudança para mobile androide.
[RESOLVIDO] Posição final do objeto em jogo 2D
Input.GetAxis() obedercer a orientação de um objeto.
Interação com elementos UI
Meu primeiro jogo na steam
Minimap/Radar/GPS Estilo GTA V
[RESOLVIDO] Erro no console depois que formatei o pc
PACK GRÁTIS de Músicas ELETRÔNICAS para ajudar vocês em seus Jogos Indies!
[TUTORIAL] Entenda como funciona: ENUM, SWITCH, BREAK, CASE no C#
O Labirinto II - Baixe o Jogo
Qual e o codigo de Botões na unity para saber seus estados?
Como carregar itens pequenos dentro do carro sem que atravesse os colliders
[Duvida] Script pegar itens
Travamento ao trocar de cena
Ontem à(s) 9:50 pm
Dom Jul 21, 2024 7:07 pm
Dom Jul 21, 2024 6:29 pm
Dom Jul 21, 2024 12:07 am
Seg Jul 15, 2024 7:02 pm
Dom Jul 14, 2024 11:24 pm
Sáb Jul 13, 2024 12:33 am
Qui Jun 27, 2024 5:49 pm
Sáb Jun 22, 2024 9:05 pm
Qui Jun 20, 2024 12:30 pm
Dom Jun 09, 2024 7:43 pm
Dom Jun 09, 2024 2:16 pm
Seg Jun 03, 2024 11:39 am
Seg maio 27, 2024 12:45 pm
Seg maio 20, 2024 9:01 pm
Dom maio 19, 2024 3:08 pm
Sáb maio 18, 2024 11:46 am
Sáb maio 11, 2024 8:55 am
Qui maio 09, 2024 11:33 pm
Seg Abr 29, 2024 9:34 pm
Qui Abr 25, 2024 3:34 pm
Seg Abr 22, 2024 5:15 pm
Seg Abr 15, 2024 12:23 pm
Qua Abr 10, 2024 1:33 am
Ter Abr 09, 2024 10:28 am
Seg Abr 08, 2024 9:27 pm
Seg Abr 08, 2024 8:01 am
Sáb Abr 06, 2024 8:05 pm
Qui Abr 04, 2024 11:34 pm
Qui Abr 04, 2024 11:13 pm
Sex Mar 22, 2024 2:41 pm
Dom Mar 10, 2024 2:30 pm
Sex Mar 01, 2024 1:27 pm
Qui Fev 22, 2024 9:57 pm
Ter Fev 20, 2024 12:15 am
Seg Fev 19, 2024 1:06 pm
Seg Fev 12, 2024 1:56 pm
Seg Fev 12, 2024 1:17 pm
Dom Fev 11, 2024 8:55 pm
Dom Fev 11, 2024 11:16 am
Seg Fev 05, 2024 4:18 pm
Dom Fev 04, 2024 9:39 pm
Qua Jan 31, 2024 11:59 pm
Ter Jan 30, 2024 7:37 pm
Ter Jan 23, 2024 6:33 pm
Dom Jan 21, 2024 6:03 pm
Sáb Jan 20, 2024 7:03 pm
Sáb Jan 20, 2024 6:58 pm
Sáb Jan 20, 2024 6:39 pm
Sex Jan 19, 2024 8:40 am
Dom Jan 14, 2024 5:30 pm
Qua Jan 10, 2024 10:29 pm
Qua Jan 10, 2024 8:55 pm
Qua Jan 10, 2024 7:14 pm
Ter Jan 09, 2024 3:55 pm
Ter Jan 09, 2024 8:04 am
Sáb Jan 06, 2024 8:02 pm
Sex Jan 05, 2024 7:01 am
Sex Jan 05, 2024 12:12 am
Qui Jan 04, 2024 6:55 pm
Qui Jan 04, 2024 12:52 pm
Qui Jan 04, 2024 4:34 am
Ter Jan 02, 2024 11:48 pm
Dom Dez 31, 2023 7:25 pm
Qua Dez 27, 2023 5:44 pm
Qua Dez 27, 2023 3:08 pm
Sáb Dez 23, 2023 7:27 pm
Sáb Dez 23, 2023 5:06 pm
Qui Dez 21, 2023 8:10 pm
Seg Dez 18, 2023 2:04 pm
Sex Dez 15, 2023 5:11 pm
Qui Dez 14, 2023 9:13 pm
Qui Dez 14, 2023 2:47 pm
Qui Dez 14, 2023 1:48 pm
Qua Dez 13, 2023 8:58 pm
Ter Dez 12, 2023 2:32 pm
Seg Dez 11, 2023 1:53 pm
Qua Dez 06, 2023 8:13 pm
Sáb Dez 02, 2023 8:06 pm
Qui Nov 30, 2023 7:49 am
Seg Nov 27, 2023 1:35 am
Qua Nov 22, 2023 7:37 am
Qui Nov 09, 2023 1:22 pm
Seg Nov 06, 2023 11:59 am
Ter Out 31, 2023 9:53 am
Dom Out 29, 2023 8:05 pm
Dom Out 29, 2023 3:03 am
Sex Out 27, 2023 3:43 pm
Sex Out 27, 2023 3:28 pm
Qua Out 25, 2023 1:20 pm
Seg Out 23, 2023 10:34 am
Dom Out 22, 2023 6:55 pm
Qui Out 19, 2023 11:57 pm
Qui Out 19, 2023 6:39 pm
Ter Out 17, 2023 6:37 pm
Ter Out 17, 2023 6:18 pm
Seg Out 16, 2023 1:59 pm
Sáb Out 14, 2023 12:15 pm
Qua Out 11, 2023 6:07 pm



































































































[AULA] Update, Start, FixedUpdate, e etc.. Diferença entre eles!

Ir para baixo

TUTORIAL [AULA] Update, Start, FixedUpdate, e etc.. Diferença entre eles!

Mensagem por MayLeone Qui Dez 03, 2020 7:16 pm

Olá pessoal, bem vindos a mais um tutorial da série "Guia rápido de programação em Unity".

No tutorial anterior, nós vimos como utilizar algumas das funções mais recorrentes da API da Unity. Hoje irei dar continuidade à série explicando sobre algo muito relevante em relação à engine: A ordem de execução de eventos.



O que são eventos:
Antes de entrarmos de fato nesse assunto, vou explanar rapidamente o que seriam os tais "eventos".

Em programação orientada a eventos, um event (evento) nada mais é que uma função como outra qualquer, com a diferença na forma como ela é chamada.

Funções "comuns" são chamadas "manualmente", como fizemos com todas as funções do tutorial anterior, ou seja, são chamadas em tempo de compilação.

Já no caso de eventos, eles podem ser chamados em momentos específicos, no caso da Unity, a própria engine fica encarregada de gerenciar essas chamadas de alguns eventos específicos de sua API, ou seja, nós como usuários não temos controle de quando eles(os eventos) serão invocados, pois eles são chamados em tempo de execução.

Podemos ter eventos que são chamados quando passamos o mouse sobre algum objeto, outro evento que é invocado quando clicamos com o lado esquerdo do mouse, ou até mesmo quando alteramos um campo dentro de um componente de UI (vide o InputField, por exemplo).

Perceba que nós como usuários da Unity não temos um real controle de quando essas funções são chamadas, quem se encarrega de gerenciar tais eventos, é a própria engine.

Eventos de inicialização:
Dito isto, perceba que sempre que criamos um novo script na Unity, o nosso código além de fazer referencia às bibliotecas necessárias, definir a classe do script e a herança do MonoBehaviour, ainda por cima sempre declara duas funções padrões: Start e Update.

Por conta de suas chamadas serem realizadas a partir da engine, que é responsável por gerenciar essas ações, podemos classificar ambas funções como eventos.

Sabemos que o Start é chamado quando o objeto é inicializado, e que o Update é chamado muitas vezes por segundo, mas será que é só isso?

Além do Start, ainda temos outros dois eventos responsáveis pela inicialização de Game Objects, são eles: Awake e OnEnable.

Na verdade, esses dois eventos são chamados ANTES do Start. A ordem de execução destes eventos de inicialização é esta:



[AULA] Update, Start, FixedUpdate, e etc.. Diferença entre eles! E50986bcbd071e13f67722d9f4e2eab4




Awake: O evento Awake é chamado assim que o objeto é instanciado e ativado em cena, no primeiro frame de carregamento. É o primeiro evento de inicialização a ser invocado.

Ele é chamado apenas uma vez, a não ser que se recarregue a cena ou que a mesma seja carregada de forma aditiva.

Se o Game Object que contiver o Awake estiver desativado, e depois ser ativado, ele vai invocar o Awake (pela primeira vez), porém, caso o script que contenha o evento Awake estiver desativado, o Awake será chamado mesmo assim.

Essa é uma grande confusão que ocorre às vezes: Existe uma diferença entre desativar/ativar o Game Object em si, e algum script/componente que ele comporte: O Awake é chamado assim que o Game Object for ativado, porém, ele será invocado MESMO que o script que o contenha estiver desativado.

Utilize o Awake como inicializador para o próprio script, seja para inicializar variáveis ou obter componentes dependentes. É como se fosse o construtor de classes "nativas" do C#.

Exemplo de uso:

C #:

Código:
private void Awake()
{
// Obtendo componentes dependentes:
        _objectRigidbody = GetComponent<Rigidbody>();

        // Inicializando valores de variáveis:
        _characterLife = 10;
_isAlive = true;
    }

Documentação oficial: https://docs.unity3d.com/ScriptReference/MonoBehaviour.Awake.html


OnEnable: É invocado assim que o objeto é ativado em cena e o seu script habilitado, porém, após a chamada do Awake.

Toda vez que o script é inabilitado e depois habilitado novamente, o OnEnable será chamado, assim como quando o Game Object for desativado e ativado, ele novamente será invocado, ao contrário do Awake que é chamado apenas uma vez durante o ciclo de vida do script.

Você pode utilizar esse evento para gerenciar algo que ocorre toda vez que o objeto ou o script são ativados (como a reinicialização de variáveis, por exemplo):

C #:

Código:
using UnityEngine;

public class Test : MonoBehaviour
{
    public int example;

    private void OnEnable()
{
example = 0;
    }

    private void Update()
{
example++;
    }

}


No exemplo acima, a variável "example" é setada com o valor zero quando o Game Object é ativado, a partir daí o Update incrementa esse valor. Quando você desativa o script ou o Game Object e o reativa, a variável "example" é resetada para o valor zero novamente.



Documentação oficial: https://docs.unity3d.com/ScriptReference/MonoBehaviour.OnEnable.html

Start: O evento Start é chamado apenas uma vez, após o Awake e o OnEnable.
Ele é chamado assim que o Game Object está ativo em cena e o script que o contém esteja habilitado.
Você pode utilizar esse evento para inicializar a comunicação com objetos ou scripts externos, que já tiverem a sua inicialização através do Awake.
Dessa forma, você tem dois momentos para controlar uma inicialização, caso necessite, se a ordem de inicialização de algum componente, objeto, ou valor importe.
Você pode "atrasar" a inicialização do Start através de Coroutines, por exemplo:

C #:

Código:
using UnityEngine;
using System.Collections;

public class Test : MonoBehaviour
{
private IEnumerator Start()
{
yield return new WaitForSeconds(3);
Debug.Log("Atrasando a chamada do Start");
}
}

No caso do exemplo acima, o Start será chamado após 3 segundos.

Documentação oficial: https://docs.unity3d.com/ScriptReference/MonoBehaviour.Start.html

Eventos de Atualização:

Agora vamos falar um pouco sobre os eventos que são invocados em dependência da taxa de frames do jogo/projeto:



[AULA] Update, Start, FixedUpdate, e etc.. Diferença entre eles! Ca71645a9bbc9414ba348fde0189376a




FixedUpdate: Este evento é chamado num controle fixo de frames per second, estipulado pela engine de física da Unity.

Ele pode ser chamado com mais frequência que o Update, ou com menos frequência (por isso o fluxograma acima pode às vezes ser invertido em alguns casos), pois nós podemos definir a taxa de quadros em que o FixedUpdate poderá ser chamado.

Para alterar a taxa de chamadas do FixedUpdate vá em >> Edit >> Project Settings >> Time >> Fixed TimeStep.

Por padrão o "TimeStep" é definido por 0.02, ou seja, o evento será chamada à cada 0.02 segundos.

A utilização do FixedUpdate é recomendada quando queremos gerenciar principalmente componentes de física, como o Rigidbody, por exemplo, pois como ele é chamado numa taxa fixa e precisa, não teremos problemas de irregularidades em cálculos da física do jogo (como aplicar a força num objeto de formas inconstantes à cada quadro):

C #:

Código:
using UnityEngine;

[RequireComponent(typeof(Rigidbody))]
public class Test : MonoBehaviour
{
public float jumpForce;
private bool isJumping;
    private Rigidbody _objectRigidbody;

    private void Awake()
{
isJumping = false;
_objectRigidbody = GetComponent<Rigidbody>();
    }

    private void Update()
{
isJumping = Input.GetKeyDown(KeyCode.Space);
    }

    private void FixedUpdate()
{
if (isJumping)
_objectRigidbody.AddForce(Vector2.up * jumpForce);
}
}

O código acima se trata de um script bem simples de pulo, onde quando o jogador pressionar "Space" o objeto receberá uma força sob seu rigidbody na direção pra cima. Perceba que a ação de física "adicionar força a um corpo rígido" está sendo realizada dentro do FixedUpdate.

Documentação oficial: https://docs.unity3d.com/ScriptReference/MonoBehaviour.FixedUpdate.html

Update: O evento de Update é muito utilizado em jogos, pois é um evento que será chamado muitas vezes por segundo.

No caso da Unity, o Update é chamado dependendo do frame per second do jogo, ele será chamado uma vez a cada quadro, logo, se o jogo está rodando à 60 fps, ele será chamado 60 vezes por segundo.

Utilizamos o Update quando queremos verificar ou validar algo que deva estar em constante observação, como o momento em que alguma tecla é pressionada durante o jogo para realizar alguma ação. A tecla pode ser pressionada a qualquer momento, por isso este tipo de verificação deve estar dentro de um evento de Update.

Por conta de suas chamadas inconstantes (depende muito do fps do jogo), não é recomendável utilizar comandos que necessitem de uma maior precisão, como cálculos de física, por exemplo, dentro do Update. Para estes fins você deve sempre estar multiplicando os valores a serem calculados por um fator multiplicador que irá tentar "padronizar" essa irregularidade de chamadas, no caso, temos o campo "deltaTime" acessado através da classe "Time".

Porém, é muito mais simples utilizar o FixedUpdate para estes casos, como visto acima.

C #:

Código:
using UnityEngine;

public class Test : MonoBehaviour
{
private void Update()
{
if (Input.GetKeyDown(KeyCode.Space))
            Debug.Log($"A tecla {KeyCode.Space.ToString()} foi pressionada");

        if (Input.GetKeyUp(KeyCode.Space))
Debug.Log($"A tecla {KeyCode.Space.ToString()} deixou de ser pressionada");
}
}

No código acima, o Update detecta quando o jogador pressiona ou deixa de pressionar a tecla "Space" e emite uma mensagem para cada ação.

Documentação oficial: https://docs.unity3d.com/ScriptReference/MonoBehaviour.Update.html

LateUpdate: Este evento é chamado sempre após o Update, e isso é algo positivo caso queiramos manter alguma ordem de execução para alguma ação (como no caso dos inicializadores).
A própria documentação da Unity sugere que o LateUpdate é perfeito para gerenciar o movimento de câmeras, visto que o Update/FixedUpdate será responsável por movimentar o personagem, o LateUpdate é chamado logo em seguida, ajustando a câmera após a movimentação do player.

Documentação oficial: https://docs.unity3d.com/ScriptReference/MonoBehaviour.LateUpdate.html

*Todos os eventos de Frame-Rate serão chamados apenas enquanto o objeto estiver ativo em cena, e o script habilitado.

Eventos de destruição:

Existem dois eventos que gerenciam as ações para GameObjects que serão desativados ou destruídos:



[AULA] Update, Start, FixedUpdate, e etc.. Diferença entre eles! 2ab907bafc21985b6f7203d454b72408




OnDisable: Este evento será chamado assim que o objeto se tornar inativo, ou seu script desabilitado, sendo oposto ao OnEnable.
O OnDisable também será chamado assim que o objeto ou seu script/componente for destruído (tanto por conta de funções como "Destroy", quanto quando a cena se encerrar).

C #:

Código:
using UnityEngine;

public class Test : MonoBehaviour
{
private void OnDisable()
{
Debug.Log("Objeto desabilitado");
}
}

OnDestroy: O evento "OnDestroy" será chamado assim que o objeto for destruído ou seu script/componente, após a chamada do "OnDisable".

Isso lhe dará uma ordem de execução para a destruição do objeto, assim como no caso dos inicializadores, se a ordem de chamadas para tal ação for importante, por exemplo.

Exemplo de uso do OnDestroy:

C #:

Código:
using UnityEngine;

public class Test : MonoBehaviour
{
    public GameObject _explosionAnimation;

    private void OnDestroy()
{
Instantiate(_explosionAnimation,
this.transform.position, Quaternion.identity);
}
}

No exemplo acima, quando o Game Object for destruído, um prefab contendo uma animação de explosão será instanciado na mesma posição que o objeto destruído.

Documentação oficial: https://docs.unity3d.com/ScriptReference/MonoBehaviour.OnDestroy.html

Lembrete:
*Lembrando que os eventos mostrados neste tutorial só serão invocados de forma correta, caso estejam contidos dentro de uma classe que herde de MonoBehaviour, pois é a partir desta classe que a Unity pode gerenciar a chamada destes eventos, e também é a partir deste tipo de classe que os scripts se tornam componentes, sendo assim, sua inicialização, atualização e destruição só poderão ocorrer quando estiverem contidos num objeto em cena.
Você pode declarar funções com os nomes dos eventos aqui mostrados em classes que não herdem de MonoBehaviour, porém elas não vão funcionar da forma esperada (não serão chamadas como mostrado ao longo do tutorial) e isso não é considerado uma boa prática.

Finalização:
E aqui chega ao fim mais um tutorial sobre programação na Unity! Espero que este tutorial possa sanar de uma vez por todas as dúvidas que os usuários tanto iniciantes quanto avançados tem em relação a estes eventos, suas diferenças e ordem de execução.

Próximo tópico do guia >> "MonoBehaviour x Classes Nativas"
MayLeone
MayLeone
Instrutor

Feminino PONTOS : 3689
REPUTAÇÃO : 598
Áreas de atuação : Unity & C#
Respeito as regras : [AULA] Update, Start, FixedUpdate, e etc.. Diferença entre eles! Aad8pUi

http://compilemosfacil.blogspot.com.br

Ir para o topo Ir para baixo

Ir para o topo

- Tópicos semelhantes

 
Permissões neste sub-fórum
Não podes responder a tópicos