From: Rudolf Polzer <divverent@alientrap.org>
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 0000000000..cfc47311e1
--- /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