From: Rudolf Polzer Date: Wed, 12 Jan 2011 06:10:25 +0000 (+0100) Subject: start of a gametype list (unused yet) X-Git-Tag: xonotic-v0.5.0~318^2~142 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=760248cd29c7e9f4aa31dea72b54328fd359242f;p=xonotic%2Fxonotic-data.pk3dir.git start of a gametype list (unused yet) --- diff --git a/qcsrc/menu/xonotic/gametypelist.c b/qcsrc/menu/xonotic/gametypelist.c new file mode 100644 index 000000000..cfc47311e --- /dev/null +++ b/qcsrc/menu/xonotic/gametypelist.c @@ -0,0 +1,128 @@ +#ifdef INTERFACE +CLASS(XonoticGametypeList) EXTENDS(XonoticListBox) + METHOD(XonoticGametypeList, configureXonoticGametypeList, void(entity)) + ATTRIB(XonoticGametypeList, rowsPerItem, float, 1) + METHOD(XonoticGametypeList, drawListBoxItem, void(entity, float, vector, float)) + METHOD(XonoticGametypeList, resizeNotify, void(entity, vector, vector, vector, vector)) + METHOD(XonoticGametypeList, setSelected, void(entity, float)) + METHOD(XonoticGametypeList, loadCvars, void(entity)) + METHOD(XonoticGametypeList, saveCvars, void(entity)) + + ATTRIB(XonoticGametypeList, realFontSize, vector, '0 0 0') + ATTRIB(XonoticGametypeList, realUpperMargin, float, 0) + ATTRIB(XonoticGametypeList, columnNameOrigin, float, 0) + ATTRIB(XonoticGametypeList, columnNameSize, float, 0) +ENDCLASS(XonoticGametypeList) +entity makeXonoticGametypeList(); +#endif + +#ifdef IMPLEMENTATION + +#define GAMETYPES \ + GAMETYPE(MAPINFO_TYPE_DEATHMATCH, "Deathmatch") \ + GAMETYPE(MAPINFO_TYPE_LMS, "LMS") \ + GAMETYPE(MAPINFO_TYPE_ARENA, "Arena") \ + GAMETYPE(MAPINFO_TYPE_RUNEMATCH, "Runematch") \ + GAMETYPE(MAPINFO_TYPE_RACE, "Race") \ + GAMETYPE(MAPINFO_TYPE_CTS, "Race CTS") \ + GAMETYPE(MAPINFO_TYPE_TEAM_DEATHMATCH, "TDM") \ + GAMETYPE(MAPINFO_TYPE_CTF, "CTF") \ + GAMETYPE(MAPINFO_TYPE_CA, "Clan Arena") \ + GAMETYPE(MAPINFO_TYPE_DOMINATION, "Domination") \ + GAMETYPE(MAPINFO_TYPE_KEYHUNT, "Key Hunt") \ + GAMETYPE(MAPINFO_TYPE_ASSAULT, "Assault") \ + GAMETYPE(MAPINFO_TYPE_ONSLAUGHT, "Onslaught") \ + GAMETYPE(MAPINFO_TYPE_NEXBALL, "Nexball") \ + GAMETYPE(MAPINFO_TYPE_FREEZETAG, "Freeze Tag") \ + GAMETYPE(MAPINFO_TYPE_KEEPAWAY, "Keepaway") \ + /* nothing */ + +float GameType_GetID(float cnt) +{ + float i; + i = 0; +#define GAMETYPE(id,name) if(i++ == cnt) return id; + GAMETYPES +#undef GAMETYPE + return 0; +} +string GameType_GetName(float cnt) +{ + float i; + i = 0; +#define GAMETYPE(id,name) if(i++ == cnt) return name; + GAMETYPES +#undef GAMETYPE + return "@!#%'n Tuba Throwing"; +} +float GameType_GetCount() +{ + float i; + i = 0; +#define GAMETYPE(id,name) ++i; + GAMETYPES +#undef GAMETYPE + return i; +} + +entity makeXonoticGametypeList(void) +{ + entity me; + me = spawnXonoticGametypeList(); + me.configureXonoticGametypeList(me); + return me; +} +void XonoticGametypeList_configureXonoticGametypeList(entity me) +{ + me.loadCvars(me); + me.configureXonoticListBox(me); +} +void XonoticGametypeList_setSelected(entity me, float i) +{ + SUPER(XonoticGametypeList).setSelected(me, i); + me.saveCvars(me); +} + +void XonoticGametypeList_loadCvars(entity me) +{ + if not(me.cvarName) + return; + + float t; + t = MapInfo_CurrentGametype(); + float i; + for(i = 0; i < GameType_GetCount(); ++i) + if(t == GameType_GetID(i)) + break; + if(i >= GameType_GetCount()) + i = 0; + me.setSelected(me, i); + // do we need this: me.parent.gameTypeChangeNotify(me.parent); // to make sure +} +void XonoticGametypeList_saveCvars(entity me) +{ + float t; + t = GameType_GetID(me.selectedItem); + if(t == MapInfo_CurrentGametype()) + return; + MapInfo_SwitchGameType(t); + me.parent.gameTypeChangeNotify(me.parent); +} +void XonoticGametypeList_drawListBoxItem(entity me, float i, vector absSize, float isSelected) +{ + string s; + if(isSelected) + draw_Fill('0 0 0', '1 1 0', SKINCOLOR_LISTBOX_SELECTED, SKINALPHA_LISTBOX_SELECTED); + s = GameType_GetName(i); + draw_Text(me.realUpperMargin * eY + (me.columnNameOrigin + (me.columnNameSize - draw_TextWidth(s, 0, me.realFontSize)) * 0.5) * eX, s, me.realFontSize, '1 1 1', SKINALPHA_TEXT, 0); +} +void XonoticGametypeList_resizeNotify(entity me, vector relOrigin, vector relSize, vector absOrigin, vector absSize) +{ + SUPER(XonoticServerList).resizeNotify(me, relOrigin, relSize, absOrigin, absSize); + me.realFontSize_y = me.fontSize / (absSize_y * me.itemHeight); + me.realFontSize_x = me.fontSize / (absSize_x * (1 - me.controlWidth)); + me.realUpperMargin = 0.5 * (1 - me.realFontSize_y); + me.columnNameOrigin = 0; + me.columnNameSize = 1; +} +#endif