LoginSignup
15
12

More than 1 year has passed since last update.

【Unity】保存した時刻からの経過時間によって処理を分岐させる

Posted at

やりたいこと

  • 攻撃を試みた時、その瞬間の時刻と前回攻撃時の時刻を比較し、前回攻撃からの経過時間によって処理を分岐させる

発動を無効化(on/off)ではなく経過時間によって発動するアクションを変えたかったためこの実装方法を選択

DateTime型を用いて処理を書きます

時間の保存

まずはじめに「最後に発動した時刻」を保存する

  • PlayerPrefsに保存

「PlayerPrefs」については下記記事を参考にしました
【Unity】PlayerPrefs の使い方やメリット/デメリットなどをまとめてみた

  • DateTime型はPlayerPrefsに対応していないため、バイナリに変換しstring型に置き換えます
using UnityEngine;
using System;

public class Sample
{
    public static void SaveAttackTime()
    {
        var currentTime = DateTime.Now;
        PlayerPrefs.SetString("LastAttackTime", currentTime.ToBinary().ToString()); 
    }
}

保存した時刻をロードする

public static string LoadAttackTime()
{
    string lastAttackTimeString = PlayerPrefs.GetString("LastAttackTime", "");
    return lastAttackTimeString;
}

攻撃を試みた時に瞬間の時刻と前回攻撃時の時刻を比較

public void CheckAttackEnabled() //攻撃を試みた際に呼び出す
{
    //前回攻撃時刻が保存されていない場合、最初の攻撃
    if (string.IsNullOrWhiteSpace(LoadAttackTime()))
    {
        //攻撃
        SaveAttackTime(); //この攻撃時刻を保存する
    }
    else
    {
        long timeValue = Convert.ToInt64(LoadAttackTime());
        var PastPostBoardTime = DateTime.FromBinary(timeValue);
        DateTime dt1 = DateTime.Now;
        DateTime dt2 = PastPostBoardTime;
        if (dt1 >= dt2.AddSeconds(10))
        {
            //攻撃
            SaveAttackTime(); //この攻撃時刻を保存する
        }
        else
        {
            //攻撃失敗
        }
    }
}

攻撃を試行した時刻(dt1)と、前回の攻撃の時刻(dt2)+設けたいインターバル(今回は10秒)を比較し、インターバル経過前に再度攻撃を試行すると失敗となります

PlayerPrefsは同じkey(今回の場合「"LastAttackTime"」)で保存した場合上書きされるため、攻撃成功時に時刻を保存してあげます

死んだときや終了したときには保存した時間を削除する処理を入れます

//死んだときや終了したときには下記処理で保存した時間を削除
    public static void DeleteAttackTime()
    {
        PlayerPrefs.DeleteKey("LastAttackTime");
    }

保存先を統一すれば攻撃の種類によって異なるインターバルの幅を設けることが可能です


スクリプト全文

using UnityEngine;
using System;

public class Sample
{
    public static void SaveAttackTime()
    {
        var currentTime = DateTime.Now;
        PlayerPrefs.SetString("LastAttackTime", currentTime.ToBinary().ToString()); 
    }

    public static string LoadAttackTime()
    {
        string lastAttackTimeString = PlayerPrefs.GetString("LastAttackTime", "");
        return lastAttackTimeString;
    }

    public void CheckAttackEnabled() //攻撃を試みた際に呼び出す
    {
        //前回攻撃時刻が保存されていない場合、最初の攻撃
        if (string.IsNullOrWhiteSpace(LoadAttackTime()))
        {
            //攻撃
            SaveAttackTime(); //この攻撃時刻を保存する
        }
        else
        {
            long timeValue = Convert.ToInt64(LoadAttackTime());
            var PastPostBoardTime = DateTime.FromBinary(timeValue);
            DateTime dt1 = DateTime.Now;
            DateTime dt2 = PastPostBoardTime;
            if (dt1 >= dt2.AddSeconds(5))
            {
                //攻撃
                SaveAttackTime(); //この攻撃時刻を保存する
            }
            else
            {
                //攻撃失敗
            }
        }
    }
    //死んだときや終了したときには下記処理で保存した時間を削除
    public static void DeleteAttackTime()
    {
        PlayerPrefs.DeleteKey("LastAttackTime");
    }
}

感想

ケースがケースだけに「いつ使うん?」といった内容となってしまいました

拙い実装ですが他に良い方法知っておりましたら教えて下さい

参考文献

15
12
2

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
15
12