+++ /dev/null
-#ifdef INTERFACE
-CLASS(XonoticPlayerModelSelector) EXTENDS(XonoticImage)
- METHOD(XonoticPlayerModelSelector, configureXonoticPlayerModelSelector, void(entity))
- METHOD(XonoticPlayerModelSelector, loadCvars, void(entity))
- METHOD(XonoticPlayerModelSelector, saveCvars, void(entity))
- METHOD(XonoticPlayerModelSelector, draw, void(entity))
- METHOD(XonoticPlayerModelSelector, resizeNotify, void(entity, vector, vector, vector, vector))
- METHOD(XonoticPlayerModelSelector, showNotify, void(entity))
- ATTRIB(XonoticPlayerModelSelector, currentModel, string, string_null)
- ATTRIB(XonoticPlayerModelSelector, currentSkin, float, 0)
- ATTRIB(XonoticPlayerModelSelector, currentModelImage, string, string_null)
- ATTRIB(XonoticPlayerModelSelector, currentModelTitle, string, string_null)
- ATTRIB(XonoticPlayerModelSelector, currentModelDescription, string, string_null)
- METHOD(XonoticPlayerModelSelector, go, void(entity, float))
- METHOD(XonoticPlayerModelSelector, destroy, void(entity))
- ATTRIB(XonoticPlayerModelSelector, origin, vector, '0 0 0')
- ATTRIB(XonoticPlayerModelSelector, size, vector, '0 0 0')
- ATTRIB(XonoticPlayerModelSelector, realFontSize, vector, '0 0 0')
- ATTRIB(XonoticPlayerModelSelector, fontSize, float, SKINFONTSIZE_NORMAL)
- ATTRIB(XonoticPlayerModelSelector, titleFontSize, float, SKINFONTSIZE_TITLE)
- ATTRIB(XonoticPlayerModelSelector, bufModels, float, -1)
- ATTRIB(XonoticPlayerModelSelector, numModels, float, -1)
- ATTRIB(XonoticPlayerModelSelector, idxModels, float, -1)
-ENDCLASS(XonoticPlayerModelSelector)
-entity makeXonoticPlayerModelSelector();
-void PlayerModelSelector_Next_Click(entity btn, entity me);
-void PlayerModelSelector_Prev_Click(entity btn, entity me);
-#endif
-
-#ifdef IMPLEMENTATION
-entity makeXonoticPlayerModelSelector()
-{
- entity me;
- me = spawnXonoticPlayerModelSelector();
- me.configureXonoticPlayerModelSelector(me);
- return me;
-}
-
-const float BUFMODELS_TITLE = 0;
-const float BUFMODELS_IMAGE = 1;
-const float BUFMODELS_MODEL = 2;
-const float BUFMODELS_SKIN = 3;
-const float BUFMODELS_DESC = 4;
-const float BUFMODELS_COUNT = 5;
-
-#define XONVOTE186 1 // (nyov) removal of model text description
-
-void XonoticPlayerModelSelector_configureXonoticPlayerModelSelector(entity me)
-{
- float sortbuf, glob, i;
- string fn;
-
- glob = search_begin(language_filename(get_model_datafilename(string_null, -1, "txt")), TRUE, TRUE);
- if (glob < 0)
- return;
-
- me.configureXonoticImage(me, string_null, -1);
-
- sortbuf = buf_create();
- for(i = 0; i < search_getsize(glob); ++i)
- {
- // select model #i!
- fn = search_getfilename(glob, i);
- if(!get_model_parameters(fn, -1))
- continue;
- bufstr_add(sortbuf, sprintf("%-128s%s", get_model_parameters_name, fn), 1);
- }
- search_end(glob);
- buf_sort(sortbuf, 128, 0);
- me.numModels = buf_getsize(sortbuf);
- me.bufModels = buf_create();
- for(i = 0; i < me.numModels; ++i)
- {
- fn = substring(bufstr_get(sortbuf, i), 128, -1);
- if(!get_model_parameters(fn, -1))
- error("But it JUST worked!");
- bufstr_set(me.bufModels, BUFMODELS_COUNT*i+BUFMODELS_TITLE, get_model_parameters_name);
- bufstr_set(me.bufModels, BUFMODELS_COUNT*i+BUFMODELS_IMAGE, strcat("/", substring(get_model_datafilename(get_model_parameters_modelname, get_model_parameters_modelskin, "tga"), 0, -5)));
- bufstr_set(me.bufModels, BUFMODELS_COUNT*i+BUFMODELS_MODEL, get_model_parameters_modelname);
- bufstr_set(me.bufModels, BUFMODELS_COUNT*i+BUFMODELS_SKIN, ftos(get_model_parameters_modelskin));
- get_model_parameters_desc = strcat(get_model_parameters_desc, "\n");
-#if XONVOTE186
- if(get_model_parameters_sex)
- get_model_parameters_desc = strcat(get_model_parameters_desc, sprintf("\n%s", get_model_parameters_sex));
-#else
- if(get_model_parameters_description)
- get_model_parameters_desc = strcat(get_model_parameters_desc, sprintf("\n%s\n", get_model_parameters_description));
- if(get_model_parameters_sex)
- get_model_parameters_desc = strcat(get_model_parameters_desc, sprintf("\nSex: %s", get_model_parameters_sex));
- if(get_model_parameters_weight)
- get_model_parameters_desc = strcat(get_model_parameters_desc, sprintf("\nWeight: %g kg", get_model_parameters_weight));
- if(get_model_parameters_age)
- get_model_parameters_desc = strcat(get_model_parameters_desc, sprintf("\nAge: %g", get_model_parameters_age));
-#endif
- while(substring(get_model_parameters_desc, -1, 1) == "\n")
- get_model_parameters_desc = substring(get_model_parameters_desc, 0, -2);
- bufstr_set(me.bufModels, BUFMODELS_COUNT*i+BUFMODELS_DESC, get_model_parameters_desc);
- }
- buf_del(sortbuf);
- get_model_parameters(string_null, 0);
- me.loadCvars(me); // this will select the initial model, depending on the current cvars
- me.go(me, 0); // this will set the vars for the selected model
-}
-void XonoticPlayerModelSelector_destroy(entity me)
-{
- buf_del(me.bufModels);
- me.bufModels = -1;
-}
-
-void XonoticPlayerModelSelector_loadCvars(entity me)
-{
- string skin, modelname;
- float i;
-
- skin = cvar_string("_cl_playerskin");
- modelname = cvar_string("_cl_playermodel");
-
- for(i = 0; i < me.numModels; ++i)
- {
- if(bufstr_get(me.bufModels, BUFMODELS_COUNT*i+BUFMODELS_MODEL) == modelname)
- if(bufstr_get(me.bufModels, BUFMODELS_COUNT*i+BUFMODELS_SKIN) == skin)
- break;
- }
- if(i >= me.numModels) // fail
- i = 0;
- me.idxModels = i;
-}
-
-void XonoticPlayerModelSelector_go(entity me, float d)
-{
- me.idxModels = mod(me.idxModels + d + me.numModels, me.numModels);
-
- if(me.currentModel)
- strunzone(me.currentModel);
- if(me.currentModelTitle)
- strunzone(me.currentModelTitle);
- if(me.currentModelImage)
- strunzone(me.currentModelImage);
- if(me.currentModelDescription)
- strunzone(me.currentModelDescription);
-
- // select model #i!
- me.currentModelTitle = strzone(bufstr_get(me.bufModels, BUFMODELS_COUNT*me.idxModels+BUFMODELS_TITLE));
- me.currentModelImage = strzone(bufstr_get(me.bufModels, BUFMODELS_COUNT*me.idxModels+BUFMODELS_IMAGE));
- me.currentSkin = stof(bufstr_get(me.bufModels, BUFMODELS_COUNT*me.idxModels+BUFMODELS_SKIN));
- me.currentModel = strzone(bufstr_get(me.bufModels, BUFMODELS_COUNT*me.idxModels+BUFMODELS_MODEL));
- me.currentModelDescription = strzone(bufstr_get(me.bufModels, BUFMODELS_COUNT*me.idxModels+BUFMODELS_DESC));
-
- // fix the image
- if(draw_PictureSize(me.currentModelImage) == '0 0 0')
- me.src = "nopreview_player";
- else
- me.src = me.currentModelImage;
- me.updateAspect(me);
-}
-
-void PlayerModelSelector_Next_Click(entity btn, entity me)
-{
- if (me.numModels <= 0)
- return;
- me.go(me, +1);
- me.saveCvars(me);
-}
-
-void PlayerModelSelector_Prev_Click(entity btn, entity me)
-{
- if (me.numModels <= 0)
- return;
- me.go(me, -1);
- me.saveCvars(me);
-}
-
-void XonoticPlayerModelSelector_saveCvars(entity me)
-{
- // we can't immediately apply here because of flood control
- cvar_set("_cl_playermodel", me.currentModel);
- cvar_set("_cl_playerskin", ftos(me.currentSkin));
-}
-
-void XonoticPlayerModelSelector_draw(entity me)
-{
- float i, n;
- vector o;
-
- if (me.numModels <= 0)
- {
- draw_CenterText('0.5 0.5 0', _("<no model found>"), me.realFontSize, SKINCOLOR_TEXT, 0.6, FALSE);
- return;
- }
-
- SUPER(XonoticPlayerModelSelector).draw(me);
- // draw text on the image, handle \n in the description
-
- draw_beginBoldFont();
-
-#if XONVOTE186 // (nyov) lower name display looks better when there is no description text
- draw_CenterText('0.5 0.8 0', me.currentModelTitle, me.realFontSize * (me.titleFontSize / me.fontSize), SKINCOLOR_MODELTITLE, SKINALPHA_MODELTITLE, FALSE);
-#else
- draw_CenterText('0.5 0 0', me.currentModelTitle, me.realFontSize * (me.titleFontSize / me.fontSize), SKINCOLOR_MODELTITLE, SKINALPHA_MODELTITLE, FALSE);
-#endif
-
- draw_endBoldFont();
-
- o = '0.5 1 0' - eY * me.realFontSize_y * ((n = tokenizebyseparator(me.currentModelDescription, "\n")) + 0.5);
- for(i = 0; i < n; ++i)
- {
- draw_CenterText(o, argv(i), me.realFontSize, SKINCOLOR_TEXT, 1, FALSE);
- o += eY * me.realFontSize_y;
- }
-}
-
-void XonoticPlayerModelSelector_resizeNotify(entity me, vector relOrigin, vector relSize, vector absOrigin, vector absSize)
-{
- SUPER(XonoticPlayerModelSelector).resizeNotify(me, relOrigin, relSize, absOrigin, absSize);
- me.realFontSize_y = me.fontSize / absSize_y;
- me.realFontSize_x = me.fontSize / absSize_x;
-}
-
-void XonoticPlayerModelSelector_showNotify(entity me)
-{
- me.configureXonoticPlayerModelSelector(me);
-}
-#endif