--- /dev/null
+#ifdef INTERFACE
+CLASS(XonoticScreenshotBrowserTab) EXTENDS(XonoticTab)
+ METHOD(XonoticScreenshotBrowserTab, fill, void(entity))
+ ATTRIB(XonoticScreenshotBrowserTab, title, string, "Screenshot")
+ ATTRIB(XonoticScreenshotBrowserTab, intendedWidth, float, 0.9)
+ ATTRIB(XonoticScreenshotBrowserTab, rows, float, 22)
+ ATTRIB(XonoticScreenshotBrowserTab, columns, float, 6.5)
+ ATTRIB(XonoticScreenshotBrowserTab, screenshotImage, entity, NULL)
+ ATTRIB(XonoticScreenshotBrowserTab, name, string, "ScreenshotBrowser")
+ENDCLASS(XonoticScreenshotBrowserTab)
+entity makeXonoticScreenshotBrowserTab();
+#endif
+
+#ifdef IMPLEMENTATION
+entity makeXonoticScreenshotBrowserTab()
+{
+ entity me;
+ me = spawnXonoticScreenshotBrowserTab();
+ me.configureDialog(me);
+ return me;
+}
+void XonoticScreenshotBrowserTab_fill(entity me)
+{
+ entity e, btn, slist;
+ me.TR(me);
+ slist = makeXonoticScreenshotList();
+ me.TR(me);
+ me.TD(me, 1, 0.5, e = makeXonoticTextLabel(0, "Filter:"));
+ me.TD(me, 1, 0.5, btn = makeXonoticButton("Clear", '0 0 0'));
+ btn.onClick = InputBox_Clear_Click;
+ me.TD(me, 1, me.columns - 1, e = makeXonoticInputBox(0, string_null));
+ e.onChange = ScreenshotList_Filter_Change;
+ e.onChangeEntity = slist;
+ btn.onClickEntity = e;
+ slist.controlledTextbox = e;
+ slist.screenshotViewerDialog = main.screenshotViewerDialog;
+ main.screenshotViewerDialog.scrList = slist;
+ me.TR(me);
+ me.TD(me, me.rows - 4, me.columns, slist);
+ me.gotoRC(me, me.rows - 1, 0);
+ me.TD(me, 1, me.columns, e = makeXonoticButton("View", '0 0 0'));
+ e.onClick = StartScreenshot_Click;
+ e.onClickEntity = slist;
+}
+#endif
--- /dev/null
+#ifdef INTERFACE\r
+CLASS(XonoticScreenshotViewerDialog) EXTENDS(XonoticRootDialog)\r
+ METHOD(XonoticScreenshotViewerDialog, fill, void(entity))\r
+ METHOD(XonoticScreenshotViewerDialog, loadScreenshot, void(entity, string))\r
+ ATTRIB(XonoticScreenshotViewerDialog, title, string, "Screenshot Viewer")\r
+ ATTRIB(XonoticScreenshotViewerDialog, intendedWidth, float, 1)\r
+ ATTRIB(XonoticScreenshotViewerDialog, rows, float, 25)\r
+ ATTRIB(XonoticScreenshotViewerDialog, columns, float, 6.5)\r
+ ATTRIB(XonoticScreenshotViewerDialog, screenshotImage, entity, NULL)\r
+ ATTRIB(XonoticScreenshotViewerDialog, scrList, entity, NULL)\r
+ENDCLASS(XonoticScreenshotViewerDialog)\r
+#endif\r
+\r
+#ifdef IMPLEMENTATION\r
+void XonoticScreenshotViewerDialog_loadScreenshot(entity me, string scrImage)\r
+{\r
+ if (me.screenshotImage.src)
+ strunzone(me.screenshotImage.src);\r
+ me.screenshotImage.src = strzone(scrImage);\r
+ me.screenshotImage.updateAspect(me.screenshotImage);\r
+}\r
+void prevScreenshot_Click(entity btn, entity me)\r
+{\r
+ me.scrList.goScreenshot(me.scrList, -1);\r
+}\r
+void nextScreenshot_Click(entity btn, entity me)\r
+{\r
+ me.scrList.goScreenshot(me.scrList, +1);\r
+}\r
+void XonoticScreenshotViewerDialog_fill(entity me)\r
+{\r
+ entity e;\r
+\r
+ me.TR(me);\r
+ me.TD(me, me.rows - 1, me.columns, e = makeXonoticImage(string_null, -1));\r
+ me.screenshotImage = e;\r
+ me.gotoRC(me, me.rows - 1, 0);\r
+ me.TD(me, 1, me.columns/2, e = makeXonoticButton("Prev", '0 0 0'));\r
+ e.onClick = prevScreenshot_Click;\r
+ e.onClickEntity = me;\r
+ me.TD(me, 1, me.columns/2, e = makeXonoticButton("Next", '0 0 0'));\r
+ e.onClick = nextScreenshot_Click;\r
+ e.onClickEntity = me;\r
+}\r
+#endif\r
--- /dev/null
+#ifdef INTERFACE
+CLASS(XonoticScreenshotList) EXTENDS(XonoticListBox)
+ METHOD(XonoticScreenshotList, configureXonoticScreenshotList, void(entity))
+ ATTRIB(XonoticScreenshotList, rowsPerItem, float, 1)
+ METHOD(XonoticScreenshotList, resizeNotify, void(entity, vector, vector, vector, vector))
+ METHOD(XonoticScreenshotList, drawListBoxItem, void(entity, float, vector, float))
+ METHOD(XonoticScreenshotList, getScreenshots, void(entity))
+ METHOD(XonoticScreenshotList, startScreenshot, void(entity))
+ METHOD(XonoticScreenshotList, screenshotName, string(entity, float))
+ METHOD(XonoticScreenshotList, clickListBoxItem, void(entity, float, vector))
+ METHOD(XonoticScreenshotList, keyDown, float(entity, float, float, float))
+ METHOD(XonoticScreenshotList, destroy, void(entity))
+ METHOD(XonoticScreenshotList, showNotify, void(entity))
+ ATTRIB(XonoticScreenshotList, listScreenshot, float, -1)
+ ATTRIB(XonoticScreenshotList, realFontSize, vector, '0 0 0')
+ ATTRIB(XonoticScreenshotList, columnNameOrigin, float, 0)
+ ATTRIB(XonoticScreenshotList, columnNameSize, float, 0)
+ ATTRIB(XonoticScreenshotList, realUpperMargin, float, 0)
+ ATTRIB(XonoticScreenshotList, origin, vector, '0 0 0')
+ ATTRIB(XonoticScreenshotList, itemAbsSize, vector, '0 0 0')
+ ATTRIB(XonoticScreenshotList, lastClickedScreenshot, float, -1)
+ ATTRIB(XonoticScreenshotList, lastClickedTime, float, 0)
+ ATTRIB(XonoticScreenshotList, filterString, string, string_null)
+ ATTRIB(XonoticScreenshotList, screenshotViewerDialog, entity, NULL)
+ METHOD(XonoticScreenshotList, goScreenshot, void(entity, float))
+ENDCLASS(XonoticScreenshotList)
+
+entity makeXonoticScreenshotList();
+void StartScreenshot_Click(entity btn, entity me);
+void ScreenshotList_Filter_Change(entity box, entity me);
+#endif
+
+#ifdef IMPLEMENTATION
+
+entity makeXonoticScreenshotList()
+{
+ entity me;
+ me = spawnXonoticScreenshotList();
+ me.configureXonoticScreenshotList(me);
+ return me;
+}
+
+void XonoticScreenshotList_configureXonoticScreenshotList(entity me)
+{
+ me.configureXonoticListBox(me);
+ me.getScreenshots(me);
+}
+
+string XonoticScreenshotList_screenshotName(entity me, float i )
+{
+ string s;
+ s = search_getfilename(me.listScreenshot, i);
+ s = substring(s, 12, strlen(s) - 12 - 4); // screenshots/, .jpg
+ return s;
+}
+
+void XonoticScreenshotList_getScreenshots(entity me)
+{
+ string s;
+
+ if(me.filterString)
+ //subdirectory in filterString allowed
+ s=strcat("screenshots/*", me.filterString, "*.jpg");
+ else
+ s="screenshots/*.jpg";
+
+ //dprint("Search screenshots with the pattern ", s, "\n");
+ if(me.listScreenshot >= 0)
+ search_end(me.listScreenshot);
+ me.listScreenshot = search_begin(s, FALSE, TRUE);
+ if(me.listScreenshot < 0)
+ me.nItems=0;
+ else
+ me.nItems=search_getsize(me.listScreenshot);
+}
+
+void XonoticScreenshotList_destroy(entity me)
+{
+ search_end(me.listScreenshot);
+}
+
+void XonoticScreenshotList_resizeNotify(entity me, vector relOrigin, vector relSize, vector absOrigin, vector absSize)
+{
+ me.itemAbsSize = '0 0 0';
+ SUPER(XonoticScreenshotList).resizeNotify(me, relOrigin, relSize, absOrigin, absSize);
+
+ 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.realUpperMargin = 0.5 * (1 - me.realFontSize_y);
+
+ me.columnNameOrigin = me.realFontSize_x;
+ me.columnNameSize = 1 - 2 * me.realFontSize_x;
+}
+
+void XonoticScreenshotList_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 = me.screenshotName(me,i);
+ s = draw_TextShortenToWidth(s, me.columnNameSize, 0, me.realFontSize);
+ draw_Text(me.realUpperMargin * eY + (me.columnNameOrigin + 0.00 * (me.columnNameSize - draw_TextWidth(s, 0, me.realFontSize))) * eX, s, me.realFontSize, '1 1 1', SKINALPHA_TEXT, 0);
+}
+
+void XonoticScreenshotList_showNotify(entity me)
+{
+ me.getScreenshots(me);
+}
+
+void ScreenshotList_Filter_Change(entity box, entity me)
+{
+ if(me.filterString)
+ strunzone(me.filterString);
+
+ if(box.text != "")
+ me.filterString = strzone(box.text);
+ else
+ me.filterString = string_null;
+
+ me.getScreenshots(me);
+}
+
+void XonoticScreenshotList_goScreenshot(entity me, float d)
+{
+ if(!me.screenshotViewerDialog)
+ return;
+ me.setSelected(me, me.selectedItem + d);
+ main.screenshotViewerDialog.loadScreenshot(main.screenshotViewerDialog, strcat("/screenshots/", me.screenshotName(me,me.selectedItem)));
+}
+
+void XonoticScreenshotList_startScreenshot(entity me)
+{
+ main.screenshotViewerDialog.loadScreenshot(main.screenshotViewerDialog, strcat("/screenshots/", me.screenshotName(me,me.selectedItem)));
+ // pop up screenshot
+ DialogOpenButton_Click_withCoords(NULL, main.screenshotViewerDialog, me.origin + eX * (me.columnNameOrigin * me.size_x) + eY * ((me.itemHeight * me.selectedItem - me.scrollPos) * me.size_y), eY * me.itemAbsSize_y + eX * (me.itemAbsSize_x * me.columnNameSize));
+}
+
+void StartScreenshot_Click(entity btn, entity me)
+{
+ me.startScreenshot(me);
+}
+
+void XonoticScreenshotList_clickListBoxItem(entity me, float i, vector where)
+{
+ if(i == me.lastClickedScreenshot)
+ if(time < me.lastClickedTime + 0.3)
+ {
+ // DOUBLE CLICK!
+ // pop up screenshot
+ me.setSelected(me, i);
+ me.startScreenshot(me);
+ }
+ me.lastClickedScreenshot = i;
+ me.lastClickedTime = time;
+}
+
+float XonoticScreenshotList_keyDown(entity me, float scan, float ascii, float shift)
+{
+ if(scan == K_ENTER || scan == K_KP_ENTER) {
+ me.startScreenshot(me);
+ return 1;
+ }
+ else
+ return SUPER(XonoticScreenshotList).keyDown(me, scan, ascii, shift);
+}
+#endif