]> git.xonotic.org Git - xonotic/xonotic-data.pk3dir.git/commitdiff
Merge remote branch 'origin/master' into samual/menu_updates
authorSamual <samual@xonotic.org>
Tue, 10 Jan 2012 19:13:15 +0000 (14:13 -0500)
committerSamual <samual@xonotic.org>
Tue, 10 Jan 2012 19:13:15 +0000 (14:13 -0500)
Conflicts:
defaultXonotic.cfg

19 files changed:
defaultXonotic.cfg
gfx/menu/luminos/gametype-icon-ar.tga [new file with mode: 0644]
gfx/menu/luminos/gametype-icon-as.tga [new file with mode: 0644]
gfx/menu/luminos/gametype-icon-ctf.tga [new file with mode: 0644]
gfx/menu/luminos/gametype-icon-cts.tga [new file with mode: 0644]
gfx/menu/luminos/gametype-icon-dm.tga [new file with mode: 0644]
gfx/menu/luminos/gametype-icon-dom.tga [new file with mode: 0644]
gfx/menu/luminos/gametype-icon-duel.tga [new file with mode: 0644]
gfx/menu/luminos/gametype-icon-ft.tga [new file with mode: 0644]
gfx/menu/luminos/gametype-icon-kh.tga [new file with mode: 0644]
gfx/menu/luminos/gametype-icon-lms.tga [new file with mode: 0644]
gfx/menu/luminos/gametype-icon-nb.tga [new file with mode: 0644]
gfx/menu/luminos/gametype-icon-race.tga [new file with mode: 0644]
gfx/menu/luminos/gametype-icon-rune.tga [new file with mode: 0644]
gfx/menu/luminos/gametype-icon-tdm.tga [new file with mode: 0644]
qcsrc/menu/xonotic/dialog_singleplayer.c
qcsrc/menu/xonotic/gametypelist.c
qcsrc/menu/xonotic/util.qc
qcsrc/menu/xonotic/util.qh

index 52c14b2be90d9f41000144d0ad6a9060b27e3e35..94b6cc6324edc5d4560257f0e1ddce2efeb9ef98 100644 (file)
@@ -22,6 +22,10 @@ gameversion_max 65535 // git builds see all versions
 //   gameversion_min = (gameversion / 100) * 100 - 100
 //   gameversion_max = (gameversion / 100) * 100 + 199
 
+// changes a cvar and reports it to the server (for the menu to notify the
+// server about changes)
+alias setreport "set \"$1\" \"$2\" ; sendcvar \"$1\""
+
 seta cl_firststart "" "how many times the client has been run"
 seta cl_startcount 0 "how many times the client has been run"
 
@@ -1136,7 +1140,7 @@ set quit_and_redirect ""  "set to an IP to redirect all players at the end of the
 set g_campaign 0
 set g_campaign_forceteam 0 "Forces the player to a given team in campaign mode, 1 = red, 2 = blue, 3 = yellow, 4 = pink"
 seta g_campaign_name "xonoticbeta"
-set g_campaign_skill 0
+seta g_campaign_skill -1 // -2 easy -1 medium 0 hard
 
 alias singleplayer_start "g_campaign_index 0; set scmenu_campaign_goto 0"
 alias singleplayer_continue "set scmenu_campaign_goto -1"
diff --git a/gfx/menu/luminos/gametype-icon-ar.tga b/gfx/menu/luminos/gametype-icon-ar.tga
new file mode 100644 (file)
index 0000000..f49fa28
Binary files /dev/null and b/gfx/menu/luminos/gametype-icon-ar.tga differ
diff --git a/gfx/menu/luminos/gametype-icon-as.tga b/gfx/menu/luminos/gametype-icon-as.tga
new file mode 100644 (file)
index 0000000..59bdfc1
Binary files /dev/null and b/gfx/menu/luminos/gametype-icon-as.tga differ
diff --git a/gfx/menu/luminos/gametype-icon-ctf.tga b/gfx/menu/luminos/gametype-icon-ctf.tga
new file mode 100644 (file)
index 0000000..cc3bc7c
Binary files /dev/null and b/gfx/menu/luminos/gametype-icon-ctf.tga differ
diff --git a/gfx/menu/luminos/gametype-icon-cts.tga b/gfx/menu/luminos/gametype-icon-cts.tga
new file mode 100644 (file)
index 0000000..bc917ec
Binary files /dev/null and b/gfx/menu/luminos/gametype-icon-cts.tga differ
diff --git a/gfx/menu/luminos/gametype-icon-dm.tga b/gfx/menu/luminos/gametype-icon-dm.tga
new file mode 100644 (file)
index 0000000..1266f59
Binary files /dev/null and b/gfx/menu/luminos/gametype-icon-dm.tga differ
diff --git a/gfx/menu/luminos/gametype-icon-dom.tga b/gfx/menu/luminos/gametype-icon-dom.tga
new file mode 100644 (file)
index 0000000..f7637f9
Binary files /dev/null and b/gfx/menu/luminos/gametype-icon-dom.tga differ
diff --git a/gfx/menu/luminos/gametype-icon-duel.tga b/gfx/menu/luminos/gametype-icon-duel.tga
new file mode 100644 (file)
index 0000000..03fe067
Binary files /dev/null and b/gfx/menu/luminos/gametype-icon-duel.tga differ
diff --git a/gfx/menu/luminos/gametype-icon-ft.tga b/gfx/menu/luminos/gametype-icon-ft.tga
new file mode 100644 (file)
index 0000000..8028b67
Binary files /dev/null and b/gfx/menu/luminos/gametype-icon-ft.tga differ
diff --git a/gfx/menu/luminos/gametype-icon-kh.tga b/gfx/menu/luminos/gametype-icon-kh.tga
new file mode 100644 (file)
index 0000000..ca0d2aa
Binary files /dev/null and b/gfx/menu/luminos/gametype-icon-kh.tga differ
diff --git a/gfx/menu/luminos/gametype-icon-lms.tga b/gfx/menu/luminos/gametype-icon-lms.tga
new file mode 100644 (file)
index 0000000..5549651
Binary files /dev/null and b/gfx/menu/luminos/gametype-icon-lms.tga differ
diff --git a/gfx/menu/luminos/gametype-icon-nb.tga b/gfx/menu/luminos/gametype-icon-nb.tga
new file mode 100644 (file)
index 0000000..b4f7441
Binary files /dev/null and b/gfx/menu/luminos/gametype-icon-nb.tga differ
diff --git a/gfx/menu/luminos/gametype-icon-race.tga b/gfx/menu/luminos/gametype-icon-race.tga
new file mode 100644 (file)
index 0000000..9874c7e
Binary files /dev/null and b/gfx/menu/luminos/gametype-icon-race.tga differ
diff --git a/gfx/menu/luminos/gametype-icon-rune.tga b/gfx/menu/luminos/gametype-icon-rune.tga
new file mode 100644 (file)
index 0000000..6906411
Binary files /dev/null and b/gfx/menu/luminos/gametype-icon-rune.tga differ
diff --git a/gfx/menu/luminos/gametype-icon-tdm.tga b/gfx/menu/luminos/gametype-icon-tdm.tga
new file mode 100644 (file)
index 0000000..cc0b938
Binary files /dev/null and b/gfx/menu/luminos/gametype-icon-tdm.tga differ
index 6e1be0067a075606c74b13fba4aafabe8d63788b..ec81b638b66b22e04dabd6873fd10c52e58eab92 100644 (file)
@@ -133,7 +133,12 @@ void XonoticSingleplayerDialog_fill(entity me)
                        me.campaignBox.labelTitle = lblTitle;
                        me.campaignBox.campaignGo(me.campaignBox, 0);
 
-       me.gotoRC(me, me.rows - 1, 0);
+       me.gotoRC(me, me.rows - 2, 0);
+               me.TD(me, 1, 2, e = makeXonoticTextLabel(0.5, _("Campaign Difficulty:")));
+               me.TD(me, 1, 1, e = makeXonoticRadioButton(1, "g_campaign_skill", "-2", _("Easy")));
+               me.TD(me, 1, 1, e = makeXonoticRadioButton(1, "g_campaign_skill", "-1", _("Medium")));
+               me.TD(me, 1, 1, e = makeXonoticRadioButton(1, "g_campaign_skill", "0", _("Hard")));
+               me.TR(me);
                me.TD(me, 1, me.columns, e = makeXonoticButton(_("Start Singleplayer!"), '0 0 0'));
                        e.onClick = CampaignList_LoadMap;
                        e.onClickEntity = me.campaignBox;
index cbc239946a70112b25f1818756dbf930b4c63a2a..1411244db7f2e3d5f2ddb9046909f5a479e0f269 100644 (file)
@@ -1,7 +1,7 @@
 #ifdef INTERFACE
 CLASS(XonoticGametypeList) EXTENDS(XonoticListBox)
        METHOD(XonoticGametypeList, configureXonoticGametypeList, void(entity))
-       ATTRIB(XonoticGametypeList, rowsPerItem, float, 1)
+       ATTRIB(XonoticGametypeList, rowsPerItem, float, 2)
        METHOD(XonoticGametypeList, drawListBoxItem, void(entity, float, vector, float))
        METHOD(XonoticGametypeList, resizeNotify, void(entity, vector, vector, vector, vector))
        METHOD(XonoticGametypeList, setSelected, void(entity, float))
@@ -9,7 +9,10 @@ CLASS(XonoticGametypeList) EXTENDS(XonoticListBox)
        METHOD(XonoticGametypeList, saveCvars, void(entity))
 
        ATTRIB(XonoticGametypeList, realFontSize, vector, '0 0 0')
-       ATTRIB(XonoticGametypeList, realUpperMargin, float, 0)
+       ATTRIB(XonoticGametypeList, realUpperMargin1, float, 0)
+       ATTRIB(XonoticGametypeList, realUpperMargin2, float, 0)
+       ATTRIB(XonoticGametypeList, columnIconOrigin, float, 0)
+       ATTRIB(XonoticGametypeList, columnIconSize, float, 0)
        ATTRIB(XonoticGametypeList, columnNameOrigin, float, 0)
        ATTRIB(XonoticGametypeList, columnNameSize, float, 0)
 ENDCLASS(XonoticGametypeList)
@@ -70,16 +73,25 @@ void XonoticGametypeList_drawListBoxItem(entity me, float i, vector absSize, flo
        string s;
        if(isSelected)
                draw_Fill('0 0 0', '1 1 0', SKINCOLOR_LISTBOX_SELECTED, SKINALPHA_LISTBOX_SELECTED);
+
+       draw_Picture(me.columnIconOrigin * eX, strcat("gametype-icon-", GameType_GetIcon(i)), me.columnIconSize * eX + eY, '1 1 1', SKINALPHA_LISTBOX_SELECTED);
        s = MapInfo_Type_ToText(GameType_GetID(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);
+       draw_Text(me.realUpperMargin1 * eY + (me.columnNameOrigin + 0.00 * (me.columnNameSize - draw_TextWidth(s, 0, me.realFontSize))) * eX, s, me.realFontSize, '1 1 1', SKINALPHA_TEXT, 0);
+       s = GameType_GetTeams(i);
+       draw_Text(me.realUpperMargin1 * eY + (me.columnNameOrigin + 1.00 * (me.columnNameSize - draw_TextWidth(s, 0, me.realFontSize))) * eX, s, me.realFontSize, '1 1 1', SKINALPHA_TEXT, 0);
 }
 void XonoticGametypeList_resizeNotify(entity me, vector relOrigin, vector relSize, vector absOrigin, vector absSize)
 {
+       me.itemAbsSize = '0 0 0';
        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;
+       
+       me.realFontSize_y = me.fontSize / (me.itemAbsSize_y = (absSize_y * me.itemHeight));
+       me.realFontSize_x = me.fontSize / (me.itemAbsSize_x = (absSize_x * (1 - me.controlWidth)));
+       me.realUpperMargin1 = 0.5 * (1 - me.realFontSize_y);
+       me.realUpperMargin2 = me.realUpperMargin1 + me.realFontSize_y;
+       me.columnIconOrigin = 0;
+       me.columnIconSize = me.itemAbsSize_y / me.itemAbsSize_x;
+       me.columnNameOrigin = me.columnIconOrigin + me.columnIconSize;
+       me.columnNameSize = 1 - me.columnIconSize - 2 * me.realFontSize_x;
 }
 #endif
index 74fe810fe74759d9d015e69f1248c4207e4cb8a4..77fedc3729f2713edbddeb27f42da6b57c159d6c 100644 (file)
@@ -543,38 +543,56 @@ float updateCompression()
 
 // note: include only those that should be in the menu!
 #define GAMETYPES \
-       GAMETYPE(MAPINFO_TYPE_ARENA) \
-       GAMETYPE(MAPINFO_TYPE_ASSAULT) \
-       GAMETYPE(MAPINFO_TYPE_CTF) \
-       GAMETYPE(MAPINFO_TYPE_CA) \
-       GAMETYPE(MAPINFO_TYPE_DEATHMATCH) \
-       GAMETYPE(MAPINFO_TYPE_DOMINATION) \
-       GAMETYPE(MAPINFO_TYPE_FREEZETAG) \
-       GAMETYPE(MAPINFO_TYPE_KEEPAWAY) \
-       GAMETYPE(MAPINFO_TYPE_KEYHUNT) \
-       GAMETYPE(MAPINFO_TYPE_LMS) \
-       GAMETYPE(MAPINFO_TYPE_NEXBALL) \
-       GAMETYPE(MAPINFO_TYPE_ONSLAUGHT) \
-       GAMETYPE(MAPINFO_TYPE_RACE) \
-       GAMETYPE(MAPINFO_TYPE_CTS) \
-       GAMETYPE(MAPINFO_TYPE_RUNEMATCH) \
-       GAMETYPE(MAPINFO_TYPE_TEAM_DEATHMATCH) \
+       GAMETYPE(MAPINFO_TYPE_ARENA, "ar", _("free for all")) \
+       GAMETYPE(MAPINFO_TYPE_ASSAULT, "as", _("teamplay")) \
+       GAMETYPE(MAPINFO_TYPE_CTF, "ctf", _("teamplay")) \
+       GAMETYPE(MAPINFO_TYPE_CA, "ca", _("teamplay")) \
+       GAMETYPE(MAPINFO_TYPE_DEATHMATCH, "dm", _("free for all")) \
+       GAMETYPE(MAPINFO_TYPE_DOMINATION, "dom", _("teamplay")) \
+       GAMETYPE(MAPINFO_TYPE_FREEZETAG, "ft", _("teamplay")) \
+       GAMETYPE(MAPINFO_TYPE_KEEPAWAY, "ka", _("free for all")) \
+       GAMETYPE(MAPINFO_TYPE_KEYHUNT, "kh", _("teamplay")) \
+       GAMETYPE(MAPINFO_TYPE_LMS, "lms", _("free for all")) \
+       GAMETYPE(MAPINFO_TYPE_NEXBALL, "nb", _("free/teamplay")) \
+       GAMETYPE(MAPINFO_TYPE_ONSLAUGHT, "ons", _("teamplay")) \
+       GAMETYPE(MAPINFO_TYPE_RACE, "race", _("free/teamplay")) \
+       GAMETYPE(MAPINFO_TYPE_CTS, "cts", _("free for all")) \
+       GAMETYPE(MAPINFO_TYPE_RUNEMATCH, "rune", _("free for all")) \
+       GAMETYPE(MAPINFO_TYPE_TEAM_DEATHMATCH, "tdm", _("teamplay")) \
        /* nothing */
 
 float GameType_GetID(float cnt)
 {
        float i;
        i = 0;
-#define GAMETYPE(id) if(i++ == cnt) return id;
+#define GAMETYPE(id,icon,teams) if(i++ == cnt) return id;
        GAMETYPES
 #undef GAMETYPE
        return 0;
 }
+string GameType_GetIcon(float cnt)
+{
+       float i;
+       i = 0;
+#define GAMETYPE(id,icon,teams) if(i++ == cnt) return icon;
+       GAMETYPES
+#undef GAMETYPE
+       return "";
+}
+string GameType_GetTeams(float cnt)
+{
+       float i;
+       i = 0;
+#define GAMETYPE(id,icon,teams) if(i++ == cnt) return teams;
+       GAMETYPES
+#undef GAMETYPE
+       return _("tuba for all");
+}
 float GameType_GetCount()
 {
        float i;
        i = 0;
-#define GAMETYPE(id) ++i;
+#define GAMETYPE(id,icon,teams) ++i;
        GAMETYPES
 #undef GAMETYPE
        return i;
index 6165fb3606b945968910c437bf76732d931c3ad5..c3bc54f90852e2d21aa2882b425e0a58e48d070d 100644 (file)
@@ -37,6 +37,8 @@ void URI_Get_Callback(float id, float status, string data);
 // game type list box stuff (does not NEED to contain all game types, other
 // types stay available via console)
 float GameType_GetID(float cnt);
+string GameType_GetIcon(float cnt);
+string GameType_GetTeams(float cnt);
 float GameType_GetCount();
 
 void dialog_hudpanel_common_notoggle(entity me, string panelname);