2020-03-16 00:47:21 +00:00
|
|
|
/* ScummVM - Graphic Adventure Engine
|
|
|
|
*
|
|
|
|
* ScummVM is the legal property of its developers, whose names
|
|
|
|
* are too numerous to list here. Please refer to the COPYRIGHT
|
|
|
|
* file distributed with this source distribution.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef COMMON_ACHIEVEMENTS_H
|
|
|
|
#define COMMON_ACHIEVEMENTS_H
|
|
|
|
|
|
|
|
#include "common/array.h"
|
2020-04-28 22:56:54 +00:00
|
|
|
#include "common/ini-file.h"
|
2020-03-16 00:47:21 +00:00
|
|
|
#include "common/singleton.h"
|
|
|
|
#include "common/str.h"
|
|
|
|
|
|
|
|
namespace Common {
|
|
|
|
|
2020-07-08 21:30:36 +00:00
|
|
|
/**
|
|
|
|
* @defgroup common_achieve Achievements
|
|
|
|
* @ingroup common
|
|
|
|
*
|
|
|
|
* @brief API related to in-game achievements.
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
2020-03-16 00:47:21 +00:00
|
|
|
/**
|
|
|
|
* List of game achievements provider platforms.
|
|
|
|
* Possible candidates are XBOX Gamerscore, PSN Trophies, Kongregate Badges, etc...
|
|
|
|
*/
|
|
|
|
enum AchievementsPlatform {
|
|
|
|
STEAM_ACHIEVEMENTS,
|
|
|
|
GALAXY_ACHIEVEMENTS,
|
|
|
|
UNK_ACHIEVEMENTS = -1
|
|
|
|
};
|
|
|
|
|
2021-05-31 01:23:01 +00:00
|
|
|
/**
|
|
|
|
* Information structure for game-specific statistics.
|
|
|
|
*/
|
|
|
|
struct StatDescription {
|
2021-06-04 01:34:59 +00:00
|
|
|
String id; //!< Stat internal ID, such as "ITEMS_THROWN".
|
|
|
|
String comment; //!< Optional stat comment, such as "Items Thrown".
|
|
|
|
String start; //!< Stat default value, such as "0".
|
2021-05-31 01:23:01 +00:00
|
|
|
};
|
|
|
|
|
2020-03-16 00:47:21 +00:00
|
|
|
/**
|
2020-09-15 23:39:09 +00:00
|
|
|
* Information structure for game-specific achievements.
|
2020-03-16 00:47:21 +00:00
|
|
|
*/
|
|
|
|
struct AchievementDescription {
|
2021-06-04 01:34:59 +00:00
|
|
|
String id; //!< Achievement internal ID, such as "ACHIEVEMENT_TIMING".
|
|
|
|
String title; //!< Achievement displayed text, such as "Marathon Runner".
|
|
|
|
String comment; //!< Optional achievement hint or comment, such as "Finish the game in less than 4 hours".
|
|
|
|
bool isHidden; //!< Whether the achievement is hidden.
|
2020-03-16 00:47:21 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
2020-09-15 23:39:09 +00:00
|
|
|
* Information structure for platform-specific achievements.
|
2020-03-16 00:47:21 +00:00
|
|
|
*/
|
|
|
|
struct AchievementsInfo {
|
2020-09-15 23:39:09 +00:00
|
|
|
Common::AchievementsPlatform platform; //!< Achievements platform, such as "STEAM_ACHIEVEMENTS".
|
|
|
|
Common::String appId; //!< Achievements application ID of the given platform.
|
2020-03-16 00:47:21 +00:00
|
|
|
|
2021-03-13 12:22:48 +00:00
|
|
|
AchievementsInfo() { platform = Common::UNK_ACHIEVEMENTS; }
|
2020-03-16 00:47:21 +00:00
|
|
|
};
|
|
|
|
|
2020-09-15 23:39:09 +00:00
|
|
|
/**
|
|
|
|
* Class for manipulating the achievements.
|
|
|
|
*
|
|
|
|
* Use the Achievements Manager class to edit the in-game achievements.
|
|
|
|
*/
|
2020-03-16 00:47:21 +00:00
|
|
|
class AchievementsManager : public Singleton<AchievementsManager> {
|
|
|
|
public:
|
|
|
|
AchievementsManager();
|
|
|
|
~AchievementsManager();
|
2021-03-13 12:22:48 +00:00
|
|
|
|
2021-05-27 23:12:59 +00:00
|
|
|
/**
|
2021-06-04 01:34:59 +00:00
|
|
|
* Set a game targeted by platform type and application ID as active domain.
|
|
|
|
* Automaticly loads messages texts from achievements.dat.
|
2021-05-27 23:12:59 +00:00
|
|
|
*
|
2021-06-04 01:34:59 +00:00
|
|
|
* @param[in] info Achievements platform type and application ID.
|
2021-05-27 23:12:59 +00:00
|
|
|
*/
|
|
|
|
bool setActiveDomain(const AchievementsInfo &info);
|
2021-03-13 12:22:48 +00:00
|
|
|
bool unsetActiveDomain(); //!< Unset the current active domain.
|
|
|
|
bool isReady() const { return _iniFile != nullptr; } //!< Check whether the domain is ready.
|
2020-09-15 23:39:09 +00:00
|
|
|
|
|
|
|
/**
|
2021-03-13 12:22:48 +00:00
|
|
|
* @name Methods for manipulating individual achievements
|
|
|
|
* @{
|
|
|
|
*/
|
2020-03-16 00:47:21 +00:00
|
|
|
|
2021-05-27 23:12:59 +00:00
|
|
|
/** Set an achievement. Message is automatically displayed with text from active domain.
|
|
|
|
*
|
|
|
|
* @param[in] id Internal ID of the achievement.
|
|
|
|
*/
|
|
|
|
bool setAchievement(const String &id);
|
|
|
|
|
2021-03-13 12:22:48 +00:00
|
|
|
/**
|
2021-05-27 23:13:49 +00:00
|
|
|
* Check if an achievement as achieved.
|
2021-03-13 12:22:48 +00:00
|
|
|
*
|
|
|
|
* @param[in] id Internal ID of the achievement.
|
|
|
|
*/
|
2021-03-13 12:23:47 +00:00
|
|
|
bool isAchieved(const String &id) const;
|
2021-03-13 12:22:48 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Clear an achieved achievement.
|
|
|
|
*
|
|
|
|
* @param[in] id Internal ID of the achievement.
|
|
|
|
*/
|
2020-03-16 00:47:21 +00:00
|
|
|
bool clearAchievement(const String &id);
|
2021-03-13 12:22:48 +00:00
|
|
|
|
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name Methods for manipulating individual statistics
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get a statistic (integer).
|
|
|
|
*
|
|
|
|
* @param[in] id Internal ID of the achievement.
|
|
|
|
*/
|
2021-06-01 20:59:40 +00:00
|
|
|
int getStatInt(const String &id) const;
|
2021-03-13 12:22:48 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set a statistic to an integer number.
|
|
|
|
*
|
|
|
|
* @param[in] id Internal ID of the achievement.
|
|
|
|
* @param[in] value Value to which the statistic is set.
|
|
|
|
*/
|
2020-03-16 00:47:21 +00:00
|
|
|
bool setStatInt(const String &id, int value);
|
2021-03-13 12:22:48 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get a statistic (float).
|
|
|
|
*
|
|
|
|
* @param[in] id Internal ID of the achievement.
|
|
|
|
*/
|
2021-06-01 20:59:40 +00:00
|
|
|
float getStatFloat(const String &id) const;
|
2021-03-13 12:22:48 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set a statistic to a float number.
|
|
|
|
*
|
|
|
|
* @param[in] id Internal ID of the achievement.
|
|
|
|
* @param[in] value Value to which the statistic is set.
|
|
|
|
*/
|
2020-03-16 00:47:21 +00:00
|
|
|
bool setStatFloat(const String &id, float value);
|
|
|
|
|
2021-05-31 01:29:30 +00:00
|
|
|
/**
|
|
|
|
* Get a statistic (raw string).
|
|
|
|
*
|
|
|
|
* @param[in] id Internal ID of the achievement.
|
|
|
|
*/
|
2021-06-01 20:59:40 +00:00
|
|
|
const String getStatRaw(const String &id) const;
|
2021-05-31 01:29:30 +00:00
|
|
|
|
2021-05-29 18:30:13 +00:00
|
|
|
/**
|
|
|
|
* Get an average rate statistic (float).
|
|
|
|
* Calcucated by devision the sum of count by the sum of times.
|
|
|
|
*
|
|
|
|
* @param[in] id Internal ID of the achievement.
|
|
|
|
*/
|
2021-06-01 20:59:40 +00:00
|
|
|
float getAverageRateStatFloat(const String &id) const;
|
2021-05-29 18:30:13 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Update an average rate statistic (float).
|
|
|
|
*
|
|
|
|
* @param[in] id Internal ID of the achievement.
|
|
|
|
* @param[in] count Value to which the statistic count is increased.
|
|
|
|
* @param[in] times Value to which the statistic times is increased.
|
|
|
|
*/
|
|
|
|
bool updateAverageRateStatFloat(const String &id, float count, float times);
|
|
|
|
|
2021-03-13 12:22:48 +00:00
|
|
|
/** @} */
|
2020-09-15 23:39:09 +00:00
|
|
|
|
2021-03-13 12:22:48 +00:00
|
|
|
/**
|
|
|
|
* @name Methods for resetting achievements and statistics
|
|
|
|
* @{
|
|
|
|
*/
|
2020-09-15 23:39:09 +00:00
|
|
|
bool resetAllAchievements(); //!< Reset all achievements.
|
|
|
|
bool resetAllStats(); //!< Reset all statistics.
|
|
|
|
|
2021-03-13 12:22:48 +00:00
|
|
|
/** @} */
|
2020-03-16 00:47:21 +00:00
|
|
|
|
2021-05-30 01:12:09 +00:00
|
|
|
/**
|
|
|
|
* @name Methods for storing platform-specific data
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Store provided key and value pair in additional section.
|
|
|
|
* May be useful for posting achievements to original platform.
|
|
|
|
*
|
|
|
|
* @param[in] id Internal ID of the achievement.
|
|
|
|
* @param[in] value Value to which the statistic is set.
|
|
|
|
*/
|
|
|
|
bool setSpecialString(const String &id, const String &value);
|
|
|
|
|
|
|
|
/** @} */
|
|
|
|
|
2021-06-04 01:36:57 +00:00
|
|
|
/**
|
|
|
|
* @name Methods for getting achievements and statistics descriptions
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get number of achivement descriptions available.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
uint16 getAchievementCount() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get achivement description by index.
|
|
|
|
*
|
|
|
|
* @param[in] index Internal index of the achievement, counted from 0 to (getAchievementCount() - 1)
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
const AchievementDescription *getAchievementDescription(uint16 index) const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get number of stat descriptions available.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
uint16 getStatCount() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get stat description by index.
|
|
|
|
*
|
|
|
|
* @param[in] index Internal index of the stat, counted from 0 to (getStatCount() - 1)
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
const StatDescription *getStatDescription(uint16 index) const;
|
|
|
|
|
|
|
|
/** @} */
|
|
|
|
|
2020-03-16 00:47:21 +00:00
|
|
|
private:
|
2021-06-04 01:34:59 +00:00
|
|
|
bool loadAchievementsData(const char *platform, const char *appId);
|
|
|
|
|
2021-06-01 20:59:40 +00:00
|
|
|
float getStatFloatEx(const String &id, const String §ion) const;
|
|
|
|
bool setStatFloatEx(const String &id, float value, const String §ion) const;
|
2021-05-29 18:30:13 +00:00
|
|
|
|
2020-04-29 08:32:23 +00:00
|
|
|
INIFile *_iniFile;
|
2020-04-28 22:56:54 +00:00
|
|
|
String _iniFileName;
|
2021-06-04 01:34:59 +00:00
|
|
|
Common::Array<StatDescription> _stats;
|
2021-05-27 23:12:59 +00:00
|
|
|
Common::Array<AchievementDescription> _descriptions;
|
2020-03-16 00:47:21 +00:00
|
|
|
};
|
|
|
|
|
2020-09-15 23:39:09 +00:00
|
|
|
/** Shortcut for accessing the Achievements Manager. */
|
2020-03-16 00:47:21 +00:00
|
|
|
#define AchMan Common::AchievementsManager::instance()
|
|
|
|
|
2020-07-08 21:30:36 +00:00
|
|
|
/** @} */
|
2020-03-16 00:47:21 +00:00
|
|
|
|
|
|
|
} // End of namespace Common
|
|
|
|
|
2020-04-29 08:32:23 +00:00
|
|
|
#endif // #ifndef COMMON_ACHIEVEMENTS_MANAGER_H
|