Heim Backend-Entwicklung C#.Net-Tutorial Kurze Analyse der Verwendung des Unity-Timer-Skripts Timer (mit Code)

Kurze Analyse der Verwendung des Unity-Timer-Skripts Timer (mit Code)

Jul 27, 2018 am 11:43 AM
c# unity

Timer-Rendering:
Kurze Analyse der Verwendung des Unity-Timer-Skripts Timer (mit Code)

Timer-Verwendung:
Erster Typ: Fügen Sie das Skript zum Objekt hinzu und aktivieren Sie „Automatisches Timing“. ".
Zweiter Typ: Fügen Sie das Skript zum Objekt hinzu und rufen Sie die Methode timer.start() auf, um es zu starten.
Die dritte Methode: Fügen Sie das Timer-Skript dynamisch zum Code hinzu.

using UnityEngine;

public class TimerTest : MonoBehaviour {

    private void Start () {
        // 创建一个Timer并开始计时
        gameObject.AddComponent<Timer>().start(1.5f, onTimeup);

        // 倒计时3秒
        gameObject.AddComponent<Timer>().start(1, 3, onCD, onCDEnd);

        // 无限计数(repeatCount为<=0时 无限重复)
        gameObject.AddComponent<Timer>().start(1, -1, onCount, null);

        // Timer API
        Timer timer = gameObject.AddComponent<Timer>();
        timer.delay = 10;// 延迟10秒开始
        timer.start();  // 开始计时
        timer.stop();   // 暂停计时
        timer.reset();  // 重置已计时的时间和次数
        timer.restart();// 重新开始计时 reset() + start()
    }

    /// <summary> 正常计时 </summary>
    private void onTimeup(Timer timer) {
        print("计时完成");
    }

    /// <summary> 倒计时间隔 </summary>
    private void onCD(Timer timer) {
        print(timer.repeatCount - timer.currentCount); // 3, 2, 1
    }

    /// <summary> 倒计时结束 </summary>
    private void onCDEnd(Timer timer) {
        print(timer.repeatCount - timer.currentCount); // 0
    }

    /// <summary> 无限计数 </summary>
    private void onCount(Timer timer) {
        print(timer.currentCount); // 1, 2, 3……
    }

}
Nach dem Login kopieren

Timer-API:

// 开始/继续计时
public void start() {}

// 暂停计时
public void stop() {}

// 停止Timer并重置数据
public void reset() {}

// 重置数据并重新开始计时
public void restart() {}

// 开始计时 time时间(秒) onComplete(Timer timer)计时完成回调事件
public void start(float time, TimerCallback onComplete) {}

// 开始计时 interval计时间隔 repeatCount重复次数 onComplete(Timer timer)计时完成回调事件
public void start(float interval, int repeatCount, TimerCallback onComplete) {}

// 开始计时 interval计时间隔 repeatCount重复次数
// onInterval(Timer timer)计时间隔回调事件
// onComplete(Timer timer)计时完成回调事件
public void start(float interval, int repeatCount, TimerCallback onInterval, TimerCallback onComplete) {}
Nach dem Login kopieren

Timer.cs

using UnityEngine;
using UnityEngine.Events;

/// <summary>
/// 计时器
/// <para>ZhangYu 2018-04-08</para>
/// </summary>
public class Timer : MonoBehaviour {

    // 延迟时间(秒)
    public float delay = 0;
    // 间隔时间(秒)
    public float interval = 1;
    // 重复次数
    public int repeatCount = 1;
    // 自动计时
    public bool autoStart = false;
    // 自动销毁
    public bool autoDestory = true;
    // 当前时间
    public float currentTime = 0;
    // 当前次数
    public int currentCount = 0;
    // 计时间隔
    public UnityEvent onIntervalEvent;
    // 计时完成
    public UnityEvent onCompleteEvent;
    // 回调事件代理
    public delegate void TimerCallback(Timer timer);
    // 上一次间隔时间
    private float lastTime = 0;
    // 计时间隔
    private TimerCallback onIntervalCall;
    // 计时结束
    private TimerCallback onCompleteCall;

    private void Start () {
        enabled = autoStart;
    }

    private void FixedUpdate () {
        if (!enabled) return;
        addInterval(Time.deltaTime);
    }

    /// <summary> 增加间隔时间 </summary>
    private void addInterval(float deltaTime) {
        currentTime += deltaTime;
        if (currentTime < delay) return;
        if (currentTime - lastTime >= interval) {
            currentCount++;
            lastTime = currentTime;
            if (repeatCount <= 0) {
                // 无限重复
                if (currentCount == int.MaxValue) reset();
                if (onIntervalCall != null) onIntervalCall(this);
                if (onIntervalEvent != null) onIntervalEvent.Invoke();
            } else {
                if (currentCount < repeatCount) {
                    //计时间隔
                    if (onIntervalCall != null) onIntervalCall(this);
                    if (onIntervalEvent != null) onIntervalEvent.Invoke();
                } else {
                    //计时结束
                    stop();
                    if (onCompleteCall != null) onCompleteCall(this);
                    if (onCompleteEvent != null) onCompleteEvent.Invoke();
                    if (autoDestory && !enabled) Destroy(this);
                }
            } 
        }
    }

    /// <summary> 开始/继续计时 </summary>
    public void start() {
        enabled = autoStart = true;
    }

    /// <summary> 开始计时 </summary>
    /// <param name="time">时间(秒)</param>
    /// <param name="onComplete(Timer timer)">计时完成回调事件</param>
    public void start(float time, TimerCallback onComplete) {
        start(time, 1, null, onComplete);
    }

    /// <summary> 开始计时 </summary>
    /// <param name="interval">计时间隔</param>
    /// <param name="repeatCount">重复次数</param>
    /// <param name="onComplete(Timer timer)">计时完成回调事件</param>
    public void start(float interval, int repeatCount, TimerCallback onComplete) {
        start(interval, repeatCount, null, onComplete);
    }

    /// <summary> 开始计时 </summary>
    /// <param name="interval">计时间隔</param>
    /// <param name="repeatCount">重复次数</param>
    /// <param name="onInterval(Timer timer)">计时间隔回调事件</param>
    /// <param name="onComplete(Timer timer)">计时完成回调事件</param>
    public void start(float interval, int repeatCount, TimerCallback onInterval, TimerCallback onComplete) {
        this.interval = interval;
        this.repeatCount = repeatCount;
        onIntervalCall = onInterval;
        onCompleteCall = onComplete;
        reset();
        enabled = autoStart = true;
    }

    /// <summary> 暂停计时 </summary>
    public void stop() {
        enabled = autoStart = false;
    }

    /// <summary> 停止Timer并重置数据 </summary>
    public void reset(){
        lastTime = currentTime = currentCount = 0;
    }

    /// <summary> 重置数据并重新开始计时 </summary>
    public void restart() {
        reset();
        start();
    }

}
Nach dem Login kopieren

TimerEditor.cs

using UnityEditor;
using UnityEngine;

/// <summary>
/// 计时器 编辑器
/// <para>ZhangYu 2018-04-08</para>
/// </summary>
[CanEditMultipleObjects]
[CustomEditor(typeof(Timer))]
public class TimerEditor : Editor {

    public override void OnInspectorGUI() {
        Timer script = (Timer)target;

        // 重绘GUI
        EditorGUI.BeginChangeCheck();

        // 公开属性
        drawProperty("delay", "延迟时间(秒)");
        drawProperty("interval", "间隔时间(秒)");
        drawProperty("repeatCount", "重复次数");
        if (script.repeatCount <= 0) EditorGUILayout.LabelField(" ", "<=0 时无限重复", GUILayout.ExpandWidth(true));
        EditorGUILayout.BeginHorizontal();
        drawProperty("autoStart", "自动计时");
        drawProperty("autoDestory", "自动销毁");
        EditorGUILayout.EndHorizontal();

        // 只读属性
        GUI.enabled = false;
        drawProperty("currentTime", "当前时间(秒)");
        drawProperty("currentCount", "当前次数");
        GUI.enabled = true;

        // 回调事件
        drawProperty("onIntervalEvent", "计时间隔事件");
        drawProperty("onCompleteEvent", "计时完成事件");
        if (EditorGUI.EndChangeCheck()) serializedObject.ApplyModifiedProperties();
    }

    private void drawProperty(string property, string label) {
        EditorGUILayout.PropertyField(serializedObject.FindProperty(property), new GUIContent(label), true);
    }

}
Nach dem Login kopieren

Verwandte Artikel:

PEAR::Benchmarking's Timer verwenden, um PHP-Programm-Timing zu implementieren

So verwenden Sie reines PHP, um Timer-Aufgaben zu implementieren ( Timer), Timer-Timer

Ähnliche Videos:

Beispiel für einen Javascript-Audiorechner spielen

Das obige ist der detaillierte Inhalt vonKurze Analyse der Verwendung des Unity-Timer-Skripts Timer (mit Code). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Active Directory mit C# Active Directory mit C# Sep 03, 2024 pm 03:33 PM

Leitfaden zu Active Directory mit C#. Hier besprechen wir die Einführung und die Funktionsweise von Active Directory in C# sowie die Syntax und das Beispiel.

C#-Serialisierung C#-Serialisierung Sep 03, 2024 pm 03:30 PM

Leitfaden zur C#-Serialisierung. Hier besprechen wir die Einführung, die Schritte des C#-Serialisierungsobjekts, die Funktionsweise bzw. das Beispiel.

Zufallszahlengenerator in C# Zufallszahlengenerator in C# Sep 03, 2024 pm 03:34 PM

Leitfaden zum Zufallszahlengenerator in C#. Hier besprechen wir die Funktionsweise des Zufallszahlengenerators, das Konzept von Pseudozufallszahlen und sicheren Zahlen.

C#-Datenrasteransicht C#-Datenrasteransicht Sep 03, 2024 pm 03:32 PM

Leitfaden zur C#-Datenrasteransicht. Hier diskutieren wir die Beispiele, wie eine Datenrasteransicht aus der SQL-Datenbank oder einer Excel-Datei geladen und exportiert werden kann.

Muster in C# Muster in C# Sep 03, 2024 pm 03:33 PM

Leitfaden zu Mustern in C#. Hier besprechen wir die Einführung und die drei wichtigsten Arten von Mustern in C# zusammen mit ihren Beispielen und der Code-Implementierung.

Fakultät in C# Fakultät in C# Sep 03, 2024 pm 03:34 PM

Leitfaden zur Fakultät in C#. Hier diskutieren wir die Einführung in die Fakultät in C# zusammen mit verschiedenen Beispielen und Code-Implementierungen.

Primzahlen in C# Primzahlen in C# Sep 03, 2024 pm 03:35 PM

Leitfaden zu Primzahlen in C#. Hier besprechen wir die Einführung und Beispiele von Primzahlen in C# sowie die Codeimplementierung.

Der Unterschied zwischen Multithreading und asynchronem C# Der Unterschied zwischen Multithreading und asynchronem C# Apr 03, 2025 pm 02:57 PM

Der Unterschied zwischen Multithreading und Asynchron besteht darin, dass Multithreading gleichzeitig mehrere Threads ausführt, während asynchron Operationen ausführt, ohne den aktuellen Thread zu blockieren. Multithreading wird für rechenintensive Aufgaben verwendet, während asynchron für die Benutzerinteraktion verwendet wird. Der Vorteil des Multi-Threading besteht darin, die Rechenleistung zu verbessern, während der Vorteil von Asynchron nicht darin besteht, UI-Threads zu blockieren. Die Auswahl von Multithreading oder Asynchron ist von der Art der Aufgabe abhängt: Berechnungsintensive Aufgaben verwenden Multithreading, Aufgaben, die mit externen Ressourcen interagieren und die UI-Reaktionsfähigkeit asynchron verwenden müssen.

See all articles