1 #include "../../warpzonelib/mathlib.qh"
4 CLASS(XonoticDecibelsSlider) EXTENDS(XonoticSlider)
5 METHOD(XonoticDecibelsSlider, loadCvars, void(entity))
6 METHOD(XonoticDecibelsSlider, saveCvars, void(entity))
7 METHOD(XonoticDecibelsSlider, valueToText, string(entity, float))
8 ENDCLASS(XonoticDecibelsSlider)
9 entity makeXonoticDecibelsSlider(float, float, float, string);
14 float toDecibelOfSquare(float f, float mi)
16 float A = log(10) / 20; // note: about 0.115; inverse: about 8.686
21 float y = exp(1 + A * mi);
23 return mi + (t - mi) * (f / y);
28 float fromDecibelOfSquare(float f, float mi)
30 float A = log(10) / 20; // note: about 0.115; inverse: about 8.686
35 float y = exp(1 + A * mi);
37 return y * ((f - mi) / (t - mi));
42 entity makeXonoticDecibelsSlider(float theValueMin, float theValueMax, float theValueStep, string theCvar)
45 me = spawnXonoticDecibelsSlider();
46 me.configureXonoticSlider(me, theValueMin, theValueMax, theValueStep, theCvar);
49 void XonoticDecibelsSlider_loadCvars(entity me)
56 v = cvar(me.cvarName);
59 if(v > fromDecibelOfSquare(me.valueMax - 0.5 * me.valueStep, me.valueMin))
60 Slider_setValue(me, me.valueMax);
62 Slider_setValue(me, me.valueStep * floor(0.5 + toDecibelOfSquare(v, me.valueMin) / me.valueStep) );
64 void XonoticDecibelsSlider_saveCvars(entity me)
69 if(me.value > me.valueMax - 0.5 * me.valueStep)
70 cvar_set(me.cvarName, ftos(fromDecibelOfSquare(me.valueMax, me.valueMin)));
72 cvar_set(me.cvarName, ftos(fromDecibelOfSquare(me.value, me.valueMin)));
75 float autocvar_menu_snd_sliderscale;
76 string XonoticDecibelsSlider_valueToText(entity me, float v)
78 if(v > me.valueMax - 0.5 * me.valueStep)
79 return CTX(_("VOL^MAX"));
80 else if(v <= me.valueMin)
81 return CTX(_("VOL^OFF"));
82 else if(autocvar_menu_snd_sliderscale == 3) // fake percent scale
83 return sprintf("%d %%", (v - me.valueMin) / (me.valueMax - me.valueMin) * 100);
84 else if(autocvar_menu_snd_sliderscale == 2) // 0..10 scale
85 return sprintf("%.1f", (v - me.valueMin) / (me.valueMax - me.valueMin) * 10);
86 else if(autocvar_menu_snd_sliderscale == 1) // real percent scale
87 return sprintf("%.2f %%", fromDecibelOfSquare(v, me.valueMin) * 100);
89 return sprintf(_("%s dB"), ftos_decimals(toDecibelOfSquare(fromDecibelOfSquare(v, me.valueMin), 0), me.valueDigits));
92 void _TEST_XonoticDecibelsSlider()
95 for(i = -400; i < 0; ++i)
98 float v = fromDecibelOfSquare(db, -40);
99 float dbv = toDecibelOfSquare(v, -40);
101 printf("%f -> %f -> %f (diff: %f)\n", db, v, dbv, d);
102 TEST_Check(fabs(d) > 0.02);