Start of Easy Mode tweaks (campaign only).
This commit is contained in:
parent
8a0808ce5a
commit
5bbb8b0104
|
@ -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/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/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
|
||||
|
||||
|
|
|
@ -17,7 +17,7 @@
|
|||
|
||||
{
|
||||
"type" : "BT_MISSILE",
|
||||
"damage" : 75,
|
||||
"damage" : 50,
|
||||
"texture" : "gfx/bullets/missile.png",
|
||||
"sound" : "SND_MISSILE",
|
||||
"flags" : "BF_ENGINE+BF_EXPLODES"
|
||||
|
|
|
@ -4,6 +4,7 @@
|
|||
|
||||
"75 30 ADDITIONAL CODE",
|
||||
"0 24 Richard Sweeney",
|
||||
"0 24 cxong",
|
||||
|
||||
"75 30 GRAPHICS",
|
||||
|
||||
|
@ -306,7 +307,7 @@
|
|||
"0 24 twitter.com/tgfcoder",
|
||||
|
||||
"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.",
|
||||
|
||||
|
|
|
@ -5,6 +5,13 @@
|
|||
"description" : "Earn all other trophies",
|
||||
"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",
|
||||
"title" : "Plan B",
|
||||
|
|
|
@ -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
|
||||
}
|
||||
]
|
|
@ -1111,9 +1111,19 @@ void checkSuspicionLevel(void)
|
|||
{
|
||||
battle.suspicionLevel++;
|
||||
battle.suspicionCoolOff = FPS * 30;
|
||||
|
||||
if (game.difficulty == DIFFICULTY_EASY)
|
||||
{
|
||||
battle.suspicionCoolOff = FPS * 60;
|
||||
}
|
||||
}
|
||||
else if (distance <= SCREEN_HEIGHT / 2)
|
||||
{
|
||||
if (game.difficulty == DIFFICULTY_EASY)
|
||||
{
|
||||
battle.suspicionLevel--;
|
||||
}
|
||||
|
||||
battle.suspicionLevel = MAX(battle.suspicionLevel - 1, 0);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -46,3 +46,4 @@ extern Colors colors;
|
|||
extern Dev dev;
|
||||
extern Entity *self;
|
||||
extern Entity *player;
|
||||
extern Game game;
|
||||
|
|
|
@ -470,6 +470,11 @@ static void endCampaign(void)
|
|||
{
|
||||
awardTrophy("CAMPAIGN_COMPLETE");
|
||||
|
||||
if (game.difficulty == DIFFICULTY_NORMAL)
|
||||
{
|
||||
awardTrophy("NORMAL_MODE");
|
||||
}
|
||||
|
||||
postBattle();
|
||||
|
||||
destroyBattle();
|
||||
|
|
|
@ -187,7 +187,7 @@ static void checkCollisions(Bullet *b)
|
|||
|
||||
if (battle.hasSuspicionLevel)
|
||||
{
|
||||
battle.suspicionLevel -= 2;
|
||||
battle.suspicionLevel -= (game.difficulty == DIFFICULTY_EASY) ? 4 : 2;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -55,3 +55,4 @@ extern App app;
|
|||
extern Battle battle;
|
||||
extern Colors colors;
|
||||
extern Entity *player;
|
||||
extern Game game;
|
||||
|
|
|
@ -98,6 +98,10 @@ void doEntities(void)
|
|||
if (--e->shieldRecharge <= 0)
|
||||
{
|
||||
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;
|
||||
}
|
||||
|
@ -179,6 +183,11 @@ void doEntities(void)
|
|||
if (e->killedBy == player && battle.hasSuspicionLevel)
|
||||
{
|
||||
battle.suspicionLevel -= (MAX_SUSPICION_LEVEL * 0.12);
|
||||
|
||||
if (game.difficulty == DIFFICULTY_EASY)
|
||||
{
|
||||
battle.suspicionLevel -= (MAX_SUSPICION_LEVEL * 0.12);
|
||||
}
|
||||
}
|
||||
|
||||
if (e == player)
|
||||
|
|
|
@ -45,3 +45,4 @@ extern Battle battle;
|
|||
extern Dev dev;
|
||||
extern Entity *self;
|
||||
extern Entity *player;
|
||||
extern Game game;
|
||||
|
|
|
@ -94,6 +94,11 @@ Entity *spawnFighter(char *name, int x, int y, int side)
|
|||
{
|
||||
e->aiAggression = 4;
|
||||
}
|
||||
|
||||
if (game.difficulty == DIFFICULTY_EASY)
|
||||
{
|
||||
e->aiAggression = MIN(e->aiAggression, 2);
|
||||
}
|
||||
|
||||
e->action = doAI;
|
||||
e->die = die;
|
||||
|
|
|
@ -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]);
|
||||
|
||||
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)
|
||||
|
@ -214,17 +220,19 @@ static void updateDeathStats(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;
|
||||
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)
|
||||
{
|
||||
playSound(SND_RECHARGED);
|
||||
}
|
||||
|
||||
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)
|
||||
{
|
||||
playSound(SND_RECHARGED);
|
||||
|
|
|
@ -71,6 +71,9 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|||
#define MAX_TARGET_RANGE 65536
|
||||
#define MAX_SYSTEM_POWER 100
|
||||
|
||||
#define DIFFICULTY_EASY 0
|
||||
#define DIFFICULTY_NORMAL 1
|
||||
|
||||
#define BATTLE_AREA_CELLS 50
|
||||
#define BATTLE_AREA_WIDTH (640 * BATTLE_AREA_CELLS)
|
||||
#define BATTLE_AREA_HEIGHT (360 * BATTLE_AREA_CELLS)
|
||||
|
|
|
@ -73,6 +73,7 @@ static char *SQUADRON_TEXT;
|
|||
static char *COMPLETED_TEXT;
|
||||
static char *EPIC_TEXT;
|
||||
static char *OPTIONAL_TEXT;
|
||||
static char *EASY_MODE_TEXT;
|
||||
|
||||
void initGalacticMap(void)
|
||||
{
|
||||
|
@ -87,6 +88,7 @@ void initGalacticMap(void)
|
|||
memset(&app.keyboard, 0, sizeof(int) * MAX_KEYBOARD_KEYS);
|
||||
|
||||
MISSIONS_TEXT = _("Missions: %d / %d");
|
||||
EASY_MODE_TEXT = _("Easy Mode");
|
||||
PILOT_TEXT = _("Pilot: %s");
|
||||
CRAFT_TEXT = _("Craft: %s");
|
||||
SQUADRON_TEXT = _("Squadron: %s");
|
||||
|
@ -576,6 +578,11 @@ static void drawInfoBars(void)
|
|||
SDL_SetRenderDrawBlendMode(app.renderer, SDL_BLENDMODE_NONE);
|
||||
|
||||
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)
|
||||
|
|
|
@ -35,6 +35,11 @@ static void options(void);
|
|||
static void credits(void);
|
||||
static void quit(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 *logo;
|
||||
|
@ -86,6 +91,14 @@ void initTitle(void)
|
|||
getWidget("credits", "title")->action = credits;
|
||||
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", "trophies")->action = ok;
|
||||
|
||||
|
@ -190,6 +203,10 @@ static void draw(void)
|
|||
drawWidgets("title");
|
||||
break;
|
||||
|
||||
case SHOW_CAMPAIGN:
|
||||
drawWidgets("campaign");
|
||||
break;
|
||||
|
||||
case SHOW_STATS:
|
||||
drawStats();
|
||||
break;
|
||||
|
@ -227,6 +244,44 @@ static void handleKeyboard(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();
|
||||
|
||||
initGalacticMap();
|
||||
|
|
|
@ -24,6 +24,8 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|||
#define SHOW_STATS 1
|
||||
#define SHOW_OPTIONS 2
|
||||
#define SHOW_TROPHIES 3
|
||||
#define SHOW_CAMPAIGN 4
|
||||
#define SHOW_CAMPAIGN_NEW 5
|
||||
|
||||
#define NUM_FIGHTERS 12
|
||||
|
||||
|
|
|
@ -424,6 +424,7 @@ typedef struct {
|
|||
Mission challengeMissionHead;
|
||||
Mission *currentMission;
|
||||
char selectedStarSystem[MAX_NAME_LENGTH];
|
||||
int difficulty;
|
||||
int completedMissions;
|
||||
int availableMissions;
|
||||
int totalMissions;
|
||||
|
|
|
@ -36,6 +36,8 @@ void loadGame(void)
|
|||
root = cJSON_Parse(text);
|
||||
|
||||
gameJSON = cJSON_GetObjectItem(root, "game");
|
||||
|
||||
game.difficulty = lookup(getJSONValueStr(gameJSON, "difficulty", "DIFFICULTY_NORMAL"));
|
||||
|
||||
STRNCPY(game.selectedStarSystem, cJSON_GetObjectItem(gameJSON, "selectedStarSystem")->valuestring, MAX_NAME_LENGTH);
|
||||
|
||||
|
|
|
@ -30,5 +30,6 @@ extern char *getSaveFilePath(char *filename);
|
|||
extern char *getLookupName(char *prefix, long num);
|
||||
extern StarSystem *getStarSystem(char *name);
|
||||
extern Trophy *getTrophy(char *id);
|
||||
extern char *getJSONValueStr(cJSON *node, char *name, char *defValue);
|
||||
|
||||
extern Game game;
|
||||
|
|
|
@ -205,6 +205,9 @@ void initLookups(void)
|
|||
addLookup("TROPHY_SILVER", TROPHY_SILVER);
|
||||
addLookup("TROPHY_GOLD", TROPHY_GOLD);
|
||||
addLookup("TROPHY_PLATINUM", TROPHY_PLATINUM);
|
||||
|
||||
addLookup("DIFFICULTY_NORMAL", DIFFICULTY_NORMAL);
|
||||
addLookup("DIFFICULTY_EASY", DIFFICULTY_EASY);
|
||||
}
|
||||
|
||||
static void addLookup(char *name, long value)
|
||||
|
|
|
@ -38,6 +38,8 @@ void saveGame(void)
|
|||
gameJSON = cJSON_CreateObject();
|
||||
cJSON_AddItemToObject(root, "game", gameJSON);
|
||||
|
||||
cJSON_AddStringToObject(gameJSON, "difficulty", getLookupName("DIFFICULTY_", game.difficulty));
|
||||
|
||||
cJSON_AddStringToObject(gameJSON, "selectedStarSystem", game.selectedStarSystem);
|
||||
|
||||
saveStarSystems(gameJSON);
|
||||
|
|
Loading…
Reference in New Issue