1 #include "hudskinlist.qh"
5 entity makeXonoticHUDSkinList()
8 me = NEW(XonoticHUDSkinList);
9 me.configureXonoticHUDSkinList(me);
13 void XonoticHUDSkinList_configureXonoticHUDSkinList(entity me)
15 me.configureXonoticListBox(me);
19 const float HUDSKINPARM_NAME = 0;
20 const float HUDSKINPARM_PATH = 1;
21 const float HUDSKINPARM_TITLE = 2;
22 const float HUDSKINPARM_AUTHOR = 3;
23 const float HUDSKINPARM_COUNT = 4;
24 string XonoticHUDSkinList_hudskinName(entity me, float i)
26 return bufstr_get(me.listHUDSkin, i * HUDSKINPARM_COUNT + HUDSKINPARM_NAME);
28 string XonoticHUDSkinList_hudskinPath(entity me, float i)
30 return bufstr_get(me.listHUDSkin, i * HUDSKINPARM_COUNT + HUDSKINPARM_PATH);
32 string XonoticHUDSkinList_hudskinTitle(entity me, float i)
34 return bufstr_get(me.listHUDSkin, i * HUDSKINPARM_COUNT + HUDSKINPARM_TITLE);
36 string XonoticHUDSkinList_hudskinAuthor(entity me, float i)
38 return bufstr_get(me.listHUDSkin, i * HUDSKINPARM_COUNT + HUDSKINPARM_AUTHOR);
41 // subdir can be a regular expression
42 void getHUDSkinFiles(entity me, int sortbuf, string subdir)
49 s = strcat(subdir, "hud_", s, ".cfg");
51 int list = search_begin(s, false, true);
54 int n = search_getsize(list);
55 for(int i = 0; i < n; ++i)
57 string s = search_getfilename(list, i);
58 int subdir_ofs = strstrofs(s, "/", 0);
65 ofs = strstrofs(s, "/", subdir_ofs + 1);
70 bufstr_add(sortbuf, s, true);
73 subdir = substring(s, 0, subdir_ofs);
74 string filename = substring(s, subdir_ofs + 1, -1);
75 // invert path and filename position so we can sort sortbuf by filename
76 bufstr_add(sortbuf, strcat(filename, "/", subdir), true);
83 void getAllHUDSkins(entity me, int sortbuf)
85 int n = buf_getsize(sortbuf);
86 for(int i = 0; i < n; ++i)
88 string entry = bufstr_get(sortbuf, i);
89 int ofs = strstrofs(entry, "/", 0);
91 string filename = entry;
94 s = substring(entry, ofs + 1, -1); // skip initial "/"
96 bufstr_set(me.listHUDSkin, i * HUDSKINPARM_COUNT + HUDSKINPARM_PATH, s);
97 filename = strcat(s, substring(entry, 0, ofs));
101 s = substring(entry, 4, ofs - 4 - 4); // remove "hud_" prefix and ".cfg" suffix
102 bufstr_set(me.listHUDSkin, i * HUDSKINPARM_COUNT + HUDSKINPARM_NAME, s);
104 int fh = fopen(filename, FILE_READ);
107 while((s = fgets(fh)) && substring(s, 0, 2) == "//")
109 tokenize_console(substring(s, 2, -1));
110 if(argv(0) == "title")
111 bufstr_set(me.listHUDSkin, i * HUDSKINPARM_COUNT + HUDSKINPARM_TITLE, argv(1));
112 else if(argv(0) == "author")
113 bufstr_set(me.listHUDSkin, i * HUDSKINPARM_COUNT + HUDSKINPARM_AUTHOR, argv(1));
119 void XonoticHUDSkinList_getHUDSkins(entity me)
121 if (me.listHUDSkin >= 0)
122 buf_del(me.listHUDSkin);
123 me.listHUDSkin = buf_create();
124 if (me.listHUDSkin < 0)
129 int sortbuf = buf_create();
130 getHUDSkinFiles(me, sortbuf, "");
131 getHUDSkinFiles(me, sortbuf, "data/");
132 buf_sort(sortbuf, 128, 0);
133 getAllHUDSkins(me, sortbuf);
135 me.nItems = buf_getsize(me.listHUDSkin) / HUDSKINPARM_COUNT;
138 void XonoticHUDSkinList_destroy(entity me)
141 buf_del(me.listHUDSkin);
144 void XonoticHUDSkinList_resizeNotify(entity me, vector relOrigin, vector relSize, vector absOrigin, vector absSize)
146 me.itemAbsSize = '0 0 0';
147 SUPER(XonoticHUDSkinList).resizeNotify(me, relOrigin, relSize, absOrigin, absSize);
149 me.itemAbsSize.y = absSize.y * me.itemHeight;
150 me.itemAbsSize.x = absSize.x * (1 - me.controlWidth);
151 me.realFontSize.y = me.fontSize / me.itemAbsSize.y;
152 me.realFontSize.x = me.fontSize / me.itemAbsSize.x;
153 me.realUpperMargin = 0.5 * (1 - me.realFontSize.y);
155 me.columnNameOrigin = me.realFontSize.x;
156 me.columnNameSize = 1 - 2 * me.realFontSize.x;
159 void XonoticHUDSkinList_drawListBoxItem(entity me, int i, vector absSize, bool isSelected, bool isFocused)
163 draw_Fill('0 0 0', '1 1 0', SKINCOLOR_LISTBOX_SELECTED, SKINALPHA_LISTBOX_SELECTED);
166 me.focusedItemAlpha = getFadedAlpha(me.focusedItemAlpha, SKINALPHA_LISTBOX_FOCUSED, SKINFADEALPHA_LISTBOX_FOCUSED);
167 draw_Fill('0 0 0', '1 1 0', SKINCOLOR_LISTBOX_FOCUSED, me.focusedItemAlpha);
170 s = me.hudskinTitle(me, i);
172 s = me.hudskinName(me, i);
173 s2 = me.hudskinAuthor(me, i);
175 s = strcat(s, " (", s2, ")");
176 s = draw_TextShortenToWidth(s, me.columnNameSize, 0, me.realFontSize);
177 draw_Text(me.realUpperMargin * eY + (me.columnNameOrigin + 0.00 * (me.columnNameSize - draw_TextWidth(s, 0, me.realFontSize))) * eX, s, me.realFontSize, SKINCOLOR_TEXT, SKINALPHA_TEXT, 1);
180 void XonoticHUDSkinList_showNotify(entity me)
185 void HUDSkinList_Refresh_Click(entity btn, entity me)
188 me.setSelected(me, 0); //always select the first element after a list update
191 void HUDSkinList_SavedName_Change(entity box, entity me)
193 strfree(me.savedName);
196 me.savedName = strzone(box.text);
199 void HUDSkinList_Filter_Change(entity box, entity me)
201 strfree(me.filterString);
205 if (strstrofs(box.text, "*", 0) >= 0 || strstrofs(box.text, "?", 0) >= 0)
206 me.filterString = strzone(box.text);
208 me.filterString = strzone(strcat("*", box.text, "*"));
214 void SaveHUDSkin_Click(entity btn, entity me)
216 string s = me.savedName;
219 localcmd(sprintf("hud save \"%s\"\n", s));
220 me.delayedRefreshTime = time + 1;
223 void XonoticHUDSkinList_draw(entity me)
225 if(me.delayedRefreshTime > 0 && me.delayedRefreshTime < time)
227 HUDSkinList_Refresh_Click(NULL, me);
228 me.delayedRefreshTime = 0;
230 SUPER(XonoticHUDSkinList).draw(me);
233 void XonoticHUDSkinList_setHUDSkin(entity me)
235 string cfg = strcat(me.hudskinPath(me, me.selectedItem), "hud_", me.hudskinName(me, me.selectedItem), ".cfg");
236 localcmd("exec \"", cfg, "\"\n");
239 void SetHUDSkin_Click(entity btn, entity me)
244 void XonoticHUDSkinList_doubleClickListBoxItem(entity me, float i, vector where)
246 m_play_click_sound(MENU_SOUND_EXECUTE);
250 float XonoticHUDSkinList_keyDown(entity me, float scan, float ascii, float shift)
252 if(scan == K_ENTER || scan == K_KP_ENTER)
259 return SUPER(XonoticHUDSkinList).keyDown(me, scan, ascii, shift);