Start of Easy Mode tweaks (campaign only).

This commit is contained in:
Steve 2017-05-14 14:02:22 +01:00
parent 8a0808ce5a
commit 5bbb8b0104
23 changed files with 195 additions and 6 deletions

View File

@ -23,6 +23,7 @@ gfx/trophies/gold.png - dervied from Trophy icon, by Lorc (CC BY 3.0): http://ga
gfx/trophies/platinum.png - dervied from Trophy icon, by Lorc (CC BY 3.0): http://game-icons.net/lorc/originals/trophy.html gfx/trophies/platinum.png - dervied from Trophy icon, by Lorc (CC BY 3.0): http://game-icons.net/lorc/originals/trophy.html
gfx/trophies/silver.png - dervied from Trophy icon, by Lorc (CC BY 3.0): http://game-icons.net/lorc/originals/trophy.html gfx/trophies/silver.png - dervied from Trophy icon, by Lorc (CC BY 3.0): http://game-icons.net/lorc/originals/trophy.html
gfx/trophies/unearned.png - dervied from Trophy icon, by Lorc (CC BY 3.0): http://game-icons.net/lorc/originals/trophy.html gfx/trophies/unearned.png - dervied from Trophy icon, by Lorc (CC BY 3.0): http://game-icons.net/lorc/originals/trophy.html
gfx/input/mousePointerMove.png, by LoneCoder / para (CC0)
All other graphics are CC BY-NC-SA 3.0, with the following attribution: Copyright 2015-2016, Stephen J Sweeney | www.battleforthesolarsystem.com All other graphics are CC BY-NC-SA 3.0, with the following attribution: Copyright 2015-2016, Stephen J Sweeney | www.battleforthesolarsystem.com

View File

@ -17,7 +17,7 @@
{ {
"type" : "BT_MISSILE", "type" : "BT_MISSILE",
"damage" : 75, "damage" : 50,
"texture" : "gfx/bullets/missile.png", "texture" : "gfx/bullets/missile.png",
"sound" : "SND_MISSILE", "sound" : "SND_MISSILE",
"flags" : "BF_ENGINE+BF_EXPLODES" "flags" : "BF_ENGINE+BF_EXPLODES"

View File

@ -4,6 +4,7 @@
"75 30 ADDITIONAL CODE", "75 30 ADDITIONAL CODE",
"0 24 Richard Sweeney", "0 24 Richard Sweeney",
"0 24 cxong",
"75 30 GRAPHICS", "75 30 GRAPHICS",
@ -306,7 +307,7 @@
"0 24 twitter.com/tgfcoder", "0 24 twitter.com/tgfcoder",
"75 30 SPECIAL THANKS", "75 30 SPECIAL THANKS",
"0 24 akien-mga, bentley, Bertram25, ChliHug, Imerion, nnesse, ptitSeb, Szunti", "0 24 akien-mga, bentley, Bertram25, ChliHug, Imerion, nnesse, ptitSeb, Szunti, cxong",
"150 24 This is a work of fiction. Names, characters, businesses, places, events and incidents are either the products of the author's imagination or used in a fictitious manner. Any resemblance to actual persons, living or dead, or actual events is purely coincidental. The Battle for the Solar System : The Pandoran War is (C) 2015-2016, Stephen J Sweeney, Some Rights Reserved. The Battle for the Solar System and all related materials (including, but not limited to, characters, setting, and story elements) are (C) 2009-2016, Stephen J Sweeney, All Rights Reserved.", "150 24 This is a work of fiction. Names, characters, businesses, places, events and incidents are either the products of the author's imagination or used in a fictitious manner. Any resemblance to actual persons, living or dead, or actual events is purely coincidental. The Battle for the Solar System : The Pandoran War is (C) 2015-2016, Stephen J Sweeney, Some Rights Reserved. The Battle for the Solar System and all related materials (including, but not limited to, characters, setting, and story elements) are (C) 2009-2016, Stephen J Sweeney, All Rights Reserved.",

View File

@ -5,6 +5,13 @@
"description" : "Earn all other trophies", "description" : "Earn all other trophies",
"value" : "TROPHY_PLATINUM" "value" : "TROPHY_PLATINUM"
}, },
{
"id" : "NORMAL_MODE",
"title" : "Fought back against the odds",
"description" : "Finished the campaign on normal",
"value" : "TROPHY_GOLD",
"hidden" : 1
},
{ {
"id" : "CAMPAIGN_COMPLETE", "id" : "CAMPAIGN_COMPLETE",
"title" : "Plan B", "title" : "Plan B",

View File

@ -0,0 +1,64 @@
[
{
"name" : "new",
"group" : "campaign",
"type" : "WT_BUTTON",
"text" : "New Campaign",
"x" : -1,
"y" : 300,
"w" : 200,
"h": 34
},
{
"name" : "continue",
"group" : "campaign",
"type" : "WT_BUTTON",
"text" : "Continue Campaign",
"x" : -1,
"y" : 400,
"w" : 200,
"h": 34
},
{
"name" : "back",
"group" : "campaign",
"type" : "WT_BUTTON",
"text" : "Back",
"x" : -1,
"y" : 680,
"w" : 200,
"h": 34
},
{
"name" : "easy",
"group" : "campaignDifficulty",
"type" : "WT_BUTTON",
"text" : "Easy Mode",
"x" : -1,
"y" : 200,
"w" : 200,
"h": 34
},
{
"name" : "normal",
"group" : "campaignDifficulty",
"type" : "WT_BUTTON",
"text" : "Normal",
"x" : -1,
"y" : 400,
"w" : 200,
"h": 34
},
{
"name" : "back",
"group" : "campaignDifficulty",
"type" : "WT_BUTTON",
"text" : "Back",
"x" : -1,
"y" : 680,
"w" : 200,
"h": 34
}
]

View File

@ -1111,9 +1111,19 @@ void checkSuspicionLevel(void)
{ {
battle.suspicionLevel++; battle.suspicionLevel++;
battle.suspicionCoolOff = FPS * 30; battle.suspicionCoolOff = FPS * 30;
if (game.difficulty == DIFFICULTY_EASY)
{
battle.suspicionCoolOff = FPS * 60;
}
} }
else if (distance <= SCREEN_HEIGHT / 2) else if (distance <= SCREEN_HEIGHT / 2)
{ {
if (game.difficulty == DIFFICULTY_EASY)
{
battle.suspicionLevel--;
}
battle.suspicionLevel = MAX(battle.suspicionLevel - 1, 0); battle.suspicionLevel = MAX(battle.suspicionLevel - 1, 0);
} }
} }

View File

@ -46,3 +46,4 @@ extern Colors colors;
extern Dev dev; extern Dev dev;
extern Entity *self; extern Entity *self;
extern Entity *player; extern Entity *player;
extern Game game;

View File

@ -470,6 +470,11 @@ static void endCampaign(void)
{ {
awardTrophy("CAMPAIGN_COMPLETE"); awardTrophy("CAMPAIGN_COMPLETE");
if (game.difficulty == DIFFICULTY_NORMAL)
{
awardTrophy("NORMAL_MODE");
}
postBattle(); postBattle();
destroyBattle(); destroyBattle();

View File

@ -187,7 +187,7 @@ static void checkCollisions(Bullet *b)
if (battle.hasSuspicionLevel) if (battle.hasSuspicionLevel)
{ {
battle.suspicionLevel -= 2; battle.suspicionLevel -= (game.difficulty == DIFFICULTY_EASY) ? 4 : 2;
} }
} }

View File

@ -55,3 +55,4 @@ extern App app;
extern Battle battle; extern Battle battle;
extern Colors colors; extern Colors colors;
extern Entity *player; extern Entity *player;
extern Game game;

View File

@ -98,6 +98,10 @@ void doEntities(void)
if (--e->shieldRecharge <= 0) if (--e->shieldRecharge <= 0)
{ {
e->shield = MIN(e->shield + 1, e->maxShield); e->shield = MIN(e->shield + 1, e->maxShield);
if (e == player && !game.currentMission->challengeData.isChallenge && game.difficulty == DIFFICULTY_EASY)
{
e->shield = MIN(e->shield + 1, e->maxShield);
}
e->shieldRecharge = e->shieldRechargeRate; e->shieldRecharge = e->shieldRechargeRate;
} }
@ -179,6 +183,11 @@ void doEntities(void)
if (e->killedBy == player && battle.hasSuspicionLevel) if (e->killedBy == player && battle.hasSuspicionLevel)
{ {
battle.suspicionLevel -= (MAX_SUSPICION_LEVEL * 0.12); battle.suspicionLevel -= (MAX_SUSPICION_LEVEL * 0.12);
if (game.difficulty == DIFFICULTY_EASY)
{
battle.suspicionLevel -= (MAX_SUSPICION_LEVEL * 0.12);
}
} }
if (e == player) if (e == player)

View File

@ -45,3 +45,4 @@ extern Battle battle;
extern Dev dev; extern Dev dev;
extern Entity *self; extern Entity *self;
extern Entity *player; extern Entity *player;
extern Game game;

View File

@ -95,6 +95,11 @@ Entity *spawnFighter(char *name, int x, int y, int side)
e->aiAggression = 4; e->aiAggression = 4;
} }
if (game.difficulty == DIFFICULTY_EASY)
{
e->aiAggression = MIN(e->aiAggression, 2);
}
e->action = doAI; e->action = doAI;
e->die = die; e->die = die;

View File

@ -94,6 +94,12 @@ void initPlayer(void)
game.stats[STAT_EPIC_KILL_STREAK] = MAX(game.stats[STAT_EPIC_KILL_STREAK], battle.stats[STAT_EPIC_KILL_STREAK]); game.stats[STAT_EPIC_KILL_STREAK] = MAX(game.stats[STAT_EPIC_KILL_STREAK], battle.stats[STAT_EPIC_KILL_STREAK]);
battle.stats[STAT_EPIC_KILL_STREAK] = 0; battle.stats[STAT_EPIC_KILL_STREAK] = 0;
if (!game.currentMission->challengeData.isChallenge && game.difficulty == DIFFICULTY_EASY)
{
player->health = player->maxHealth = (player->maxHealth * 1.25);
player->shield = player->maxShield = (player->maxShield * 1.25);
}
} }
static void setPilotName(void) static void setPilotName(void)
@ -214,17 +220,19 @@ static void updateDeathStats(void)
static void rechargeBoostECM(void) static void rechargeBoostECM(void)
{ {
int boostTimer, ecmTimer; int boostTimer, ecmTimer, i;
i = (game.currentMission->challengeData.isChallenge || game.difficulty == DIFFICULTY_NORMAL) ? 1 : 2;
boostTimer = battle.boostTimer; boostTimer = battle.boostTimer;
battle.boostTimer = MIN(battle.boostTimer + 1, BOOST_RECHARGE_TIME); battle.boostTimer = MIN(battle.boostTimer + i, BOOST_RECHARGE_TIME);
if (boostTimer < BOOST_RECHARGE_TIME && battle.boostTimer == BOOST_RECHARGE_TIME) if (boostTimer < BOOST_RECHARGE_TIME && battle.boostTimer == BOOST_RECHARGE_TIME)
{ {
playSound(SND_RECHARGED); playSound(SND_RECHARGED);
} }
ecmTimer = battle.ecmTimer; ecmTimer = battle.ecmTimer;
battle.ecmTimer = MIN(battle.ecmTimer + 1, ECM_RECHARGE_TIME); battle.ecmTimer = MIN(battle.ecmTimer + i, ECM_RECHARGE_TIME);
if (ecmTimer < ECM_RECHARGE_TIME && battle.ecmTimer == ECM_RECHARGE_TIME) if (ecmTimer < ECM_RECHARGE_TIME && battle.ecmTimer == ECM_RECHARGE_TIME)
{ {
playSound(SND_RECHARGED); playSound(SND_RECHARGED);

View File

@ -71,6 +71,9 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#define MAX_TARGET_RANGE 65536 #define MAX_TARGET_RANGE 65536
#define MAX_SYSTEM_POWER 100 #define MAX_SYSTEM_POWER 100
#define DIFFICULTY_EASY 0
#define DIFFICULTY_NORMAL 1
#define BATTLE_AREA_CELLS 50 #define BATTLE_AREA_CELLS 50
#define BATTLE_AREA_WIDTH (640 * BATTLE_AREA_CELLS) #define BATTLE_AREA_WIDTH (640 * BATTLE_AREA_CELLS)
#define BATTLE_AREA_HEIGHT (360 * BATTLE_AREA_CELLS) #define BATTLE_AREA_HEIGHT (360 * BATTLE_AREA_CELLS)

View File

@ -73,6 +73,7 @@ static char *SQUADRON_TEXT;
static char *COMPLETED_TEXT; static char *COMPLETED_TEXT;
static char *EPIC_TEXT; static char *EPIC_TEXT;
static char *OPTIONAL_TEXT; static char *OPTIONAL_TEXT;
static char *EASY_MODE_TEXT;
void initGalacticMap(void) void initGalacticMap(void)
{ {
@ -87,6 +88,7 @@ void initGalacticMap(void)
memset(&app.keyboard, 0, sizeof(int) * MAX_KEYBOARD_KEYS); memset(&app.keyboard, 0, sizeof(int) * MAX_KEYBOARD_KEYS);
MISSIONS_TEXT = _("Missions: %d / %d"); MISSIONS_TEXT = _("Missions: %d / %d");
EASY_MODE_TEXT = _("Easy Mode");
PILOT_TEXT = _("Pilot: %s"); PILOT_TEXT = _("Pilot: %s");
CRAFT_TEXT = _("Craft: %s"); CRAFT_TEXT = _("Craft: %s");
SQUADRON_TEXT = _("Squadron: %s"); SQUADRON_TEXT = _("Squadron: %s");
@ -576,6 +578,11 @@ static void drawInfoBars(void)
SDL_SetRenderDrawBlendMode(app.renderer, SDL_BLENDMODE_NONE); SDL_SetRenderDrawBlendMode(app.renderer, SDL_BLENDMODE_NONE);
drawText((SCREEN_WIDTH / 2), 5, 18, TA_CENTER, colors.white, MISSIONS_TEXT, game.completedMissions, game.availableMissions); drawText((SCREEN_WIDTH / 2), 5, 18, TA_CENTER, colors.white, MISSIONS_TEXT, game.completedMissions, game.availableMissions);
if (game.difficulty == DIFFICULTY_EASY)
{
drawText(10, 5, 14, TA_LEFT, colors.lightGrey, EASY_MODE_TEXT);
}
} }
static void selectStarSystem(void) static void selectStarSystem(void)

View File

@ -35,6 +35,11 @@ static void options(void);
static void credits(void); static void credits(void);
static void quit(void); static void quit(void);
static void returnFromOptions(void); static void returnFromOptions(void);
static void newCampaign(void);
static void easyCampaign(void);
static void normalCampaign(void);
static void continueCampaign(void);
static void back(void);
static SDL_Texture *background; static SDL_Texture *background;
static SDL_Texture *logo; static SDL_Texture *logo;
@ -86,6 +91,14 @@ void initTitle(void)
getWidget("credits", "title")->action = credits; getWidget("credits", "title")->action = credits;
getWidget("quit", "title")->action = quit; getWidget("quit", "title")->action = quit;
getWidget("new", "campaign")->action = newCampaign;
getWidget("continue", "campaign")->action = continueCampaign;
getWidget("back", "campaign")->action = back;
getWidget("easy", "campaignDifficulty")->action = easyCampaign;
getWidget("normal", "campaignDifficulty")->action = normalCampaign;
getWidget("back", "campaignDifficulty")->action = back;
getWidget("ok", "stats")->action = ok; getWidget("ok", "stats")->action = ok;
getWidget("ok", "trophies")->action = ok; getWidget("ok", "trophies")->action = ok;
@ -190,6 +203,10 @@ static void draw(void)
drawWidgets("title"); drawWidgets("title");
break; break;
case SHOW_CAMPAIGN:
drawWidgets("campaign");
break;
case SHOW_STATS: case SHOW_STATS:
drawStats(); drawStats();
break; break;
@ -227,6 +244,44 @@ static void handleKeyboard(void)
static void campaign(void) static void campaign(void)
{ {
show = SHOW_CAMPAIGN;
}
static void newCampaign(void)
{
}
static void continueCampaign(void)
{
}
static void back(void)
{
switch (show)
{
case SHOW_CAMPAIGN:
show = SHOW_TITLE;
break;
case SHOW_CAMPAIGN_NEW:
show = SHOW_CAMPAIGN;
break;
}
}
static void easyCampaign(void)
{
game.difficulty = DIFFICULTY_EASY;
destroyBattle();
initGalacticMap();
}
static void normalCampaign(void)
{
game.difficulty = DIFFICULTY_NORMAL;
destroyBattle(); destroyBattle();
initGalacticMap(); initGalacticMap();

View File

@ -24,6 +24,8 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#define SHOW_STATS 1 #define SHOW_STATS 1
#define SHOW_OPTIONS 2 #define SHOW_OPTIONS 2
#define SHOW_TROPHIES 3 #define SHOW_TROPHIES 3
#define SHOW_CAMPAIGN 4
#define SHOW_CAMPAIGN_NEW 5
#define NUM_FIGHTERS 12 #define NUM_FIGHTERS 12

View File

@ -424,6 +424,7 @@ typedef struct {
Mission challengeMissionHead; Mission challengeMissionHead;
Mission *currentMission; Mission *currentMission;
char selectedStarSystem[MAX_NAME_LENGTH]; char selectedStarSystem[MAX_NAME_LENGTH];
int difficulty;
int completedMissions; int completedMissions;
int availableMissions; int availableMissions;
int totalMissions; int totalMissions;

View File

@ -37,6 +37,8 @@ void loadGame(void)
gameJSON = cJSON_GetObjectItem(root, "game"); gameJSON = cJSON_GetObjectItem(root, "game");
game.difficulty = lookup(getJSONValueStr(gameJSON, "difficulty", "DIFFICULTY_NORMAL"));
STRNCPY(game.selectedStarSystem, cJSON_GetObjectItem(gameJSON, "selectedStarSystem")->valuestring, MAX_NAME_LENGTH); STRNCPY(game.selectedStarSystem, cJSON_GetObjectItem(gameJSON, "selectedStarSystem")->valuestring, MAX_NAME_LENGTH);
loadStarSystems(cJSON_GetObjectItem(gameJSON, "starSystems")); loadStarSystems(cJSON_GetObjectItem(gameJSON, "starSystems"));

View File

@ -30,5 +30,6 @@ extern char *getSaveFilePath(char *filename);
extern char *getLookupName(char *prefix, long num); extern char *getLookupName(char *prefix, long num);
extern StarSystem *getStarSystem(char *name); extern StarSystem *getStarSystem(char *name);
extern Trophy *getTrophy(char *id); extern Trophy *getTrophy(char *id);
extern char *getJSONValueStr(cJSON *node, char *name, char *defValue);
extern Game game; extern Game game;

View File

@ -205,6 +205,9 @@ void initLookups(void)
addLookup("TROPHY_SILVER", TROPHY_SILVER); addLookup("TROPHY_SILVER", TROPHY_SILVER);
addLookup("TROPHY_GOLD", TROPHY_GOLD); addLookup("TROPHY_GOLD", TROPHY_GOLD);
addLookup("TROPHY_PLATINUM", TROPHY_PLATINUM); addLookup("TROPHY_PLATINUM", TROPHY_PLATINUM);
addLookup("DIFFICULTY_NORMAL", DIFFICULTY_NORMAL);
addLookup("DIFFICULTY_EASY", DIFFICULTY_EASY);
} }
static void addLookup(char *name, long value) static void addLookup(char *name, long value)

View File

@ -38,6 +38,8 @@ void saveGame(void)
gameJSON = cJSON_CreateObject(); gameJSON = cJSON_CreateObject();
cJSON_AddItemToObject(root, "game", gameJSON); cJSON_AddItemToObject(root, "game", gameJSON);
cJSON_AddStringToObject(gameJSON, "difficulty", getLookupName("DIFFICULTY_", game.difficulty));
cJSON_AddStringToObject(gameJSON, "selectedStarSystem", game.selectedStarSystem); cJSON_AddStringToObject(gameJSON, "selectedStarSystem", game.selectedStarSystem);
saveStarSystems(gameJSON); saveStarSystems(gameJSON);