public interface

Snapshots

com.google.android.gms.games.snapshot.Snapshots

Class Overview

The Snapshots API allows you to store data representing the player's game progress on Google's servers. Your app can use this data to restore saved state from a previous gaming session and provide a visual indicator of progression to the player.

For more details, see the saved games developer guide.

Summary

Nested Classes
interface Snapshots.CommitSnapshotResult Result delivered when a snapshot has been committed. 
interface Snapshots.DeleteSnapshotResult Result delivered when a snapshot has been deleted. 
interface Snapshots.LoadSnapshotsResult Result delivered when snapshot data has been loaded. 
interface Snapshots.OpenSnapshotResult Result delivered when a snapshot has been opened. 
Constants
int DISPLAY_LIMIT_NONE Constant passed to getSelectSnapshotIntent(GoogleApiClient, String, boolean, boolean, int) indicating that the UI should not cap the number of displayed snapshots.
String EXTRA_SNAPSHOT_METADATA Intent extra used to pass a SnapshotMetadata.
String EXTRA_SNAPSHOT_NEW Intent extra used to indicate the user wants to create a new snapshot.
Public Methods
abstract PendingResult<Snapshots.CommitSnapshotResult> commitAndClose(GoogleApiClient apiClient, Snapshot snapshot, SnapshotMetadataChange metadataChange)
Commit any modifications made to the snapshot.
abstract PendingResult<Snapshots.DeleteSnapshotResult> delete(GoogleApiClient apiClient, SnapshotMetadata metadata)
Delete the specified snapshot.
abstract void discardAndClose(GoogleApiClient apiClient, Snapshot snapshot)
Discard the contents of the snapshot and close the contents.
abstract int getMaxCoverImageSize(GoogleApiClient apiClient)
Gets the maximum data size per snapshot cover image in bytes.
abstract int getMaxDataSize(GoogleApiClient apiClient)
Gets the maximum data size per snapshot in bytes.
abstract Intent getSelectSnapshotIntent(GoogleApiClient apiClient, String title, boolean allowAddButton, boolean allowDelete, int maxSnapshots)
Returns an intent that will let the user select a snapshot.
abstract SnapshotMetadata getSnapshotFromBundle(Bundle extras)
This method takes a Bundle object and extracts the Snapshot provided.
abstract PendingResult<Snapshots.LoadSnapshotsResult> load(GoogleApiClient apiClient, boolean forceReload)
Asynchronously load the snapshot data for the currently signed-in player.
abstract PendingResult<Snapshots.OpenSnapshotResult> open(GoogleApiClient apiClient, String fileName, boolean createIfNotFound)
Open a snapshot with the given name.
abstract PendingResult<Snapshots.OpenSnapshotResult> open(GoogleApiClient apiClient, SnapshotMetadata metadata)
Open a snapshot with the given metadata (usually returned from load(GoogleApiClient, boolean).
abstract PendingResult<Snapshots.OpenSnapshotResult> resolveConflict(GoogleApiClient apiClient, String conflictId, String snapshotId, SnapshotMetadataChange metadataChange, SnapshotContents snapshotContents)
Resolve a conflict using the provided data.
abstract PendingResult<Snapshots.OpenSnapshotResult> resolveConflict(GoogleApiClient apiClient, String conflictId, Snapshot snapshot)
Resolve a conflict using the data from the provided snapshot.

Constants

public static final int DISPLAY_LIMIT_NONE

Constant passed to getSelectSnapshotIntent(GoogleApiClient, String, boolean, boolean, int) indicating that the UI should not cap the number of displayed snapshots.

Constant Value: -1 (0xffffffff)

public static final String EXTRA_SNAPSHOT_METADATA

Intent extra used to pass a SnapshotMetadata.

Constant Value: "com.google.android.gms.games.SNAPSHOT_METADATA"

public static final String EXTRA_SNAPSHOT_NEW

Intent extra used to indicate the user wants to create a new snapshot.

Constant Value: "com.google.android.gms.games.SNAPSHOT_NEW"

Public Methods

public abstract PendingResult<Snapshots.CommitSnapshotResult> commitAndClose (GoogleApiClient apiClient, Snapshot snapshot, SnapshotMetadataChange metadataChange)

Commit any modifications made to the snapshot. This will cause the changes to be synced to the server in the background.

Calling this method with a snapshot that has already been committed or that was not opened via open(GoogleApiClient, SnapshotMetadata) will throw an exception.

Note that the total size of the contents of snapshot may not exceed the size provided by getMaxDataSize(GoogleApiClient).

Required API: API
Required Scopes: SCOPE_GAMES and SCOPE_APPFOLDER.

Parameters
apiClient The GoogleApiClient to service the call.
snapshot The snapshot to commit the data for.
metadataChange The set of changes to apply to the metadata for the snapshot. Use EMPTY_CHANGE to preserve the existing metadata.
Returns

public abstract PendingResult<Snapshots.DeleteSnapshotResult> delete (GoogleApiClient apiClient, SnapshotMetadata metadata)

Delete the specified snapshot. This will delete the data of the snapshot locally and on the server.

Required API: API
Required Scopes: SCOPE_GAMES and SCOPE_APPFOLDER.

Parameters
apiClient The GoogleApiClient to service the call.
metadata The metadata of the snapshot to delete.
Returns

public abstract void discardAndClose (GoogleApiClient apiClient, Snapshot snapshot)

Discard the contents of the snapshot and close the contents. This will discard all changes made to the file, and close the snapshot to future changes until it is re-opened. The file will not be modified on the server.

Calling this method with a snapshot that has already been committed or that was not opened via open(GoogleApiClient, SnapshotMetadata) will throw an exception.

Required API: API
Required Scopes: SCOPE_GAMES and SCOPE_APPFOLDER.

Parameters
apiClient The GoogleApiClient to service the call.
snapshot The snapshot to discard the data for.

public abstract int getMaxCoverImageSize (GoogleApiClient apiClient)

Gets the maximum data size per snapshot cover image in bytes. Guaranteed to be at least 800 KB. May increase in the future.

If the service cannot be reached for some reason, this will return -1.

Required API: API
Required Scopes: SCOPE_GAMES and SCOPE_APPFOLDER.

Parameters
apiClient The GoogleApiClient to service the call.
Returns
  • The maximum data size per snapshot cover image in bytes.

public abstract int getMaxDataSize (GoogleApiClient apiClient)

Gets the maximum data size per snapshot in bytes. Guaranteed to be at least 3 MB. May increase in the future.

If the service cannot be reached for some reason, this will return -1.

Required API: API
Required Scopes: SCOPE_GAMES and SCOPE_APPFOLDER.

Parameters
apiClient The GoogleApiClient to service the call.
Returns
  • The maximum data size per snapshot in bytes.

public abstract Intent getSelectSnapshotIntent (GoogleApiClient apiClient, String title, boolean allowAddButton, boolean allowDelete, int maxSnapshots)

Returns an intent that will let the user select a snapshot. Note that this must be invoked using startActivityForResult(Intent, int) so that the identity of the calling package can be established.

If the user canceled without selecting a snapshot, the result will be RESULT_CANCELED. If the user selected a snapshot from the list, the result will be RESULT_OK and the data intent will contain the selected Snapshot as a parcelable object in EXTRA_SNAPSHOT_METADATA. If the user pressed the add button, the result will be RESULT_OK and the data intent will contain a true boolean value in EXTRA_SNAPSHOT_NEW.

Note that if you have modified an open snapshot, the changes will not appear in this UI until you call commitAndClose(GoogleApiClient, Snapshot, SnapshotMetadataChange) on the snapshot.

Required API: API
Required Scopes: SCOPE_GAMES and SCOPE_APPFOLDER.

Parameters
apiClient The GoogleApiClient to service the call.
title The title to display in the action bar of the returned Activity.
allowAddButton Whether or not to display a "create new snapshot" option in the selection UI.
allowDelete Whether or not to provide a delete overflow menu option for each snapshot in the selection UI.
maxSnapshots The maximum number of snapshots to display in the UI. Use DISPLAY_LIMIT_NONE to display all snapshots.
Returns
  • An Intent that can be started to view the select snapshot UI.

public abstract SnapshotMetadata getSnapshotFromBundle (Bundle extras)

This method takes a Bundle object and extracts the Snapshot provided. If the Bundle is invalid or does not contain the correct data, this method returns null.

Parameters
extras The Bundle to parse for a Snapshot object.
Returns

public abstract PendingResult<Snapshots.LoadSnapshotsResult> load (GoogleApiClient apiClient, boolean forceReload)

Asynchronously load the snapshot data for the currently signed-in player.

Required API: API
Required Scopes: SCOPE_GAMES and SCOPE_APPFOLDER.

Parameters
apiClient The GoogleApiClient to service the call.
forceReload If true, this call will clear any locally cached data and attempt to fetch the latest data from the server. This would commonly be used for something like a user-initiated refresh. Normally, this should be set to false to gain advantages of data caching.
Returns

public abstract PendingResult<Snapshots.OpenSnapshotResult> open (GoogleApiClient apiClient, String fileName, boolean createIfNotFound)

Open a snapshot with the given name. If createIfNotFound is set to true, the specified snapshot will be created if it does not already exist.

Required API: API
Required Scopes: SCOPE_GAMES and SCOPE_APPFOLDER.

Parameters
apiClient The GoogleApiClient to service the call.
fileName The name of the snapshot file to open. Must be between 1 and 100 non-URL-reserved characters (a-z, A-Z, 0-9, or the symbols "-", ".", "_", or "~").
createIfNotFound If true, the snapshot will be created if one cannot be found.
Returns

public abstract PendingResult<Snapshots.OpenSnapshotResult> open (GoogleApiClient apiClient, SnapshotMetadata metadata)

Open a snapshot with the given metadata (usually returned from load(GoogleApiClient, boolean). To succeed, the snapshot must exist; i.e. this call will fail if the snapshot was deleted between the load and open calls.

Required API: API
Required Scopes: SCOPE_GAMES and SCOPE_APPFOLDER.

Parameters
apiClient The GoogleApiClient to service the call.
metadata The metadata of the existing snapshot to load.
Returns

public abstract PendingResult<Snapshots.OpenSnapshotResult> resolveConflict (GoogleApiClient apiClient, String conflictId, String snapshotId, SnapshotMetadataChange metadataChange, SnapshotContents snapshotContents)

Resolve a conflict using the provided data. This will replace the data on the server with the specified metadata changes and contents. Note that it is possible for this operation to result in a conflict itself, in which case resolution should be repeated.

Values which are not included in the metadata change will be resolved to the version currently on the server.

Note that the total size of contents may not exceed the size provided by getMaxDataSize(GoogleApiClient).

Calling this method with a snapshot that has already been committed or that was not opened via open(GoogleApiClient, SnapshotMetadata) will throw an exception.

Required API: API
Required Scopes: SCOPE_GAMES and SCOPE_APPFOLDER.

Parameters
apiClient The GoogleApiClient to service the call.
conflictId The ID of the conflict to resolve. Must come from getConflictId().
snapshotId The ID of the snapshot to resolve the conflict for.
metadataChange The set of changes to apply to the metadata for the snapshot.
snapshotContents The SnapshotContents to replace the snapshot data with.
Returns

public abstract PendingResult<Snapshots.OpenSnapshotResult> resolveConflict (GoogleApiClient apiClient, String conflictId, Snapshot snapshot)

Resolve a conflict using the data from the provided snapshot. This will replace the data on the server with the specified snapshot. Note that it is possible for this operation to result in a conflict itself, in which case resolution should be repeated.

Note that the total size of the contents of snapshot may not exceed the size provided by getMaxDataSize(GoogleApiClient).

Calling this method with a snapshot that has already been committed or that was not opened via open(GoogleApiClient, SnapshotMetadata) will throw an exception.

Required API: API
Required Scopes: SCOPE_GAMES and SCOPE_APPFOLDER.

Parameters
apiClient The GoogleApiClient to service the call.
conflictId The ID of the conflict to resolve. Must come from getConflictId().
snapshot The snapshot to use to resolve the conflict.
Returns