ref: 2bc56af7010e7f40d94dd664b51d86cfd4bd5fc8
parent: 9b6485b5cc5f005a547e8dd3e3d5a8b90838ed99
author: Simon Howard <fraggle@gmail.com>
date: Thu Jan 3 11:05:27 EST 2013
Refactor skill selector to change automatically when switching character class in Hexen mode. Add Strife skills list. Subversion-branch: /branches/v2-branch Subversion-revision: 2557
--- a/src/setup/multiplayer.c
+++ b/src/setup/multiplayer.c
@@ -67,67 +67,48 @@
static char *iwadfile;
-static char *doom_skills[] =
+static char *doom_skills[] =
{
- "I'm too young to die.",
- "Hey, not too rough.",
- "Hurt me plenty.",
- "Ultra-Violence.",
- "NIGHTMARE!",
+ "I'm too young to die.", "Hey, not too rough.", "Hurt me plenty.",
+ "Ultra-Violence.", "NIGHTMARE!",
};
-static char *chex_skills[] =
+static char *chex_skills[] =
{
- "Easy does it",
- "Not so sticky",
- "Gobs of goo",
- "Extreme ooze",
+ "Easy does it", "Not so sticky", "Gobs of goo", "Extreme ooze",
"SUPER SLIMEY!"
};
static char *heretic_skills[] =
{
- "Thou needeth a wet-nurse",
- "Yellowbellies-R-us",
- "Bringest them oneth",
- "Thou art a smite-meister",
- "Black plague possesses thee"
+ "Thou needeth a wet-nurse", "Yellowbellies-R-us", "Bringest them oneth",
+ "Thou art a smite-meister", "Black plague possesses thee"
};
-static char *hexen_skills[] =
+static char *hexen_fighter_skills[] =
{
- "Squire/Altar boy/Apprentice",
- "Knight/Acolyte/Enchanter",
- "Warrior/Priest/Sorceror",
- "Berserker/Cardinal/Warlock",
- "Titan/Pope/Archimage"
+ "Squire", "Knight", "Warrior", "Berserker", "Titan"
};
-static char *character_classes[] =
+static char *hexen_cleric_skills[] =
{
- "Fighter",
- "Cleric",
- "Mage"
+ "Altar boy", "Acolyte", "Priest", "Cardinal", "Pope"
};
-static struct
+static char *hexen_mage_skills[] =
{
- GameMission_t mission;
- char **strings;
-} skills[] =
-{
- { doom, doom_skills },
- { heretic, heretic_skills },
- { hexen, hexen_skills }
+ "Apprentice", "Enchanter", "Sorceror", "Warlock", "Archimage"
};
-static char *gamemodes[] =
+static char *strife_skills[] =
{
- "Co-operative",
- "Deathmatch",
- "Deathmatch 2.0",
+ "Training", "Rookie", "Veteran", "Elite", "Bloodbath"
};
+static char *character_classes[] = { "Fighter", "Cleric", "Mage" };
+
+static char *gamemodes[] = { "Co-operative", "Deathmatch", "Deathmatch 2.0" };
+
static char *strife_gamemodes[] =
{
"Normal deathmatch",
@@ -333,22 +314,40 @@
static void UpdateSkillButton(void)
{
iwad_t *iwad = GetCurrentIWAD();
- int i;
if (IsChexQuest(iwad))
{
skillbutton->values = chex_skills;
}
- else
+ else switch(gamemission)
{
- for (i=0; i<arrlen(skills); ++i)
- {
- if (gamemission == skills[i].mission)
+ default:
+ case doom:
+ skillbutton->values = doom_skills;
+ break;
+
+ case heretic:
+ skillbutton->values = heretic_skills;
+ break;
+
+ case hexen:
+ if (character_class == 0)
{
- skillbutton->values = skills[i].strings;
- break;
+ skillbutton->values = hexen_fighter_skills;
}
- }
+ else if (character_class == 2)
+ {
+ skillbutton->values = hexen_cleric_skills;
+ }
+ else
+ {
+ skillbutton->values = hexen_mage_skills;
+ }
+ break;
+
+ case strife:
+ skillbutton->values = strife_skills;
+ break;
}
}
@@ -686,26 +685,34 @@
TXT_SetWindowAction(window, TXT_HORIZ_CENTER, WadWindowAction());
TXT_SetWindowAction(window, TXT_HORIZ_RIGHT, StartGameAction(multiplayer));
-
+
TXT_SetColumnWidths(gameopt_table, 12, 6);
TXT_AddWidgets(gameopt_table,
TXT_NewLabel("Game"),
iwad_selector = IWADSelector(),
- TXT_NewLabel("Skill"),
- skillbutton = TXT_NewDropdownList(&skill, doom_skills, 5),
- TXT_NewLabel("Level warp"),
- warpbutton = TXT_NewButton2("????", LevelSelectDialog, NULL),
NULL);
if (gamemission == hexen)
{
+ txt_dropdown_list_t *cc_dropdown;
TXT_AddWidgets(gameopt_table,
TXT_NewLabel("Character class "),
- TXT_NewDropdownList(&character_class,
- character_classes, 3),
+ cc_dropdown = TXT_NewDropdownList(&character_class,
+ character_classes, 3),
NULL);
+
+ // Update skill level dropdown when the character class is changed:
+
+ TXT_SignalConnect(cc_dropdown, "changed", UpdateWarpType, NULL);
}
+
+ TXT_AddWidgets(gameopt_table,
+ TXT_NewLabel("Skill"),
+ skillbutton = TXT_NewDropdownList(&skill, doom_skills, 5),
+ TXT_NewLabel("Level warp"),
+ warpbutton = TXT_NewButton2("????", LevelSelectDialog, NULL),
+ NULL);
if (multiplayer)
{