「Unity/UniRx/遅延処理」の版間の差分
ナビゲーションに移動
検索に移動
| 31行目: | 31行目: | ||
Observable.Timer(System.TimeSpan.FromSeconds(0.01d)) | Observable.Timer(System.TimeSpan.FromSeconds(0.01d)) | ||
.Subscribe(_ => Debug.Log("0.01秒後")) | .Subscribe(_ => Debug.Log("0.01秒後")) | ||
.AddTo(gameObject); | |||
</pre> | |||
===一定期間処理をEveryUpdateとThrottleFirstを使ってやる場合=== | |||
<pre> | |||
Observable.EveryUpdate() | |||
.ThrottleFirst(TimeSpan.FromSeconds(1f)) // 1秒ごと呼び出し | |||
.Subscribe(_ => { | |||
// Debug.Log("update"); | |||
}) | |||
.AddTo(gameObject); | .AddTo(gameObject); | ||
</pre> | </pre> | ||
2023年4月17日 (月) 18:56時点における版
時間後処理
using UniRx;
// 1秒後に実行
Observable.Timer(System.TimeSpan.FromSeconds(1))
.Subscribe(_ => Debug.Log("1秒後に実行"))
.AddTo(gameObject);
複数行であれば
Observable.Timer(System.TimeSpan.FromSeconds(1))
.Subscribe(_ => {
Debug.Log("1秒後に実行");
Debug.Log("2行目");
})
.AddTo(gameObject);
参考:https://qiita.com/toRisouP/items/86fea641982e6e16dac6
続けて一定時間処理
// 1秒後から2秒間隔
Observable.Timer(System.TimeSpan.FromSeconds(1), System.TimeSpan.FromSeconds(2))
.Subscribe(_ => Debug.Log("2秒間隔に実行"))
.AddTo(gameObject);
参考:https://qiita.com/toRisouP/items/86fea641982e6e16dac6
ミリ秒処理
// 0.01秒後
Observable.Timer(System.TimeSpan.FromSeconds(0.01d))
.Subscribe(_ => Debug.Log("0.01秒後"))
.AddTo(gameObject);
一定期間処理をEveryUpdateとThrottleFirstを使ってやる場合
Observable.EveryUpdate()
.ThrottleFirst(TimeSpan.FromSeconds(1f)) // 1秒ごと呼び出し
.Subscribe(_ => {
// Debug.Log("update");
})
.AddTo(gameObject);