Added Achievments.OnAchievementStateChanged

This commit is contained in:
Garry Newman 2017-07-28 17:04:18 +01:00
parent c6cb8a2f81
commit 61268b973e

View File

@ -13,23 +13,52 @@ namespace Facepunch.Steamworks
public Achievement[] All { get; private set; } public Achievement[] All { get; private set; }
public event Action OnUpdated; public event Action OnUpdated;
public event Action<Achievement> OnAchievementStateChanged;
private List<Achievement> unlockedRecently = new List<Achievement>();
internal Achievements( Client c ) internal Achievements( Client c )
{ {
client = c; client = c;
All = new Achievement[0]; All = new Achievement[0];
SteamNative.UserStatsReceived_t.RegisterCallback( c, UserStatsReceived ); SteamNative.UserStatsReceived_t.RegisterCallback( c, UserStatsReceived );
SteamNative.UserStatsStored_t.RegisterCallback( c, UserStatsStored );
Refresh(); Refresh();
} }
public void Refresh() public void Refresh()
{ {
var old = All;
All = Enumerable.Range( 0, (int)client.native.userstats.GetNumAchievements() ) All = Enumerable.Range( 0, (int)client.native.userstats.GetNumAchievements() )
.Select( x => new Achievement( client, x ) ) .Select( x =>
{
if ( old != null )
{
var name = client.native.userstats.GetAchievementName( (uint)x );
var found = old.FirstOrDefault( y => y.Id == name );
if ( found != null )
{
if ( found.Refresh() )
{
unlockedRecently.Add( found );
}
return found;
}
}
return new Achievement( client, x );
} )
.ToArray(); .ToArray();
foreach ( var i in unlockedRecently )
{
OnAchievementStateChanged?.Invoke( i );
}
unlockedRecently.Clear();
} }
public void Dispose() public void Dispose()
@ -74,6 +103,15 @@ namespace Facepunch.Steamworks
OnUpdated?.Invoke(); OnUpdated?.Invoke();
} }
private void UserStatsStored( UserStatsStored_t stats, bool isError )
{
if ( isError ) return;
Refresh();
OnUpdated?.Invoke();
}
} }
public class Achievement public class Achievement
@ -95,6 +133,7 @@ namespace Facepunch.Steamworks
public DateTime UnlockTime { get; private set; } public DateTime UnlockTime { get; private set; }
private int iconId { get; set; } = -1; private int iconId { get; set; } = -1;
private int refreshCount = 0;
/// <summary> /// <summary>
/// If this achievement is linked to a stat this will return the progress. /// If this achievement is linked to a stat this will return the progress.
@ -186,10 +225,12 @@ namespace Facepunch.Steamworks
/// <summary> /// <summary>
/// Refresh the unlock state. You shouldn't need to call this manually /// Refresh the unlock state. You shouldn't need to call this manually
/// but it's here if you have to for some reason. /// but it's here if you have to for some reason. Retuns true if state changed (meaning, probably unlocked)
/// </summary> /// </summary>
public void Refresh() public bool Refresh()
{ {
bool previousState = State;
bool state = false; bool state = false;
uint unlockTime; uint unlockTime;
@ -200,6 +241,15 @@ namespace Facepunch.Steamworks
State = state; State = state;
UnlockTime = Utility.Epoch.ToDateTime( unlockTime ); UnlockTime = Utility.Epoch.ToDateTime( unlockTime );
} }
refreshCount++;
if ( previousState != State && refreshCount > 1 )
{
return true;
}
return false;
} }
} }