Add custom karma folder graphics

Closes #38
This commit is contained in:
Alexander Batalov 2022-06-09 09:53:41 +03:00
parent ba1715d9b0
commit e35594040d
3 changed files with 113 additions and 1 deletions

View File

@ -23,6 +23,7 @@
#include "platform_compat.h" #include "platform_compat.h"
#include "proto.h" #include "proto.h"
#include "scripts.h" #include "scripts.h"
#include "sfall_config.h"
#include "skill.h" #include "skill.h"
#include "stat.h" #include "stat.h"
#include "text_font.h" #include "text_font.h"
@ -36,6 +37,8 @@
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include <vector>
#define RENDER_ALL_STATS 7 #define RENDER_ALL_STATS 7
#define EDITOR_WINDOW_WIDTH 640 #define EDITOR_WINDOW_WIDTH 640
@ -581,6 +584,13 @@ unsigned char _free_perk;
// 0x570A2A // 0x570A2A
unsigned char _first_skill_list; unsigned char _first_skill_list;
struct CustomKarmaFolderDescription {
int frmId;
int threshold;
};
static std::vector<CustomKarmaFolderDescription> gCustomKarmaFolderDescriptions;
// 0x431DF8 // 0x431DF8
int _editor_design(bool isCreationMode) int _editor_design(bool isCreationMode)
{ {
@ -1078,6 +1088,9 @@ int characterEditorWindowInit()
return -1; return -1;
} }
// SFALL: Custom karma folder.
customKarmaFolderInit();
soundContinueAll(); soundContinueAll();
for (i = 0; i < EDITOR_GRAPHIC_COUNT; i++) { for (i = 0; i < EDITOR_GRAPHIC_COUNT; i++) {
@ -1637,6 +1650,9 @@ void characterEditorWindowFree()
// NOTE: Uninline. // NOTE: Uninline.
karmaFree(); karmaFree();
// SFALL: Custom karma folder.
customKarmaFolderFree();
messageListFree(&editorMessageList); messageListFree(&editorMessageList);
interfaceBarRefresh(); interfaceBarRefresh();
@ -5372,7 +5388,8 @@ void editorRenderKarma()
} }
if (!hasSelection) { if (!hasSelection) {
_folder_card_fid = 47; // SFALL: Custom karma folder.
_folder_card_fid = customKarmaFolderGetFrmId();
_folder_card_title = getmsg(&editorMessageList, &editorMessageListItem, 125); _folder_card_title = getmsg(&editorMessageList, &editorMessageListItem, 125);
_folder_card_title2 = NULL; _folder_card_title2 = NULL;
_folder_card_desc = getmsg(&editorMessageList, &editorMessageListItem, 128); _folder_card_desc = getmsg(&editorMessageList, &editorMessageListItem, 128);
@ -6851,3 +6868,92 @@ int genericReputationCompare(const void* a1, const void* a2)
} }
return 0; return 0;
} }
void customKarmaFolderInit()
{
char* karmaFrms = NULL;
configGetString(&gSfallConfig, SFALL_CONFIG_MISC_KEY, SFALL_CONFIG_KARMA_FRMS_KEY, &karmaFrms);
if (karmaFrms != NULL && karmaFrms[0] == '\0') {
karmaFrms = NULL;
}
if (karmaFrms == NULL) {
return;
}
char* karmaPoints = NULL;
configGetString(&gSfallConfig, SFALL_CONFIG_MISC_KEY, SFALL_CONFIG_KARMA_POINTS_KEY, &karmaPoints);
if (karmaPoints != NULL && karmaPoints[0] == '\0') {
karmaPoints = NULL;
}
if (karmaPoints == NULL) {
return;
}
int karmaFrmsCount = 0;
for (char* pch = karmaFrms; pch != NULL; pch = strchr(pch + 1, ',')) {
karmaFrmsCount++;
}
int karmaPointsCount = 0;
for (char* pch = karmaPoints; pch != NULL; pch = strchr(pch + 1, ',')) {
karmaPointsCount++;
}
gCustomKarmaFolderDescriptions.resize(karmaFrmsCount);
for (int index = 0; index < karmaFrmsCount; index++) {
char* pch;
pch = strchr(karmaFrms, ',');
if (pch != NULL) {
*pch = '\0';
}
gCustomKarmaFolderDescriptions[index].frmId = atoi(karmaFrms);
if (pch != NULL) {
*pch = ',';
}
karmaFrms = pch + 1;
if (index < karmaPointsCount) {
pch = strchr(karmaPoints, ',');
if (pch != NULL) {
*pch = '\0';
}
gCustomKarmaFolderDescriptions[index].threshold = atoi(karmaPoints);
if (pch != NULL) {
*pch = ',';
}
karmaPoints = pch + 1;
} else {
gCustomKarmaFolderDescriptions[index].threshold = INT_MAX;
}
}
}
void customKarmaFolderFree()
{
gCustomKarmaFolderDescriptions.clear();
}
int customKarmaFolderGetFrmId()
{
if (gCustomKarmaFolderDescriptions.empty()) {
return 47;
}
int reputation = gGameGlobalVars[GVAR_PLAYER_REPUTATION];
for (auto& entry : gCustomKarmaFolderDescriptions) {
if (reputation < entry.threshold) {
return entry.frmId;
}
}
return gCustomKarmaFolderDescriptions.end()->frmId;
}

View File

@ -311,4 +311,8 @@ int genericReputationInit();
void genericReputationFree(); void genericReputationFree();
int genericReputationCompare(const void* a1, const void* a2); int genericReputationCompare(const void* a1, const void* a2);
void customKarmaFolderInit();
void customKarmaFolderFree();
int customKarmaFolderGetFrmId();
#endif /* CHARACTER_EDITOR_H */ #endif /* CHARACTER_EDITOR_H */

View File

@ -15,6 +15,8 @@
#define SFALL_CONFIG_MAIN_MENU_FONT_COLOR "MainMenuFontColour" #define SFALL_CONFIG_MAIN_MENU_FONT_COLOR "MainMenuFontColour"
#define SFALL_CONFIG_SKIP_OPENING_MOVIES_KEY "SkipOpeningMovies" #define SFALL_CONFIG_SKIP_OPENING_MOVIES_KEY "SkipOpeningMovies"
#define SFALL_CONFIG_STARTING_MAP_KEY "StartingMap" #define SFALL_CONFIG_STARTING_MAP_KEY "StartingMap"
#define SFALL_CONFIG_KARMA_FRMS_KEY "KarmaFRMs"
#define SFALL_CONFIG_KARMA_POINTS_KEY "KarmaPoints"
#define SFALL_CONFIG_DISPLAY_KARMA_CHANGES_KEY "DisplayKarmaChanges" #define SFALL_CONFIG_DISPLAY_KARMA_CHANGES_KEY "DisplayKarmaChanges"
extern bool gSfallConfigInitialized; extern bool gSfallConfigInitialized;