mirror of
https://github.com/hanetzer/sdraw_mods_cvr.git
synced 2025-09-03 10:29:22 +00:00
442 lines
16 KiB
JavaScript
442 lines
16 KiB
JavaScript
// Add settings
|
|
var g_modSettingsLME = [];
|
|
|
|
engine.on('updateModSettingLME', function (_name, _value) {
|
|
for (var i = 0; i < g_modSettingsLME.length; i++) {
|
|
if (g_modSettingsLME[i].name == _name) {
|
|
g_modSettingsLME[i].updateValue(_value);
|
|
break;
|
|
}
|
|
}
|
|
});
|
|
|
|
// Modified from original `inp` types, because I have no js knowledge to hook stuff
|
|
function inp_toggle_mod_lme(_obj, _callbackName) {
|
|
this.obj = _obj;
|
|
this.callbackName = _callbackName;
|
|
this.value = _obj.getAttribute('data-current');
|
|
this.name = _obj.id;
|
|
this.type = _obj.getAttribute('data-type');
|
|
|
|
var self = this;
|
|
|
|
this.mouseDown = function (_e) {
|
|
self.value = self.value == "True" ? "False" : "True";
|
|
self.updateState();
|
|
}
|
|
|
|
this.updateState = function () {
|
|
self.obj.classList.remove("checked");
|
|
if (self.value == "True") {
|
|
self.obj.classList.add("checked");
|
|
}
|
|
|
|
engine.call(self.callbackName, self.name, self.value);
|
|
}
|
|
|
|
_obj.addEventListener('mousedown', this.mouseDown);
|
|
|
|
this.getValue = function () {
|
|
return self.value;
|
|
}
|
|
|
|
this.updateValue = function (value) {
|
|
self.value = value;
|
|
|
|
self.obj.classList.remove("checked");
|
|
if (self.value == "True") {
|
|
self.obj.classList.add("checked");
|
|
}
|
|
}
|
|
|
|
this.updateValue(this.value);
|
|
|
|
return {
|
|
name: this.name,
|
|
value: this.getValue,
|
|
updateValue: this.updateValue
|
|
}
|
|
}
|
|
|
|
function inp_slider_mod_lme(_obj, _callbackName) {
|
|
this.obj = _obj;
|
|
this.callbackName = _callbackName;
|
|
this.minValue = parseFloat(_obj.getAttribute('data-min'));
|
|
this.maxValue = parseFloat(_obj.getAttribute('data-max'));
|
|
this.percent = 0;
|
|
this.value = parseFloat(_obj.getAttribute('data-current'));
|
|
this.dragActive = false;
|
|
this.name = _obj.id;
|
|
this.type = _obj.getAttribute('data-type');
|
|
this.stepSize = _obj.getAttribute('data-stepSize') || 0;
|
|
this.format = _obj.getAttribute('data-format') || '{value}';
|
|
|
|
var self = this;
|
|
|
|
if (this.stepSize != 0)
|
|
this.value = Math.round(this.value / this.stepSize) * this.stepSize;
|
|
else
|
|
this.value = Math.round(this.value);
|
|
|
|
this.valueLabelBackground = document.createElement('div');
|
|
this.valueLabelBackground.className = 'valueLabel background';
|
|
this.valueLabelBackground.innerHTML = this.format.replace('{value}', this.value);
|
|
this.obj.appendChild(this.valueLabelBackground);
|
|
|
|
this.valueBar = document.createElement('div');
|
|
this.valueBar.className = 'valueBar';
|
|
this.valueBar.setAttribute('style', 'width: ' + (((this.value - this.minValue) / (this.maxValue - this.minValue)) * 100) + '%;');
|
|
this.obj.appendChild(this.valueBar);
|
|
|
|
this.valueLabelForeground = document.createElement('div');
|
|
this.valueLabelForeground.className = 'valueLabel foreground';
|
|
this.valueLabelForeground.innerHTML = this.format.replace('{value}', this.value);
|
|
this.valueLabelForeground.setAttribute('style', 'width: ' + (1.0 / ((this.value - this.minValue) / (this.maxValue - this.minValue)) * 100) + '%;');
|
|
this.valueBar.appendChild(this.valueLabelForeground);
|
|
|
|
this.mouseDown = function (_e) {
|
|
self.dragActive = true;
|
|
self.mouseMove(_e, false);
|
|
}
|
|
|
|
this.mouseMove = function (_e, _write) {
|
|
if (self.dragActive) {
|
|
var rect = _obj.getBoundingClientRect();
|
|
var start = rect.left;
|
|
var end = rect.right;
|
|
self.percent = Math.min(Math.max((_e.clientX - start) / rect.width, 0), 1);
|
|
var value = self.percent;
|
|
value *= (self.maxValue - self.minValue);
|
|
value += self.minValue;
|
|
if (self.stepSize != 0) {
|
|
value = Math.round(value / self.stepSize);
|
|
self.value = value * self.stepSize;
|
|
self.percent = (self.value - self.minValue) / (self.maxValue - self.minValue);
|
|
}
|
|
else
|
|
self.value = Math.round(value);
|
|
|
|
self.valueBar.setAttribute('style', 'width: ' + (self.percent * 100) + '%;');
|
|
self.valueLabelForeground.setAttribute('style', 'width: ' + (1.0 / self.percent * 100) + '%;');
|
|
self.valueLabelBackground.innerHTML = self.valueLabelForeground.innerHTML = self.format.replace('{value}', self.value);
|
|
|
|
engine.call(self.callbackName, self.name, "" + self.value);
|
|
self.displayImperial();
|
|
}
|
|
}
|
|
|
|
this.mouseUp = function (_e) {
|
|
self.mouseMove(_e, true);
|
|
self.dragActive = false;
|
|
}
|
|
|
|
_obj.addEventListener('mousedown', this.mouseDown);
|
|
document.addEventListener('mousemove', this.mouseMove);
|
|
document.addEventListener('mouseup', this.mouseUp);
|
|
|
|
this.getValue = function () {
|
|
return self.value;
|
|
}
|
|
|
|
this.updateValue = function (value) {
|
|
if (self.stepSize != 0)
|
|
self.value = Math.round(value * self.stepSize) / self.stepSize;
|
|
else
|
|
self.value = Math.round(value);
|
|
self.percent = (self.value - self.minValue) / (self.maxValue - self.minValue);
|
|
self.valueBar.setAttribute('style', 'width: ' + (self.percent * 100) + '%;');
|
|
self.valueLabelForeground.setAttribute('style', 'width: ' + (1.0 / self.percent * 100) + '%;');
|
|
self.valueLabelBackground.innerHTML = self.valueLabelForeground.innerHTML = self.format.replace('{value}', self.value);
|
|
self.displayImperial();
|
|
}
|
|
|
|
this.displayImperial = function () {
|
|
var displays = document.querySelectorAll('.imperialDisplay');
|
|
for (var i = 0; i < displays.length; i++) {
|
|
var binding = displays[i].getAttribute('data-binding');
|
|
if (binding == self.name) {
|
|
var realFeet = ((self.value * 0.393700) / 12);
|
|
var feet = Math.floor(realFeet);
|
|
var inches = Math.floor((realFeet - feet) * 12);
|
|
displays[i].innerHTML = feet + "'" + inches + '''';
|
|
}
|
|
}
|
|
}
|
|
|
|
return {
|
|
name: this.name,
|
|
value: this.getValue,
|
|
updateValue: this.updateValue
|
|
}
|
|
}
|
|
|
|
function inp_dropdown_mod_lme(_obj, _callbackName) {
|
|
this.obj = _obj;
|
|
this.callbackName = _callbackName;
|
|
this.value = _obj.getAttribute('data-current');
|
|
this.options = _obj.getAttribute('data-options').split(',');
|
|
this.name = _obj.id;
|
|
this.opened = false;
|
|
this.keyValue = [];
|
|
this.type = _obj.getAttribute('data-type');
|
|
|
|
this.optionElements = [];
|
|
|
|
var self = this;
|
|
|
|
this.SelectValue = function (_e) {
|
|
self.value = _e.target.getAttribute('data-key');
|
|
self.valueElement.innerHTML = _e.target.getAttribute('data-value');
|
|
self.globalClose();
|
|
|
|
engine.call(self.callbackName, self.name, self.value);
|
|
}
|
|
|
|
this.openClick = function (_e) {
|
|
if (self.obj.classList.contains('open')) {
|
|
self.obj.classList.remove('open');
|
|
self.list.setAttribute('style', 'display: none;');
|
|
} else {
|
|
self.obj.classList.add('open');
|
|
self.list.setAttribute('style', 'display: block;');
|
|
self.opened = true;
|
|
window.setTimeout(function () { self.opened = false; }, 10);
|
|
}
|
|
}
|
|
|
|
this.globalClose = function (_e) {
|
|
if (self.opened) return;
|
|
self.obj.classList.remove('open');
|
|
self.list.setAttribute('style', 'display: none;');
|
|
}
|
|
|
|
this.list = document.createElement('div');
|
|
this.list.className = 'valueList';
|
|
|
|
this.updateOptions = function () {
|
|
self.list.innerHTML = "";
|
|
for (var i = 0; i < self.options.length; i++) {
|
|
self.optionElements[i] = document.createElement('div');
|
|
self.optionElements[i].className = 'listValue';
|
|
var valuePair = Array.isArray(self.options[i]) ? self.options[i] : self.options[i].split(':');
|
|
var key = "";
|
|
var value = "";
|
|
if (valuePair.length == 1) {
|
|
key = valuePair[0];
|
|
value = valuePair[0];
|
|
} else {
|
|
key = valuePair[0];
|
|
value = valuePair[1];
|
|
}
|
|
self.keyValue[key] = value;
|
|
self.optionElements[i].innerHTML = value;
|
|
self.optionElements[i].setAttribute('data-value', value);
|
|
self.optionElements[i].setAttribute('data-key', key);
|
|
self.list.appendChild(self.optionElements[i]);
|
|
self.optionElements[i].addEventListener('mousedown', self.SelectValue);
|
|
}
|
|
|
|
self.valueElement.innerHTML = self.keyValue[self.value];
|
|
}
|
|
|
|
this.valueElement = document.createElement('div');
|
|
this.valueElement.className = 'dropdown-value';
|
|
|
|
this.updateOptions();
|
|
|
|
this.obj.appendChild(this.valueElement);
|
|
this.obj.appendChild(this.list);
|
|
this.valueElement.addEventListener('mousedown', this.openClick);
|
|
document.addEventListener('mousedown', this.globalClose);
|
|
|
|
this.getValue = function () {
|
|
return self.value;
|
|
}
|
|
|
|
this.updateValue = function (value) {
|
|
self.value = value;
|
|
self.valueElement.innerHTML = self.keyValue[value];
|
|
}
|
|
|
|
this.setOptions = function (options) {
|
|
self.options = options;
|
|
}
|
|
|
|
return {
|
|
name: this.name,
|
|
value: this.getValue,
|
|
updateValue: this.updateValue,
|
|
updateOptions: this.updateOptions,
|
|
setOptions: this.setOptions
|
|
}
|
|
}
|
|
|
|
// Add own menu
|
|
{
|
|
let l_block = document.createElement('div');
|
|
l_block.innerHTML = `
|
|
<div class ="settings-subcategory">
|
|
<div class ="subcategory-name">Leap Motion tracking</div>
|
|
<div class ="subcategory-description"></div>
|
|
</div>
|
|
|
|
<div class ="row-wrapper">
|
|
<div class ="option-caption">Enable tracking: </div>
|
|
<div class ="option-input">
|
|
<div id="Enabled" class ="inp_toggle no-scroll" data-current="false"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class ="row-wrapper">
|
|
<div class ="option-caption">Tracking mode: </div>
|
|
<div class ="option-input">
|
|
<div id="Mode" class ="inp_dropdown no-scroll" data-options="0:Screentop,1:Desktop,2:HMD" data-current="1"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class ="row-wrapper">
|
|
<div class ="option-caption">Desktop offset X: </div>
|
|
<div class ="option-input">
|
|
<div id="DesktopX" class ="inp_slider no-scroll" data-min="-100" data-max="100" data-current="0"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class ="row-wrapper">
|
|
<div class ="option-caption">Desktop offset Y: </div>
|
|
<div class ="option-input">
|
|
<div id="DesktopY" class ="inp_slider no-scroll" data-min="-100" data-max="100" data-current="-45"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class ="row-wrapper">
|
|
<div class ="option-caption">Desktop offset Z: </div>
|
|
<div class ="option-input">
|
|
<div id="DesktopZ" class ="inp_slider no-scroll" data-min="-100" data-max="100" data-current="30"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class ="row-wrapper">
|
|
<div class ="option-caption">Attach to head: </div>
|
|
<div class ="option-input">
|
|
<div id="Head" class ="inp_toggle no-scroll" data-current="false"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class ="row-wrapper">
|
|
<div class ="option-caption">Head offset X: </div>
|
|
<div class ="option-input">
|
|
<div id="HeadX" class ="inp_slider no-scroll" data-min="-100" data-max="100" data-current="0"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class ="row-wrapper">
|
|
<div class ="option-caption">Head offset Y: </div>
|
|
<div class ="option-input">
|
|
<div id="HeadY" class ="inp_slider no-scroll" data-min="-100" data-max="100" data-current="-30"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class ="row-wrapper">
|
|
<div class ="option-caption">Head offset Z: </div>
|
|
<div class ="option-input">
|
|
<div id="HeadZ" class ="inp_slider no-scroll" data-min="-100" data-max="100" data-current="15"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class ="row-wrapper">
|
|
<div class ="option-caption">Offset angle X: </div>
|
|
<div class ="option-input">
|
|
<div id="AngleX" class ="inp_slider no-scroll" data-min="-180" data-max="180" data-current="0"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class ="row-wrapper">
|
|
<div class ="option-caption">Offset angle Y: </div>
|
|
<div class ="option-input">
|
|
<div id="AngleY" class ="inp_slider no-scroll" data-min="-180" data-max="180" data-current="0"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class ="row-wrapper">
|
|
<div class ="option-caption">Offset angle Z: </div>
|
|
<div class ="option-input">
|
|
<div id="AngleZ" class ="inp_slider no-scroll" data-min="-180" data-max="180" data-current="0"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class ="row-wrapper">
|
|
<div class ="option-caption">Track elbows: </div>
|
|
<div class ="option-input">
|
|
<div id="TrackElbows" class ="inp_toggle no-scroll" data-current="true"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class ="row-wrapper">
|
|
<div class ="option-caption">Fingers tracking only: </div>
|
|
<div class ="option-input">
|
|
<div id="FingersOnly" class ="inp_toggle no-scroll" data-current="false"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class ="row-wrapper">
|
|
<div class ="option-caption">Model visibility: </div>
|
|
<div class ="option-input">
|
|
<div id="Model" class ="inp_toggle no-scroll" data-current="false"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class ="row-wrapper">
|
|
<div class ="option-caption">Visualize hands: </div>
|
|
<div class ="option-input">
|
|
<div id="VisualHands" class ="inp_toggle no-scroll" data-current="false"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class ="row-wrapper">
|
|
<div class ="option-caption">Interaction input: </div>
|
|
<div class ="option-input">
|
|
<div id="Input" class ="inp_toggle no-scroll" data-current="false"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class ="row-wrapper">
|
|
<div class ="option-caption">Recognize gestures: </div>
|
|
<div class ="option-input">
|
|
<div id="Gestures" class ="inp_toggle no-scroll" data-current="false"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class ="row-wrapper">
|
|
<div class ="option-caption">Interact gesture threadhold: </div>
|
|
<div class ="option-input">
|
|
<div id="InteractThreadhold" class ="inp_slider no-scroll" data-min="0" data-max="100" data-current="80"></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class ="row-wrapper">
|
|
<div class ="option-caption">Grip gesture threadhold: </div>
|
|
<div class ="option-input">
|
|
<div id="GripThreadhold" class ="inp_slider no-scroll" data-min="0" data-max="100" data-current="40"></div>
|
|
</div>
|
|
</div>
|
|
`;
|
|
document.getElementById('settings-implementation').appendChild(l_block);
|
|
|
|
// Update toggles in new menu block
|
|
let l_toggles = l_block.querySelectorAll('.inp_toggle');
|
|
for (var i = 0; i < l_toggles.length; i++) {
|
|
g_modSettingsLME[g_modSettingsLME.length] = new inp_toggle_mod_lme(l_toggles[i], 'MelonMod_LME_Call_InpToggle');
|
|
}
|
|
|
|
// Update sliders in new menu block
|
|
let l_sliders = l_block.querySelectorAll('.inp_slider');
|
|
for (var i = 0; i < l_sliders.length; i++) {
|
|
g_modSettingsLME[g_modSettingsLME.length] = new inp_slider_mod_lme(l_sliders[i], 'MelonMod_LME_Call_InpSlider');
|
|
}
|
|
|
|
//Update dropdowns in new menu block
|
|
let l_dropdowns = l_block.querySelectorAll('.inp_dropdown');
|
|
for (var i = 0; i < l_dropdowns.length; i++) {
|
|
g_modSettingsLME[g_modSettingsLME.length] = new inp_dropdown_mod_lme(l_dropdowns[i], 'MelonMod_LME_Call_InpDropdown');
|
|
}
|
|
}
|