타이머 렌더링:
타이머 사용법:
첫 번째 유형: 추가 개체에 스크립트를 적용하고 "자동 타이밍"을 확인하세요.
두 번째 유형: 개체에 스크립트를 추가하고 타이머.start() 메서드를 호출하여 시작합니다.
세 번째 방법: 코드에 Timer 스크립트를 동적으로 추가합니다.
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…… } }
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) {}
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(); } }
# 🎜🎜#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); } }관련 기사:
PEAR::Benchmarking의 타이머를 사용하여 PHP 프로그램 타이밍 구현# 🎜🎜#
순수 PHP를 사용하여 타이머 작업(타이머), 타이머 타이머를 구현하는 방법# 🎜🎜#자바스크립트 오디오 계산기 예제로 재생
위 내용은 Unity 타이머 스크립트 Timer(코드 포함) 사용에 대한 간략한 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

C# .NET 개발을 시작하려면 다음과 같은 것이 필요합니다. 1. C#의 기본 지식과 .NET 프레임 워크의 핵심 개념을 이해하십시오. 2. 변수, 데이터 유형, 제어 구조, 기능 및 클래스의 기본 개념을 마스터하십시오. 3. LINQ 및 비동기 프로그래밍과 같은 C#의 고급 기능을 배우십시오. 4. 일반적인 오류에 대한 디버깅 기술 및 성능 최적화 방법에 익숙해 지십시오. 이러한 단계를 통해 C#.NET의 세계를 점차적으로 침투하고 효율적인 응용 프로그램을 작성할 수 있습니다.

C#과 .NET의 관계는 분리 할 수 없지만 같은 것은 아닙니다. C#은 프로그래밍 언어이며 .NET은 개발 플랫폼입니다. C#은 코드를 작성하고 .NET의 중간 언어 (IL)로 컴파일하고 .NET 런타임 (CLR)에 의해 실행되는 데 사용됩니다.

C#.NET은 여러 응용 프로그램 개발을 지원하는 강력한 도구 및 라이브러리를 제공하기 때문에 여전히 중요합니다. 1) C#은 .NET 프레임 워크를 결합하여 개발 효율적이고 편리하게 만듭니다. 2) C#의 타입 안전 및 쓰레기 수집 메커니즘은 장점을 향상시킵니다. 3) .NET은 크로스 플랫폼 실행 환경과 풍부한 API를 제공하여 개발 유연성을 향상시킵니다.

C#.NETISVERSATILEFORBOTHWEBBANDDESKTOPDEVENTROMMENT.1) FORWEB, useASP.NETFORRICHINTERFACES.3) FORDESKTOP.3) USEXAMARINFORCROSS-PLATFORMDEEVENTRIMMENT, LINABILEDEV, MACODEDEV, and MACODEDOWS, 및 MACODEDOWS.

C# 및 .NET는 지속적인 업데이트 및 최적화를 통해 신흥 기술의 요구에 적응합니다. 1) C# 9.0 및 .NET5는 레코드 유형 및 성능 최적화를 소개합니다. 2) .NETCORE는 클라우드 네이티브 및 컨테이너화 된 지원을 향상시킵니다. 3) ASP.NETCORE는 최신 웹 기술과 통합됩니다. 4) ML.NET는 기계 학습 및 인공 지능을 지원합니다. 5) 비동기 프로그래밍 및 모범 사례는 성능을 향상시킵니다.

C#.netissuitable forenterprise-levelapplications는 richlibraries, androbustperformance, 그러나 itmaynotbeidealforcross-platformdevelopmentorwhenrawspeediscritical, wherelanguagesslikerustorthightordogrordogrognegrognegrognegrognecross-platformdevelopmentor.

.NET에서 C#의 프로그래밍 프로세스에는 다음 단계가 포함됩니다. 1) C# 코드 작성, 2) 중간 언어 (IL)로 컴파일하고 .NET 런타임 (CLR)에 의해 실행됩니다. .NET에서 C#의 장점은 현대적인 구문, 강력한 유형 시스템 및 .NET 프레임 워크와의 긴밀한 통합으로 데스크탑 응용 프로그램에서 웹 서비스에 이르기까지 다양한 개발 시나리오에 적합합니다.

C#은 Microsoft가 개발 한 최신 객체 지향 프로그래밍 언어이며 .NET 프레임 워크의 일부로 개발되었습니다. 1.C#은 캡슐화, 상속 및 다형성을 포함한 객체 지향 프로그래밍 (OOP)을 지원합니다. 2. C#의 비동기 프로그래밍은 응용 프로그램 응답 성을 향상시키기 위해 비동기 및 키워드를 기다리는 키워드를 통해 구현됩니다. 3. LINQ를 사용하여 데이터 컬렉션을 간결하게 처리하십시오. 4. 일반적인 오류에는 NULL 참조 예외 및 인덱스 외 예외가 포함됩니다. 디버깅 기술에는 디버거 사용 및 예외 처리가 포함됩니다. 5. 성능 최적화에는 StringBuilder 사용 및 불필요한 포장 및 Unboxing을 피하는 것이 포함됩니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

Dreamweaver Mac版
시각적 웹 개발 도구
