Achievements
The Achievement module allows the developer to grant achievements to the player, to clear achievements, and to determine if an achievement has been granted. It also allows the recording of progress towards an achievement.
By default, the achievement stores information in the persistent file. If Steam support is available and enabled, achievement information is automatically synchronized with Steam.
Steam support must be added to Ren'Py, to ensure that it is only distributed by creators that have been accepted to the Steam partner program. To install it, choose "preferences", "Install libraries", "Install Steam Support".
- achievement.Sync()
An action that calls achievement.sync(). This is only sensitive if achievements are out of sync.
- achievement.clear(name)
Clears the achievement with name.
- achievement.clear_all()
Clears all achievements.
- achievement.get_progress(name)
Returns the current progress towards the achievement identified with name, or 0 if no progress has been registered for it or if the achievement is not known.
- achievement.grant(name)
Grants the achievement with name, if it has not already been granted.
- achievement.has(name)
Returns true if the player has been granted the achievement with name.
- achievement.progress(name, complete)
Reports progress towards the achievement with name, if that achievement has not been granted. The achievement must be defined with a completion amount.
- name
The name of the achievement. This should be the name of the achievement, and not the stat.
- complete
An integer giving the number of units completed towards the achievement.
- achievement.register(name, **kwargs)
Registers an achievement. Achievements are not required to be registered, but doing so allows one to pass information to the backends.
- name
The name of the achievement to register.
The following keyword parameters are optional.
- steam
The name to use on steam. If not given, defaults to name.
- stat_max
The integer value of the stat at which the achievement unlocks.
- stat_modulo
If the progress modulo stat_max is 0, progress is displayed to the user. For example, if stat_modulo is 10, progress will be displayed to the user when it reaches 10, 20, 30, etc. If not given, this defaults to 0.
- achievement.sync()
Synchronizes registered achievements between local storage and other backends. (For example, Steam.)
Variables that control achievements are:
- achievement.steam_position = None
If not None, this sets the position of the steam notification popup. This must be a string, one of "top left", "top right", "bottom left", or "bottom right".
- define config.steam_appid = None
If not None, this should be the Steam appid. Ren'Py will automatically set this appid when it starts. This needs to be set using the define statement:
define config.steam_appid = 12345
- define config.automatic_steam_timeline = True
If true, when run under Steam, the game will automatically update the Steam Timeline.
This currently consists of:
Updating the state description to match
save_name
, if the variables is set.Updating the game mode to reflect when the player is inside a menu.
Steamworks API
When Steam is available, a ctypes-based binding to the Steamworks API is
available as achievement.steamapi
. The binding is an instance of the
steamapi module, as found here,
and represents a machine translation of the C++ Steamworks API to Python.
In addition, a large number of functions are available in the achievement.steam object, if and only if the Steamworks API is available.
- achievement.steam
If Steam initialized successfully, this is a namespace with high-level Steam methods. If Steam did not initialize, this is None. Always check that this is not None before calling a method.
Steam Apps
- achievement.steam.dlc_installed(appid)
Returns True if dlc is installed, or False otherwise.
- achievement.steam.dlc_progress(appid)
Reports the progress towards DLC download completion.
- achievement.steam.get_app_build_id()
Returns the build ID of the installed game.
- achievement.steam.get_current_beta_name()
Returns the name of the current beta, or None if it can't.
- achievement.steam.get_current_game_language()
Return the name of the language the user has selected.
- achievement.steam.get_steam_ui_language()
Return the name of the language the steam UI is using.
- achievement.steam.install_dlc(appid)
Requests the DLC with appid be installed.
- achievement.steam.is_subscribed_app(appid)
Returns true if the user owns the app with appid, and false otherwise.
- achievement.steam.uninstall_dlc(appid)
Requests that the DLC with appid be uninstalled.
Steam Overlay
- achievement.steam.activate_overlay(dialog)
Activates the Steam overlay.
- dialog
The dialog to open the overlay to. One of "Friends", "Community", "Players", "Settings", "OfficialGameGroup", "Stats", "Achievements"
- achievement.steam.activate_overlay_to_store(appid, flag=None)
Opens the steam overlay to the store.
- appid
The appid to open.
- flag
One of achievement.steam.STORE_NONE, .STORE_ADD_TO_CART, or .STORE_ADD_TO_CART_AND_SHOW.
- achievement.steam.activate_overlay_to_web_page(url)
Activates the Steam overlay, and opens the web page at url.
- achievement.steam.is_overlay_enabled()
Returns true if the steam overlay is enabled. (This might take a while to return true once the game starts.)
- achievement.steam.overlay_needs_present()
Returns true if the steam overlay is enabled. (This might take a while to return true once the game starts.)
- achievement.steam.set_overlay_notification_position(position)
Sets the position of the steam overlay. Position should be one of achievement.steam.POSITION_TOP_LEFT, .POSITION_TOP_RIGHT, .POSITION_BOTTOM_LEFT, or .POSITION_BOTTOM_RIGHT.
Steam Stats
- achievement.steam.clear_achievement(name)
Clears the achievement with name. Call
_renpysteam.store_stats()
to push this change to the server.
- achievement.steam.get_achievement(name)
Gets the state of the achievements with name. This returns True if the achievement has been granted, False if it hasn't, and None if the achievement is unknown or an error occurs.
- achievement.steam.get_float_stat(name)
Returns the value of the stat with name, or None if no such stat exits.
- achievement.steam.get_int_stat(name)
Returns the value of the stat with name, or None if no such stat exits.
- achievement.steam.grant_achievement(name)
Grants the achievement with name. Call
_renpysteam.store_stats()
to push this change to the server.
- achievement.steam.indicate_achievement_progress(name, cur_progress, max_progress)
Indicates achievement progress to the user. This does not unlock the achievement.
- achievement.steam.list_achievements()
Returns a list of achievement names.
- achievement.steam.retrieve_stats()
Retrieves achievements and statistics from Steam.
- achievement.steam.set_float_stat(name, value)
Sets the value of the stat with name, which must have the type of FLOAT. Call
_renpysteam.store_stats()
to push this change to the server.
- achievement.steam.set_int_stat(name, value)
Sets the value of the stat with name, which must have the type of INT. Call
_renpysteam.store_stats()
to push this change to the server.
- achievement.steam.store_stats()
Stores statistics and achievements on the Steam server.
Steam Timeline
- achievement.steam.add_timeline_event(icon, title, description, priority=0, start_offset=0.0, duration=0.0, possible_clip=None)
Adds an event to the timeline.
- icon
The icon to display for the event. This should be a string giving one of the standard steam icons, or one you uploaded to Steam.
- title
The title of the event.
- description
The description of the event.
- priority
The priority of the event, used to resolve conflicts. This should be an interger between 0 and 1000.
- start_offset
The offset of the start of the event from the current time, in seconds.
- duration
The duration of the event, in seconds.
- possible_clip
This determines if the event can be clipped. This should be one of the achievement.steam.CLIP_PRIORITY... constants: CLIP_PRIORITY_NONE, CLIP_PRIORITY_STANDARD, or CLIP_PRIORITY_FEATURED.
- achievement.steam.clear_timeline_state_description(time_delta)
Clears the description of the current state in the timeline.
- achievement.steam.set_timeline_state_description(description, time_delta=0.0)
Sets the description of the current state in the timeline.
- description
A string giving the description of the current state.
- time_delta
The time since the last state change.
Steam User
- achievement.steam.cancel_ticket()
Cancels the ticket returned by
achievement.steam.get_session_ticket()
.
- achievement.steam.get_account_id()
Returns the user's account ID.
- achievement.steam.get_csteam_id()
Returns the user's full CSteamID as a 64-bit number.
- achievement.steam.get_game_badge_level(series, foil)
Gets the level of the users Steam badge for your game.
- achievement.steam.get_persona_name()
Returns the user's publicly-visible name.
- achievement.steam.get_session_ticket()
Gets a ticket that can be sent to the server to authenticate this user.
Steam Workshop
- achievement.steam.get_subscribed_item_path(item_id)
Returns the path where an item of user-generated content was installed. Returns None if the item was not installed.
- item_id
The item id.
- achievement.steam.get_subscribed_items()
Returns a list of the item ids the user has subscribed to in the steam workshop.