123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154 |
- using UnityEngine;
- using System.Collections;
- using System.Collections.Generic;
- using System;
- using System.Threading;
- using System.Linq;
- public class Loom : MonoBehaviour
- {
- public static int maxThreads = 8;
- static int numThreads;
- private static Loom _current;
- private int _count;
- public static Loom Current
- {
- get
- {
- Initialize();
- return _current;
- }
- }
- void Awake()
- {
- _current = this;
- initialized = true;
- }
- static bool initialized;
- static void Initialize()
- {
- if (!initialized)
- {
- if (!Application.isPlaying)
- return;
- initialized = true;
- var g = new GameObject("Loom");
- _current = g.AddComponent<Loom>();
- }
- }
- private List<Action> _actions = new List<Action>();
- public struct DelayedQueueItem
- {
- public float time;
- public Action action;
- }
- private List<DelayedQueueItem> _delayed = new List<DelayedQueueItem>();
- List<DelayedQueueItem> _currentDelayed = new List<DelayedQueueItem>();
- public static void QueueOnMainThread(Action action)
- {
- QueueOnMainThread(action, 0f);
- }
- public static void QueueOnMainThread(Action action, float time)
- {
- if (time != 0)
- {
- lock (Current._delayed)
- {
- Current._delayed.Add(new DelayedQueueItem { time = Time.time + time, action = action });
- }
- }
- else
- {
- lock (Current._actions)
- {
- Current._actions.Add(action);
- }
- }
- }
- public static Thread RunAsync(Action a)
- {
- Initialize();
- while (numThreads >= maxThreads)
- {
- Thread.Sleep(1);
- }
- Interlocked.Increment(ref numThreads);
- ThreadPool.QueueUserWorkItem(RunAction, a);
- return null;
- }
- private static void RunAction(object action)
- {
- try
- {
- ((Action)action)();
- }
- catch
- {
- }
- finally
- {
- Interlocked.Decrement(ref numThreads);
- }
- }
- void OnDisable()
- {
- if (_current == this)
- {
- _current = null;
- }
- }
-
- void Start()
- {
- }
- List<Action> _currentActions = new List<Action>();
-
- void Update()
- {
- lock (_actions)
- {
- _currentActions.Clear();
- _currentActions.AddRange(_actions);
- _actions.Clear();
- }
- foreach (var a in _currentActions)
- {
- a();
- }
- lock (_delayed)
- {
- _currentDelayed.Clear();
- _currentDelayed.AddRange(_delayed.Where(d => d.time <= Time.time));
- foreach (var item in _currentDelayed)
- _delayed.Remove(item);
- }
- foreach (var delayed in _currentDelayed)
- {
- delayed.action();
- }
- }
- }
|