mirror of
https://github.com/Facepunch/Facepunch.Steamworks.git
synced 2025-01-26 05:28:07 +03:00
Added Inventory.OnDefinitionsUpdated
This commit is contained in:
parent
144f401d2c
commit
7b7cfa29c4
@ -15,6 +15,12 @@ namespace Facepunch.Steamworks.Test
|
|||||||
{
|
{
|
||||||
using ( var client = new Facepunch.Steamworks.Client( 252490 ) )
|
using ( var client = new Facepunch.Steamworks.Client( 252490 ) )
|
||||||
{
|
{
|
||||||
|
while ( client.Inventory.Definitions == null )
|
||||||
|
{
|
||||||
|
client.Update();
|
||||||
|
System.Threading.Thread.Sleep( 10 );
|
||||||
|
}
|
||||||
|
|
||||||
Assert.IsNotNull( client.Inventory.Definitions );
|
Assert.IsNotNull( client.Inventory.Definitions );
|
||||||
Assert.AreNotEqual( 0, client.Inventory.Definitions.Length );
|
Assert.AreNotEqual( 0, client.Inventory.Definitions.Length );
|
||||||
|
|
||||||
@ -36,6 +42,12 @@ namespace Facepunch.Steamworks.Test
|
|||||||
{
|
{
|
||||||
using ( var client = new Facepunch.Steamworks.Client( 252490 ) )
|
using ( var client = new Facepunch.Steamworks.Client( 252490 ) )
|
||||||
{
|
{
|
||||||
|
while ( client.Inventory.Definitions == null )
|
||||||
|
{
|
||||||
|
client.Update();
|
||||||
|
System.Threading.Thread.Sleep( 10 );
|
||||||
|
}
|
||||||
|
|
||||||
Assert.IsNotNull( client.Inventory.Definitions );
|
Assert.IsNotNull( client.Inventory.Definitions );
|
||||||
Assert.AreNotEqual( 0, client.Inventory.Definitions.Length );
|
Assert.AreNotEqual( 0, client.Inventory.Definitions.Length );
|
||||||
|
|
||||||
@ -58,6 +70,12 @@ namespace Facepunch.Steamworks.Test
|
|||||||
{
|
{
|
||||||
using ( var client = new Facepunch.Steamworks.Client( 252490 ) )
|
using ( var client = new Facepunch.Steamworks.Client( 252490 ) )
|
||||||
{
|
{
|
||||||
|
while ( client.Inventory.Definitions == null )
|
||||||
|
{
|
||||||
|
client.Update();
|
||||||
|
System.Threading.Thread.Sleep( 10 );
|
||||||
|
}
|
||||||
|
|
||||||
Assert.IsNotNull( client.Inventory.Definitions );
|
Assert.IsNotNull( client.Inventory.Definitions );
|
||||||
Assert.AreNotEqual( 0, client.Inventory.Definitions.Length );
|
Assert.AreNotEqual( 0, client.Inventory.Definitions.Length );
|
||||||
|
|
||||||
@ -80,6 +98,12 @@ namespace Facepunch.Steamworks.Test
|
|||||||
{
|
{
|
||||||
using ( var client = new Facepunch.Steamworks.Client( 252490 ) )
|
using ( var client = new Facepunch.Steamworks.Client( 252490 ) )
|
||||||
{
|
{
|
||||||
|
while ( client.Inventory.Definitions == null )
|
||||||
|
{
|
||||||
|
client.Update();
|
||||||
|
System.Threading.Thread.Sleep( 10 );
|
||||||
|
}
|
||||||
|
|
||||||
bool CallbackCalled = false;
|
bool CallbackCalled = false;
|
||||||
|
|
||||||
// OnUpdate hsould be called when we receive a list of our items
|
// OnUpdate hsould be called when we receive a list of our items
|
||||||
@ -146,6 +170,12 @@ namespace Facepunch.Steamworks.Test
|
|||||||
{
|
{
|
||||||
using ( var client = new Facepunch.Steamworks.Client( 252490 ) )
|
using ( var client = new Facepunch.Steamworks.Client( 252490 ) )
|
||||||
{
|
{
|
||||||
|
while ( client.Inventory.Definitions == null )
|
||||||
|
{
|
||||||
|
client.Update();
|
||||||
|
System.Threading.Thread.Sleep( 10 );
|
||||||
|
}
|
||||||
|
|
||||||
Assert.IsTrue( client.IsValid );
|
Assert.IsTrue( client.IsValid );
|
||||||
Assert.IsNotNull(client.Inventory.Definitions);
|
Assert.IsNotNull(client.Inventory.Definitions);
|
||||||
Assert.AreNotEqual(0, client.Inventory.Definitions.Length);
|
Assert.AreNotEqual(0, client.Inventory.Definitions.Length);
|
||||||
@ -202,6 +232,12 @@ namespace Facepunch.Steamworks.Test
|
|||||||
{
|
{
|
||||||
using (var client = new Facepunch.Steamworks.Client(252490))
|
using (var client = new Facepunch.Steamworks.Client(252490))
|
||||||
{
|
{
|
||||||
|
while ( client.Inventory.Definitions == null )
|
||||||
|
{
|
||||||
|
client.Update();
|
||||||
|
System.Threading.Thread.Sleep( 10 );
|
||||||
|
}
|
||||||
|
|
||||||
Assert.IsNotNull(client.Inventory.Definitions);
|
Assert.IsNotNull(client.Inventory.Definitions);
|
||||||
Assert.AreNotEqual(0, client.Inventory.Definitions.Length);
|
Assert.AreNotEqual(0, client.Inventory.Definitions.Length);
|
||||||
|
|
||||||
@ -235,6 +271,12 @@ namespace Facepunch.Steamworks.Test
|
|||||||
{
|
{
|
||||||
using (var client = new Facepunch.Steamworks.Client(252490))
|
using (var client = new Facepunch.Steamworks.Client(252490))
|
||||||
{
|
{
|
||||||
|
while ( client.Inventory.Definitions == null )
|
||||||
|
{
|
||||||
|
client.Update();
|
||||||
|
System.Threading.Thread.Sleep( 10 );
|
||||||
|
}
|
||||||
|
|
||||||
Assert.IsNotNull(client.Inventory.Definitions);
|
Assert.IsNotNull(client.Inventory.Definitions);
|
||||||
Assert.AreNotEqual(0, client.Inventory.Definitions.Length);
|
Assert.AreNotEqual(0, client.Inventory.Definitions.Length);
|
||||||
|
|
||||||
|
@ -128,8 +128,6 @@ namespace Facepunch.Steamworks
|
|||||||
|
|
||||||
public virtual void Update()
|
public virtual void Update()
|
||||||
{
|
{
|
||||||
Inventory.Update();
|
|
||||||
|
|
||||||
Networking.Update();
|
Networking.Update();
|
||||||
|
|
||||||
RunUpdateCallbacks();
|
RunUpdateCallbacks();
|
||||||
@ -169,6 +167,11 @@ namespace Facepunch.Steamworks
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Debug function, called for every callback. Only really used to confirm that callbacks are working properly.
|
||||||
|
/// </summary>
|
||||||
|
public Action<object> OnAnyCallback;
|
||||||
|
|
||||||
Dictionary<Type, List<Action<object>>> Callbacks = new Dictionary<Type, List<Action<object>>>();
|
Dictionary<Type, List<Action<object>>> Callbacks = new Dictionary<Type, List<Action<object>>>();
|
||||||
|
|
||||||
internal List<Action<object>> CallbackList( Type T )
|
internal List<Action<object>> CallbackList( Type T )
|
||||||
@ -192,6 +195,11 @@ namespace Facepunch.Steamworks
|
|||||||
{
|
{
|
||||||
i( data );
|
i( data );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ( OnAnyCallback != null )
|
||||||
|
{
|
||||||
|
OnAnyCallback.Invoke( data );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void RegisterCallback<T>( Action<T> func )
|
internal void RegisterCallback<T>( Action<T> func )
|
||||||
|
@ -37,25 +37,27 @@ namespace Facepunch.Steamworks
|
|||||||
|
|
||||||
internal SteamNative.SteamInventory inventory;
|
internal SteamNative.SteamInventory inventory;
|
||||||
|
|
||||||
private Stopwatch fetchRetryTimer;
|
|
||||||
|
|
||||||
private bool IsServer { get; set; }
|
private bool IsServer { get; set; }
|
||||||
|
|
||||||
|
public event Action OnDefinitionsUpdated;
|
||||||
|
|
||||||
internal Inventory( BaseSteamworks steamworks, SteamNative.SteamInventory c, bool server )
|
internal Inventory( BaseSteamworks steamworks, SteamNative.SteamInventory c, bool server )
|
||||||
{
|
{
|
||||||
IsServer = server;
|
IsServer = server;
|
||||||
inventory = c;
|
inventory = c;
|
||||||
|
|
||||||
|
steamworks.RegisterCallback<SteamNative.SteamInventoryDefinitionUpdate_t>( onDefinitionsUpdated );
|
||||||
|
|
||||||
Result.Pending = new Dictionary<int, Result>();
|
Result.Pending = new Dictionary<int, Result>();
|
||||||
|
|
||||||
FetchItemDefinitions();
|
FetchItemDefinitions(); // onDefinitionsUpdated should get called on next Update
|
||||||
UpdatePrices();
|
|
||||||
|
|
||||||
if ( !server )
|
if ( !server )
|
||||||
{
|
{
|
||||||
steamworks.RegisterCallback<SteamNative.SteamInventoryResultReady_t>( onResultReady );
|
steamworks.RegisterCallback<SteamNative.SteamInventoryResultReady_t>( onResultReady );
|
||||||
steamworks.RegisterCallback<SteamNative.SteamInventoryFullUpdate_t>( onFullUpdate );
|
steamworks.RegisterCallback<SteamNative.SteamInventoryFullUpdate_t>( onFullUpdate );
|
||||||
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Get a list of our items immediately
|
// Get a list of our items immediately
|
||||||
//
|
//
|
||||||
@ -63,6 +65,37 @@ namespace Facepunch.Steamworks
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Should get called when the definitions get updated from Steam.
|
||||||
|
/// </summary>
|
||||||
|
private void onDefinitionsUpdated( SteamInventoryDefinitionUpdate_t obj )
|
||||||
|
{
|
||||||
|
Console.WriteLine( "onDefinitionsUpdated" );
|
||||||
|
LoadDefinitions();
|
||||||
|
UpdatePrices();
|
||||||
|
|
||||||
|
if ( OnDefinitionsUpdated != null )
|
||||||
|
{
|
||||||
|
OnDefinitionsUpdated.Invoke();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private bool LoadDefinitions()
|
||||||
|
{
|
||||||
|
var ids = inventory.GetItemDefinitionIDs();
|
||||||
|
if ( ids == null )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
Definitions = ids.Select( x => CreateDefinition( x ) ).ToArray();
|
||||||
|
|
||||||
|
foreach ( var def in Definitions )
|
||||||
|
{
|
||||||
|
def.Link( Definitions );
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// We've received a FULL update
|
/// We've received a FULL update
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@ -202,22 +235,7 @@ namespace Facepunch.Steamworks
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public void FetchItemDefinitions()
|
public void FetchItemDefinitions()
|
||||||
{
|
{
|
||||||
//
|
|
||||||
// Make sure item definitions are loaded, because we're going to be using them.
|
|
||||||
//
|
|
||||||
|
|
||||||
inventory.LoadItemDefinitions();
|
inventory.LoadItemDefinitions();
|
||||||
|
|
||||||
var ids = inventory.GetItemDefinitionIDs();
|
|
||||||
if ( ids == null )
|
|
||||||
return;
|
|
||||||
|
|
||||||
Definitions = ids.Select( x => CreateDefinition( x ) ).ToArray();
|
|
||||||
|
|
||||||
foreach ( var def in Definitions )
|
|
||||||
{
|
|
||||||
def.Link( Definitions );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -225,24 +243,7 @@ namespace Facepunch.Steamworks
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public void Update()
|
public void Update()
|
||||||
{
|
{
|
||||||
if ( Definitions == null )
|
|
||||||
{
|
|
||||||
//
|
|
||||||
// Don't try every frame, just try every 10 seconds.
|
|
||||||
//
|
|
||||||
{
|
|
||||||
if ( fetchRetryTimer != null && fetchRetryTimer.Elapsed.TotalSeconds < 10.0f )
|
|
||||||
return;
|
|
||||||
|
|
||||||
if ( fetchRetryTimer == null )
|
|
||||||
fetchRetryTimer = Stopwatch.StartNew();
|
|
||||||
|
|
||||||
fetchRetryTimer.Reset();
|
|
||||||
fetchRetryTimer.Start();
|
|
||||||
}
|
|
||||||
|
|
||||||
FetchItemDefinitions();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -258,7 +259,10 @@ namespace Facepunch.Steamworks
|
|||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
for( int i=0; i< Definitions.Length; i++ )
|
if ( Definitions == null )
|
||||||
|
yield break;
|
||||||
|
|
||||||
|
for ( int i=0; i< Definitions.Length; i++ )
|
||||||
{
|
{
|
||||||
if (Definitions[i].LocalPrice > 0)
|
if (Definitions[i].LocalPrice > 0)
|
||||||
yield return Definitions[i];
|
yield return Definitions[i];
|
||||||
|
Loading…
x
Reference in New Issue
Block a user