262 lines
19 KiB
HTML
262 lines
19 KiB
HTML
<!DOCTYPE html>
|
||
<html>
|
||
<head>
|
||
<meta name="viewport" content="width=500">
|
||
<title>LED Settings</title>
|
||
<script>
|
||
var f=0,p=0,d=document,laprev=55;
|
||
function H()
|
||
{
|
||
window.open("https://github.com/Aircoookie/WLED/wiki/Settings#led-settings");
|
||
}
|
||
function B()
|
||
{
|
||
window.open("/settings","_self");
|
||
}
|
||
function S(){GetV();setTimeout(function(){fillfx(0);},200);setTimeout(function(){fillfx(1);},400);setABL();}
|
||
function enABL()
|
||
{
|
||
var en = d.getElementById('able').checked;
|
||
d.Sf.LA.value = (en) ? laprev:0;
|
||
d.getElementById('abl').style.display = (en) ? 'inline':'none';
|
||
d.getElementById('psu2').style.display = (en) ? 'inline':'none';
|
||
if (d.Sf.LA.value > 0) setABL();
|
||
}
|
||
function enLA()
|
||
{
|
||
var val = d.Sf.LAsel.value;
|
||
d.Sf.LA.value = val;
|
||
d.getElementById('LAdis').style.display = (val == 50) ? 'inline':'none';
|
||
UI();
|
||
}
|
||
function setABL()
|
||
{
|
||
d.getElementById('able').checked = true;
|
||
d.Sf.LAsel.value = 50;
|
||
switch (parseInt(d.Sf.LA.value)) {
|
||
case 0: d.getElementById('able').checked = false; enABL(); break;
|
||
case 30: d.Sf.LAsel.value = 30; break;
|
||
case 35: d.Sf.LAsel.value = 35; break;
|
||
case 55: d.Sf.LAsel.value = 55; break;
|
||
default: d.getElementById('LAdis').style.display = 'inline';
|
||
}
|
||
UI();
|
||
}
|
||
function UI()
|
||
{
|
||
var myC = d.querySelectorAll('.wc'),
|
||
l = myC.length;
|
||
for (i = 0; i < l; i++) {
|
||
myC[i].style.display = (d.getElementById('rgbw').checked) ? 'inline':'none';
|
||
}
|
||
|
||
d.getElementById('ledwarning').style.display = (d.Sf.LC.value > 1000) ? 'inline':'none';
|
||
d.getElementById('ampwarning').style.display = (d.Sf.MA.value > 7200) ? 'inline':'none';
|
||
|
||
if (d.Sf.LA.value > 0) laprev = d.Sf.LA.value;
|
||
|
||
var val = Math.ceil((100 + d.Sf.LC.value * laprev)/500)/2;
|
||
val = (val > 5) ? Math.ceil(val) : val;
|
||
var s = "";
|
||
var is12V = (d.Sf.LAsel.value == 30);
|
||
if (val < 1.02 && !is12V)
|
||
{
|
||
s = "ESP 5V pin with 1A USB supply";
|
||
} else
|
||
{
|
||
s += is12V ? "12V ":"5V ";
|
||
s += val;
|
||
s += "A supply connected to LEDs";
|
||
}
|
||
var val2 = Math.ceil((100 + d.Sf.LC.value * laprev)/1500)/2;
|
||
val2 = (val2 > 5) ? Math.ceil(val2) : val2;
|
||
var s2 = "(for most effects, ~";
|
||
s2 += val2;
|
||
s2 += "A is enough)<br>";
|
||
d.getElementById('psu').innerHTML = s;
|
||
d.getElementById('psu2').innerHTML = s2;
|
||
}
|
||
function fillfx(pl)
|
||
{
|
||
e="<option>Error loading list!</option>";
|
||
el=pl?Sf.FP:Sf.FX;
|
||
fetch(pl?'/json/palettes':'/json/effects')
|
||
.then(res => {
|
||
if (!res.ok) {
|
||
el.innerHTML=e;
|
||
}
|
||
return res.json();
|
||
})
|
||
.then(json => {
|
||
var x="";
|
||
for (i in json) {
|
||
x += "<option value=\""+i+"\">"+json[i]+" ("+i+")</option>";
|
||
}
|
||
el.innerHTML=x;
|
||
el.selectedIndex=pl?p:f;
|
||
})
|
||
.catch(function () {
|
||
el.innerHTML=e;
|
||
})
|
||
}
|
||
function GetV()
|
||
{
|
||
//values injected by server while sending HTML
|
||
}
|
||
</script>
|
||
<style>
|
||
:root {
|
||
--aCol: #fff;
|
||
--bCol: #333;
|
||
--cCol: #222;
|
||
--dCol: #fff;
|
||
--sCol: #0000;
|
||
}
|
||
body {
|
||
font-family: Verdana, Helvetica, sans-serif;
|
||
text-align: center;
|
||
background: var(--cCol);
|
||
color: var(--dCol);
|
||
line-height: 200%;
|
||
margin: 0;
|
||
background-attachment: fixed;
|
||
}
|
||
hr {
|
||
border-color: var(--dCol);
|
||
filter: drop-shadow( -5px -5px 5px var(--sCol) );
|
||
}
|
||
button {
|
||
background: var(--bCol);
|
||
color: var(--dCol);
|
||
border: 0.3ch solid var(--bCol);
|
||
display: inline-block;
|
||
filter: drop-shadow( -5px -5px 5px var(--sCol) );
|
||
font-size: 20px;
|
||
margin: 8px;
|
||
margin-top: 12px;
|
||
}
|
||
.helpB {
|
||
text-align: left;
|
||
position: absolute;
|
||
width:60px;
|
||
}
|
||
select {
|
||
background: var(--bCol);
|
||
color: var(--dCol);
|
||
border: 0.5ch solid var(--bCol);
|
||
font-family: var(--cFn), sans-serif;
|
||
filter: drop-shadow( -5px -5px 5px var(--sCol) );
|
||
}
|
||
input {
|
||
background: var(--bCol);
|
||
color: var(--dCol);
|
||
border: 0.5ch solid var(--bCol);
|
||
filter: drop-shadow( -5px -5px 5px var(--sCol) );
|
||
}
|
||
input[type=number] {
|
||
width: 4em;
|
||
}
|
||
</style>
|
||
</head>
|
||
<body onload="S()">
|
||
<form id="form_s" name="Sf" method="post">
|
||
<div class="helpB"><button type="button" onclick="H()">?</button></div>
|
||
<button type="button" onclick="B()">Back</button><button type="submit">Save</button><hr>
|
||
<h2>LED setup</h2>
|
||
LED count: <input name="LC" type="number" min="1" max="1500" oninput="UI()" required><br>
|
||
<div id="ledwarning" style="color: orange; display: none;">
|
||
⚠ You might run into stability or lag issues.<br>
|
||
Use less than 1000 LEDs per ESP for the best experience!<br>
|
||
</div>
|
||
<i>Recommended power supply for brightest white:</i><br>
|
||
<b><span id="psu">?</span></b><br>
|
||
<span id="psu2"><br></span>
|
||
<br>
|
||
Enable automatic brightness limiter: <input type="checkbox" name="ABen" onchange="enABL()" id="able"><br>
|
||
<div id="abl">
|
||
Maximum Current: <input name="MA" type="number" min="250" max="65000" oninput="UI()" required> mA<br>
|
||
<div id="ampwarning" style="color: orange; display: none;">
|
||
⚠ Your power supply provides high current.<br>
|
||
To improve the safety of your setup,<br>
|
||
please use thick cables,<br>
|
||
multiple power injection points and a fuse!<br>
|
||
</div>
|
||
<i>Automatically limits brightness to stay close to the limit.<br>
|
||
Keep at <1A if powering LEDs directly from the ESP 5V pin!<br>
|
||
If you are using an external power supply, enter its rating.<br>
|
||
(Current estimated usage: <span class="pow">unknown</span>)</i><br><br>
|
||
LED voltage (Max. current for a single LED):<br>
|
||
<select name="LAsel" onchange="enLA()">
|
||
<option value="55" selected>5V default (55mA)</option>
|
||
<option value="35">5V efficient (35mA)</option>
|
||
<option value="30">12V (30mA)</option>
|
||
<option value="50">Custom</option>
|
||
</select><br>
|
||
<span id="LAdis" style="display: none;">Custom max. current per LED: <input name="LA" type="number" min="0" max="255" id="la" oninput="UI()" required> mA<br></span>
|
||
<i>Keep at default if you are unsure about your type of LEDs.</i><br>
|
||
</div>
|
||
<br>
|
||
LEDs are 4-channel type (RGBW): <input type="checkbox" name="EW" onchange=UI() id="rgbw"><br>
|
||
Color order:
|
||
<select name="CO">
|
||
<option value="0">GRB</option>
|
||
<option value="1">RGB</option>
|
||
<option value="2">BRG</option>
|
||
<option value="3">RBG</option>
|
||
</select>
|
||
<h3>Defaults</h3>
|
||
Turn LEDs on after power up/reset: <input type="checkbox" name="BO"><br>
|
||
Default brightness: <input name="CA" type="number" min="0" max="255" required> (0-255)<br><br>
|
||
Set current color, brightness and effects as boot default: <input type="checkbox" name="IS"><br>
|
||
Set current preset cycle setting as boot default: <input type="checkbox" name="PC">
|
||
<br>- <i>or</i> -<br>
|
||
Apply preset <input name="BP" type="number" min="0" max="25" required> at boot (0 uses defaults)
|
||
<br>- <i>or</i> -<br>
|
||
Default RGB<span class="wc">W</span> color:<br>
|
||
<input name="CR" type="number" min="0" max="255" required>
|
||
<input name="CG" type="number" min="0" max="255" required>
|
||
<input name="CB" type="number" min="0" max="255" required>
|
||
<span class="wc"><input name="CW" type="number" min="0" max="255" required><br>
|
||
Auto-calculate white from RGB instead: <input type="checkbox" name="AW"></span><br>
|
||
Default secondary RGB<span class="wc">W</span>:<br>
|
||
<input name="SR" type="number" min="0" max="255" required>
|
||
<input name="SG" type="number" min="0" max="255" required>
|
||
<input name="SB" type="number" min="0" max="255" required>
|
||
<span class="wc"><input name="SW" type="number" min="0" max="255" required></span><br>
|
||
Default effect ID:<br>
|
||
<select name="FX">
|
||
<option>Loading...</option>
|
||
</select>
|
||
<br>Default color palette:<br>
|
||
<select name="FP">
|
||
<option>Loading...</option>
|
||
</select><br>
|
||
Default effect speed: <input name="SX" type="number" min="0" max="255" required><br>
|
||
Default effect intensity: <input name="IX" type="number" min="0" max="255" required><br><br>
|
||
Use Gamma correction for color: <input type="checkbox" name="GC"> (strongly recommended)<br>
|
||
Use Gamma correction for brightness: <input type="checkbox" name="GB"> (not recommended)<br><br>
|
||
Brightness factor: <input name="BF" type="number" min="1" max="255" required> %
|
||
<h3>Transitions</h3>
|
||
Crossfade: <input type="checkbox" name="TF"><br>
|
||
Transition Time: <input name="TD" maxlength="5" size="2"> ms<br>
|
||
Enable transition for secondary color: <input type="checkbox" name="T2"><br>
|
||
Enable Palette transitions: <input type="checkbox" name="PF">
|
||
<h3>Timed light</h3>
|
||
Default Duration: <input name="TL" type="number" min="1" max="255" required> min<br>
|
||
Default Target brightness: <input name="TB" type="number" min="0" max="255" required><br>
|
||
Fade down: <input type="checkbox" name="TW"><br>
|
||
<h3>Advanced</h3>
|
||
Palette blending:
|
||
<select name="PB">
|
||
<option value="0">Linear (wrap if moving)</option>
|
||
<option value="1">Linear (always wrap)</option>
|
||
<option value="2">Linear (never wrap)</option>
|
||
<option value="3">None (not recommended)</option>
|
||
</select><br>
|
||
Reverse LED order (rotate 180): <input type="checkbox" name="RV"><br>
|
||
Skip first LED: <input type="checkbox" name="SL"><hr>
|
||
<button type="button" onclick="B()">Back</button><button type="submit">Save</button>
|
||
</form>
|
||
</body>
|
||
</html>
|