1095 lines
50 KiB
HTML
Executable File
1095 lines
50 KiB
HTML
Executable File
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="utf-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
|
|
<meta name="description" content="">
|
|
<meta name="author" content="M. Lehmann">
|
|
<title>CG scale by M. Lehmann</title>
|
|
<style>
|
|
body {
|
|
font-family: "Trebuchet MS", Arial, Helvetica, sans-serif;
|
|
background: #DCDCDC;
|
|
margin:0;
|
|
}
|
|
|
|
/***** remove standard-styles *****/
|
|
input, select, textarea {
|
|
-webkit-appearance: none;
|
|
-moz-appearance: none;
|
|
appearance: none;
|
|
border:none;
|
|
border-radius: 4px;
|
|
font-size: 1em;
|
|
width: 100%
|
|
}
|
|
|
|
/***** navbar *****/
|
|
|
|
.navbar {
|
|
list-style-type: none;
|
|
margin: 0;
|
|
padding: 0;
|
|
top: 0;
|
|
width: 100%;
|
|
background-color: #555;
|
|
position: fixed;
|
|
overflow: auto;
|
|
z-index: 10;
|
|
}
|
|
|
|
.navbar logo {
|
|
float: left;
|
|
display: block;
|
|
padding: 12px;
|
|
color: white;
|
|
text-decoration: none;
|
|
font-size: 32px;
|
|
}
|
|
|
|
.navbar a {
|
|
float: right;
|
|
display: block;
|
|
padding: 12px;
|
|
color: white;
|
|
text-decoration: none;
|
|
font-size: 32px;
|
|
}
|
|
|
|
.navbar a:hover {
|
|
background-color: #000;
|
|
}
|
|
|
|
.active {
|
|
background-color: #1E90FF;
|
|
}
|
|
|
|
.navbar .icon {
|
|
display: none;
|
|
}
|
|
|
|
@media screen and (max-width: 600px) {
|
|
.navbar a:not(:first-child) {display: none;}
|
|
.navbar a.icon {
|
|
float: right;
|
|
display: block;
|
|
}
|
|
.navbar.responsive {position: relative;}
|
|
.navbar.responsive .icon {
|
|
position: absolute;
|
|
right: 0;
|
|
top: 0;
|
|
height: auto;
|
|
}
|
|
.navbar.responsive a {
|
|
float: none;
|
|
display: block;
|
|
text-align: left;
|
|
}
|
|
.navbar.responsive logo{display: none;}
|
|
}
|
|
|
|
/***** Upload *****/
|
|
|
|
.upload-btn-wrapper {
|
|
position: relative;
|
|
overflow: hidden;
|
|
display: inline-block;
|
|
}
|
|
|
|
.btn {
|
|
border: 1px solid #bbb;
|
|
color: #bbb;
|
|
background-color: white;
|
|
padding: 8px 16px;
|
|
padding-right: 100px;
|
|
border-radius: 4px 0px 0px 4px;
|
|
font-size: 16px;
|
|
}
|
|
|
|
.upload-btn-wrapper input[type=file] {
|
|
font-size: 100px;
|
|
position: absolute;
|
|
left: 0;
|
|
top: 0;
|
|
opacity: 0;
|
|
}
|
|
|
|
|
|
/***** tab *****/
|
|
|
|
* {
|
|
box-sizing: border-box;
|
|
}
|
|
|
|
.wrapper {
|
|
width: 100%;
|
|
margin: 0 auto;
|
|
}
|
|
.tabs {
|
|
position: relative;
|
|
margin: 3rem 0;
|
|
background: #1abc9c;
|
|
}
|
|
.tabs::before,
|
|
.tabs::after {
|
|
content: "";
|
|
display: table;
|
|
}
|
|
.tabs::after {
|
|
clear: both;
|
|
}
|
|
.tab {
|
|
float: left;
|
|
}
|
|
.tab-switch {
|
|
display: none;
|
|
}
|
|
.tab-label {
|
|
position: relative;
|
|
display: block;
|
|
line-height: 2.75em;
|
|
height: 3em;
|
|
padding: 0 1.618em;
|
|
background: #1abc9c;
|
|
border-right: 0.125rem solid #16a085;
|
|
color: #2c3e50;
|
|
cursor: pointer;
|
|
top: 0;
|
|
transition: all 0.25s;
|
|
}
|
|
.tab-label:hover {
|
|
top: -0.25rem;
|
|
transition: top 0.25s;
|
|
}
|
|
.tab-content {
|
|
height: 2300px;
|
|
width: 100%;
|
|
position: absolute;
|
|
z-index: 1;
|
|
top: 2.75em;
|
|
left: 0;
|
|
padding: 1.618rem;
|
|
background: #FFFFFF;
|
|
color: #2c3e50;
|
|
opacity: 0;
|
|
transition: all 0.35s;
|
|
}
|
|
.tab-switch:checked + .tab-label {
|
|
background: #FFFFFF;
|
|
color: #2c3e50;
|
|
border-bottom: 0;
|
|
transition: all 0.35s;
|
|
z-index: 1;
|
|
top: -0.0625rem;
|
|
}
|
|
.tab-switch:checked + label + .tab-content {
|
|
z-index: 2;
|
|
opacity: 1;
|
|
transition: all 0.35s;
|
|
}
|
|
|
|
/***** button *****/
|
|
|
|
.button {
|
|
border: none;
|
|
border-radius: 4px;
|
|
color: white;
|
|
padding: 7px 16px;
|
|
text-align: center;
|
|
text-decoration: none;
|
|
display: inline-block;
|
|
font-size: 16px;
|
|
margin: 4px 2px;
|
|
-webkit-transition-duration: 0.4s; /* Safari */
|
|
transition-duration: 0.4s;
|
|
cursor: pointer;
|
|
}
|
|
|
|
.calButton {
|
|
background-color: white;
|
|
color: black;
|
|
border: 2px solid #1E90FF;
|
|
}
|
|
|
|
.calButton:hover {
|
|
background-color: #1E90FF;
|
|
color: white;
|
|
}
|
|
|
|
.tareButton {
|
|
background-color: white;
|
|
color: black;
|
|
border: 2px solid #778899;
|
|
}
|
|
|
|
.tareButton:hover {
|
|
background-color: #778899;
|
|
color: white;
|
|
}
|
|
|
|
.saveButton {
|
|
background-color: white;
|
|
color: black;
|
|
border: 2px solid #1abc9c;
|
|
}
|
|
|
|
.saveButton:hover {
|
|
background-color: #1abc9c;
|
|
color: white;
|
|
}
|
|
|
|
.backupButton {
|
|
background-color: white;
|
|
color: black;
|
|
border: 2px solid #f04029;
|
|
}
|
|
|
|
.backupButton:hover {
|
|
background-color: #f04029;
|
|
color: white;
|
|
}
|
|
|
|
.updateButton {
|
|
background-color: white;
|
|
color: black;
|
|
border: 2px solid #1E90FF;
|
|
}
|
|
|
|
.updateButton:hover {
|
|
background-color: #1E90FF;
|
|
color: white;
|
|
}
|
|
|
|
.donateButton {
|
|
background-color: white;
|
|
color: black;
|
|
border: 2px solid #f7c40c;
|
|
background-color: #f7c40c;
|
|
width: 130px;
|
|
margin: auto;
|
|
display: flex;
|
|
justify-content: center;
|
|
}
|
|
|
|
.donateButton:hover {
|
|
border: 2px solid #f7a10c;
|
|
background-color: #f7a10c;
|
|
color: white;
|
|
}
|
|
|
|
.uploadButton {
|
|
background-color: white;
|
|
color: black;
|
|
border: 2px solid #1E90FF;
|
|
border-radius: 0px 4px 4px 0px;
|
|
margin-left: -7px;
|
|
}
|
|
|
|
.uploadButton:hover {
|
|
background-color: #1E90FF;
|
|
color: white;
|
|
}
|
|
|
|
/***** Labels *****/
|
|
|
|
big{
|
|
display: inline-block;
|
|
padding: 10px 2px;
|
|
padding-top: 15px;
|
|
font-size: 16px;
|
|
color: #3c3c3c;
|
|
}
|
|
|
|
small{
|
|
display: inline-block;
|
|
padding: 10px 2px;
|
|
font-size: 12px;
|
|
color: #808080;
|
|
}
|
|
|
|
.titlebar {
|
|
margin-left:30px;
|
|
margin-top:95px;
|
|
font-size:25px;
|
|
float: left;
|
|
width:40%;
|
|
}
|
|
|
|
.buttonbar {
|
|
margin-right:20px;
|
|
margin-top:85px;
|
|
float: right;
|
|
text-align:right;
|
|
width:50%;
|
|
}
|
|
|
|
.main_container {
|
|
padding-left:20px;
|
|
padding-right: 20px;
|
|
padding-top:105px;
|
|
padding-bottom: 2240px
|
|
}
|
|
|
|
@media screen and (max-width: 600px) {
|
|
.titlebar {
|
|
width:100%;
|
|
}
|
|
|
|
.buttonbar {
|
|
margin-left:20px;
|
|
margin-top:20px;
|
|
float: left;
|
|
text-align:left;
|
|
width:100%;
|
|
}
|
|
|
|
.main_container {
|
|
padding-top:165px;
|
|
}
|
|
}
|
|
|
|
/***** Input *****/
|
|
|
|
input{
|
|
background-color:white;
|
|
border: 1px solid #bbb;
|
|
padding:.75em 1em .5em 1em;
|
|
font-size: 16px;
|
|
color: #3c3c3c;
|
|
}
|
|
|
|
input:active,
|
|
|
|
|
|
/***** selectbox *****/
|
|
|
|
select {
|
|
border: 1px solid #bbb;
|
|
padding:.75em 1em .5em 1em;
|
|
background-color:white;
|
|
background-image:url('');
|
|
background-position: right;
|
|
background-repeat: no-repeat;
|
|
font-size: 16px;
|
|
color: #3c3c3c;
|
|
}
|
|
|
|
/* Hide browser-styling in IE10 */
|
|
select::-ms-expand {
|
|
display:none;
|
|
}
|
|
|
|
/* Hide custom-icons in lower versions of Internet Explorer (< IE10). */
|
|
.lt-ie10 select {
|
|
background-image: none;
|
|
}
|
|
|
|
/***** switch *****/
|
|
|
|
.switch {
|
|
position: relative;
|
|
display: inline-block;
|
|
width: 60px;
|
|
height: 34px;
|
|
}
|
|
|
|
.switch input {
|
|
opacity: 0;
|
|
width: 0;
|
|
height: 0;
|
|
}
|
|
|
|
.slider {
|
|
position: absolute;
|
|
cursor: pointer;
|
|
top: 0;
|
|
left: 0;
|
|
right: 0;
|
|
bottom: 0;
|
|
background-color: #ccc;
|
|
border-radius: 34px;
|
|
-webkit-transition: .4s;
|
|
transition: .4s;
|
|
}
|
|
|
|
.slider:before {
|
|
position: absolute;
|
|
content: "";
|
|
height: 26px;
|
|
width: 26px;
|
|
left: 4px;
|
|
bottom: 4px;
|
|
background-color: white;
|
|
border-radius: 50%;
|
|
-webkit-transition: .4s;
|
|
transition: .4s;
|
|
}
|
|
|
|
input:checked + .slider {
|
|
background-color: #1abc9c;
|
|
}
|
|
|
|
input:focus + .slider {
|
|
box-shadow: 0 0 1px #1abc9c;
|
|
}
|
|
|
|
input:checked + .slider:before {
|
|
-webkit-transform: translateX(26px);
|
|
-ms-transform: translateX(26px);
|
|
transform: translateX(26px);
|
|
}
|
|
</style>
|
|
|
|
<script>
|
|
var CG_trans_visible = true;
|
|
var batVolt_visible = true;
|
|
var curSSID_STA = "";
|
|
|
|
var translation;
|
|
var languages = {
|
|
"en":{
|
|
"settingsLabel":"Settings",
|
|
"tareBtn":"Tare",
|
|
"saveBtn":"Save",
|
|
"tabGeneral":"General",
|
|
"wifiHeading":"WiFi",
|
|
"homeWifiSSID":"Home WiFi name (SSID):",
|
|
"homeWifiSSIDdesc":"Connect to existing network",
|
|
"homeWifiPW":"WiFi password:",
|
|
"APwifiSSID":"Device name / Access point WiFi name (SSID):",
|
|
"APwifiSSIDdesc":"If no Home network is present, a access point is created",
|
|
"APwifiPW":"WiFi password:",
|
|
"APwifiPWdesc":"At least 8 characters",
|
|
"checkUpdate":"Automatically check for firmware updates at startup",
|
|
"enableOTAlabel":"Enable over the air update",
|
|
"modelDBheading":"Model database",
|
|
"modelDBdesc":"Download model database to your Computer.",
|
|
"backupBTN":"Backup",
|
|
"backupDesc":"Restore your model database. Select the 'models.json' file on your computer.",
|
|
"file-upload-filename":"Choose a file...",
|
|
"uploadBTN":"Upload",
|
|
"aboutHeading":"About CG scale",
|
|
"aboutDesc":"The CG Scale firmware is open source and available free of charge. If you like it, support the project with a donation and help it to be continuously developed.",
|
|
"donateBTN":"Donate",
|
|
"updateHeading":"Update",
|
|
"updateDesc":"A backup of the model database must be created before the firmware update! Download the latest version from https://github.com/nightflyer88/CG_scale/releases/latest, and then update the firmware (cgscale_xxx.bin) and the file system (cgscale_spiffs.bin).",
|
|
"updateBTN":"Firmware update",
|
|
"tabMechanics":"Mechanics",
|
|
"mechanicsTypeHeading":"Mechanics:",
|
|
"mechanics0":"Fixed contact surfaces",
|
|
"mechanics1":"movable contact surfaces",
|
|
"mechanics2":"2-point landing gear",
|
|
"mechanics3":"3-point landing gear",
|
|
"nLoadcellsHeading":"Number of load cells:",
|
|
"dist1label":"Distance X1 [mm]:",
|
|
"dist2label":"Distance X2 [mm]:",
|
|
"dist3label":"Distance X3 [mm]:",
|
|
"calHelpTxt":"To calibrate the cells it is recommended to use a reference object with a known weight and CG. Enter these values, check that the scale indicates 0g, then place the reference object on it and press 'Auto calibrate'. Otherwise, the calibration values can also be set manually.",
|
|
"refWgLabel":"Reference weight [g]:",
|
|
"refCGLabel":"Reference CG [mm]:",
|
|
"autoCalDesc":"The parameters must be saved before calibration.",
|
|
"autoCalBTN":"Auto calibrate",
|
|
"lc1Label":"Loadcell 1: ",
|
|
"lc2Label":"Loadcell 2: ",
|
|
"lc3Label":"Loadcell 3: ",
|
|
"cal1Label":"Calibration factor of load cell 1:",
|
|
"cal2Label":"Calibration factor of load cell 2:",
|
|
"cal3Label":"Calibration factor of load cell 3:",
|
|
"tabBattery":"Battery",
|
|
"batteryTypeLabel":"Battery type:",
|
|
"batT0":"OFF",
|
|
"batT1":"Voltage",
|
|
"batteryTypeDesc":"Select the battery type to display the percent. 'Voltage' only shows the battery voltage.",
|
|
"nBatCells":"Number of battery cells:",
|
|
"R1label":"Value of resistor R1 [ohm]:",
|
|
"R2label":"Value of resistor R2 [ohm]:"
|
|
},
|
|
"de":{
|
|
"settingsLabel":"Einstellungen",
|
|
"tareBtn":"Tare",
|
|
"saveBtn":"Speichern",
|
|
"tabGeneral":"Allgemein",
|
|
"wifiHeading":"WiFi",
|
|
"homeWifiSSID":"Home WiFi Name (SSID):",
|
|
"homeWifiSSIDdesc":"In bestehendes Netzwerk einloggen",
|
|
"homeWifiPW":"WiFi Passwort:",
|
|
"APwifiSSID":"Gerätename / Access point WiFi Name (SSID):",
|
|
"APwifiSSIDdesc":"Wenn kein Heimnetzwerk vorhanden ist, wird ein Access point erstellt",
|
|
"APwifiPW":"WiFi Passwort:",
|
|
"APwifiPWdesc":"Mindestens 8 Zeichen",
|
|
"checkUpdate":"Beim Start automatisch nach Firmware-Updates suchen",
|
|
"enableOTAlabel":"Over-the-Air Update aktivieren",
|
|
"modelDBheading":"Modell Datenbank",
|
|
"modelDBdesc":"Laden Sie die Modelldatenbank auf Ihren Computer herunter.",
|
|
"backupBTN":"Backup",
|
|
"backupDesc":"Stellen Sie Ihre Modelldatenbank wieder her. Wählen Sie die Datei 'models.json' auf Ihrem Computer.",
|
|
"file-upload-filename":"Datei wählen...",
|
|
"uploadBTN":"Upload",
|
|
"aboutHeading":"Über CG Scale",
|
|
"aboutDesc":"Die CG Scale-Firmware ist Quelloffen und kostenlos erhältlich. Wenn es Ihnen gefällt, unterstützen Sie das Projekt mit einer Spende und helfen Sie mit, dass es kontinuierlich weiterentwickelt wird.",
|
|
"donateBTN":"Spenden",
|
|
"updateHeading":"Update",
|
|
"updateDesc":"Vor dem Firmware Update muss ein Backup der Modelldatenbank erstellt werden ! Laden Sie die neuste Version von https://github.com/nightflyer88/CG_scale/releases/latest herunter, und aktualisieren Sie anschliessend die Firmware (cgscale_xxx.bin) und das Filesystem (cgscale_spiffs.bin).",
|
|
"updateBTN":"Firmware Update",
|
|
"tabMechanics":"Mechanik",
|
|
"mechanicsTypeHeading":"Mechanik:",
|
|
"mechanics0":"Feste Auflageflächen",
|
|
"mechanics1":"bewegliche Auflageflächen",
|
|
"mechanics2":"2 Punkt Fahrwerk",
|
|
"mechanics3":"3 Punkt Fahrwerk",
|
|
"nLoadcellsHeading":"Anzahl Wägezellen:",
|
|
"dist1label":"Distanz X1 [mm]:",
|
|
"dist2label":"Distanz X2 [mm]:",
|
|
"dist3label":"Distanz X3 [mm]:",
|
|
"calHelpTxt":"Zur Kalibrierung der Zellen wird empfohlen, ein Referenzobjekt mit bekanntem Gewicht und Schwerpunkt zu verwenden. Geben Sie diese Werte ein, überprüfen Sie dass die Waage 0g anzeigt, legen Sie das Referenzobjekt darauf und drücken Sie auf 'Automatisch kalibrieren'. Die Kalibrierwerte können ansonsten auch manuell eingestellt werden.",
|
|
"refWgLabel":"Referenz Gewicht [g]:",
|
|
"refCGLabel":"Referenz Schwerpunkt [mm]:",
|
|
"autoCalDesc":"Vor dem kalibrieren müssen die Parameter gespeichert werden.",
|
|
"autoCalBTN":"Automatisch kalibrieren",
|
|
"lc1Label":"Wägezelle 1: ",
|
|
"lc2Label":"Wägezelle 2: ",
|
|
"lc3Label":"Wägezelle 3: ",
|
|
"cal1Label":"Kalibrierfaktor Wägezelle 1:",
|
|
"cal2Label":"Kalibrierfaktor Wägezelle 2:",
|
|
"cal3Label":"Kalibrierfaktor Wägezelle 3:",
|
|
"tabBattery":"Batterie",
|
|
"batteryTypeLabel":"Batterie Typ:",
|
|
"batT0":"AUS",
|
|
"batT1":"Spannung",
|
|
"batteryTypeDesc":"Wählen Sie den Batterietyp aus, um den Prozentwert anzuzeigen. Mit 'Spannung' wird nur die Batteriespannung angezeigt.",
|
|
"nBatCells":"Anzahl Batteriezellen",
|
|
"R1label":"Wert des Widerstandes R1 [ohm]:",
|
|
"R2label":"Wert des Widerstandes R2 [ohm]:"
|
|
}
|
|
};
|
|
|
|
|
|
function setTranslation(defaultLang) {
|
|
var lang = navigator.languages ? navigator.languages[0] : navigator.language;
|
|
lang = lang.substr(0, 2);
|
|
|
|
translation = languages[lang] || languages[defaultLang];
|
|
|
|
for (var item in translation) {
|
|
var docElement = document.getElementById(item);
|
|
if(docElement){
|
|
docElement.innerHTML = translation[item];
|
|
}
|
|
}
|
|
}
|
|
|
|
function getHead(){
|
|
var request = new XMLHttpRequest();
|
|
request.onreadystatechange = function(){
|
|
if(this.readyState == 4 && this.status == 200){
|
|
if(this.responseText != null){
|
|
var responseString = this.responseText;
|
|
var value = responseString.split("&");
|
|
document.getElementById("ssid").innerHTML = value[0];
|
|
document.getElementById("cgscaleVersion").innerHTML = value[2];
|
|
// check if new version available
|
|
if(parseFloat(value[3]) > parseFloat(value[2])){
|
|
if (confirm("A new firmware version is available: V" + value[3] + "\nPlease download the latest version from GitHub and update the firmware.")) {
|
|
location.href='https://github.com/nightflyer88/CG_scale/releases/latest'
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
request.open("GET", "getHead", true);
|
|
request.send();
|
|
}
|
|
|
|
function getParameter(func){
|
|
var request = new XMLHttpRequest();
|
|
request.onreadystatechange = function(){
|
|
if(this.readyState == 4 && this.status == 200){
|
|
if(this.responseText != null){
|
|
var responseString = this.responseText;
|
|
var value = responseString.split("&");
|
|
setValue("nLoadcells", value[0]);
|
|
setValue("distanceX1", value[1]);
|
|
setValue("distanceX2", value[2]);
|
|
setValue("distanceX3", value[3]);
|
|
setValue("refWeight", value[4]);
|
|
setValue("refCG", value[5]);
|
|
setValue("calFactorLoadcell1", value[6]);
|
|
setValue("calFactorLoadcell2", value[7]);
|
|
setValue("calFactorLoadcell3", value[8]);
|
|
setValue("resistorR1", value[9]);
|
|
setValue("resistorR2", value[10]);
|
|
setValue("batType", value[11]);
|
|
setValue("batCells", value[12]);
|
|
curSSID_STA = value[13];
|
|
setValue("ssid_STA", curSSID_STA);
|
|
setValue("password_STA", value[14]);
|
|
setValue("ssid_AP", value[15]);
|
|
setValue("password_AP", value[16]);
|
|
setValue("mechanicsType", value[23]);
|
|
if(value[24]=="1"){
|
|
document.getElementById("enableUpdate").checked = true;
|
|
}else{
|
|
document.getElementById("enableUpdate").checked = false;
|
|
}
|
|
if(value[25]=="1"){
|
|
document.getElementById("enableOTA").checked = true;
|
|
}else{
|
|
document.getElementById("enableOTA").checked = false;
|
|
}
|
|
if(value[0] == "2"){
|
|
CG_trans_visible = false;
|
|
document.getElementById("lc3Label").outerHTML = "";
|
|
}
|
|
if(value[11] == "0"){
|
|
batVolt_visible = false;
|
|
document.getElementById("batContainer").outerHTML = "";
|
|
}
|
|
return func;
|
|
}
|
|
}
|
|
}
|
|
request.open("GET", "getParameter", true);
|
|
request.send();
|
|
}
|
|
|
|
function getRawValue(){
|
|
var request = new XMLHttpRequest();
|
|
request.onreadystatechange = function(){
|
|
if(this.readyState == 4 && this.status == 200){
|
|
if(this.responseText != null){
|
|
var responseString = this.responseText;
|
|
var value = responseString.split("&");
|
|
document.getElementById("lc1").innerHTML = value[0];
|
|
document.getElementById("lc2").innerHTML = value[1];
|
|
if(CG_trans_visible == true){
|
|
document.getElementById("lc3").innerHTML = value[2];
|
|
}
|
|
if(batVolt_visible == true){
|
|
drawBattery(value[3]);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
request.open("GET", "getRawValue", true);
|
|
request.send();
|
|
setTimeout('getRawValue()', 1500);
|
|
}
|
|
|
|
function getWiFiNetworks(){
|
|
var request = new XMLHttpRequest();
|
|
request.onreadystatechange = function(){
|
|
if(this.readyState == 4 && this.status == 200){
|
|
if(this.responseText != null){
|
|
var responseString = this.responseText;
|
|
var value = responseString.split("&");
|
|
var select = document.getElementById('ssid_STA');
|
|
for (var i = 0; i<value.length; ++i){
|
|
var opt = document.createElement('option');
|
|
opt.text = value[i];
|
|
select.add(opt);
|
|
}
|
|
setValue("ssid_STA", curSSID_STA);
|
|
}
|
|
}
|
|
}
|
|
request.open("GET", "getWiFiNetworks", true);
|
|
request.send();
|
|
}
|
|
|
|
function saveParameter(func){
|
|
var data = "?";
|
|
data += "nLoadcells=" + document.getElementById("nLoadcells").value;
|
|
data += "&distanceX1=" + document.getElementById("distanceX1").value;
|
|
data += "&distanceX2=" + document.getElementById("distanceX2").value;
|
|
data += "&distanceX3=" + document.getElementById("distanceX3").value;
|
|
data += "&refWeight=" + document.getElementById("refWeight").value;
|
|
data += "&refCG=" + document.getElementById("refCG").value;
|
|
data += "&calFactorLoadcell1=" + document.getElementById("calFactorLoadcell1").value;
|
|
data += "&calFactorLoadcell2=" + document.getElementById("calFactorLoadcell2").value;
|
|
data += "&calFactorLoadcell3=" + document.getElementById("calFactorLoadcell3").value;
|
|
data += "&resistorR1=" + document.getElementById("resistorR1").value;
|
|
data += "&resistorR2=" + document.getElementById("resistorR2").value;
|
|
data += "&batType=" + document.getElementById("batType").value;
|
|
data += "&batCells=" + document.getElementById("batCells").value;
|
|
data += "&ssid_STA=" + encodeURIComponent(document.getElementById("ssid_STA").value);
|
|
data += "&password_STA=" + encodeURIComponent(document.getElementById("password_STA").value);
|
|
data += "&ssid_AP=" + encodeURIComponent(document.getElementById("ssid_AP").value);
|
|
data += "&password_AP=" + encodeURIComponent(document.getElementById("password_AP").value);
|
|
data += "&mechanicsType=" + document.getElementById("mechanicsType").value;
|
|
if(document.getElementById("enableUpdate").checked){
|
|
data += "&enableUpdate=1"
|
|
}else{
|
|
data += "&enableUpdate=0"
|
|
}
|
|
if(document.getElementById("enableOTA").checked){
|
|
data += "&enableOTA=1"
|
|
}else{
|
|
data += "&enableOTA=0"
|
|
}
|
|
var request = new XMLHttpRequest();
|
|
request.onreadystatechange = function(){
|
|
if(this.readyState == 4 && this.status == 200){
|
|
alert("Parameters saved");
|
|
getParameter(func);
|
|
}else if(this.readyState == 4 && this.status == 404){
|
|
alert("Save parameter failed !");
|
|
}
|
|
}
|
|
request.open("GET", "saveParameter" + data, true);
|
|
request.send();
|
|
}
|
|
|
|
function autoCalibrate(){
|
|
if (confirm("When ready, put the reference object on the scale.")){
|
|
var request = new XMLHttpRequest();
|
|
request.onreadystatechange = function(){
|
|
if(this.readyState == 4 && this.status == 200){
|
|
alert("Calibration successful");
|
|
getParameter();
|
|
}else if(this.readyState == 4 && this.status == 404){
|
|
alert("Calibration failed !");
|
|
}
|
|
}
|
|
request.open("GET", "autoCalibrate", true);
|
|
request.send();
|
|
}
|
|
}
|
|
|
|
function setValue(id, value)
|
|
{
|
|
var element = document.getElementById(id);
|
|
element.value = value;
|
|
}
|
|
|
|
function tare(){
|
|
document.getElementById("lc1").innerHTML = "TARE";
|
|
document.getElementById("lc2").innerHTML = "TARE";
|
|
if(CG_trans_visible == true){
|
|
document.getElementById("lc3").innerHTML = "TARE";
|
|
}
|
|
var request = new XMLHttpRequest();
|
|
request.onreadystatechange = function(){
|
|
if(this.readyState == 4 && this.status == 404){
|
|
alert("Tare failed !");
|
|
}
|
|
}
|
|
request.open("GET", "tare", true);
|
|
request.send();
|
|
}
|
|
|
|
function drawBattery(value){
|
|
document.getElementById("batValue").innerHTML = value;
|
|
|
|
var canvas = document.getElementById('batCanvas');
|
|
var ctx = canvas.getContext('2d');
|
|
ctx.clearRect(0,0,canvas.width, canvas.height);
|
|
|
|
// battery icon
|
|
var r = 5;
|
|
var l = 40;
|
|
var h = 20;
|
|
var bl = 3;
|
|
var bh = 3;
|
|
var ox = 2;
|
|
var oy = 2;
|
|
// battery fill
|
|
var fr = 2;
|
|
var fl = 34; //100%
|
|
var fh = 14;
|
|
var fx = 5;
|
|
var fy = 5;
|
|
|
|
var percentpos = value.indexOf('%');
|
|
if(percentpos != -1){
|
|
var percent = Number(value.substring(0, percentpos));
|
|
fl = fl/100*percent;
|
|
}else{
|
|
fl = 0;
|
|
}
|
|
|
|
// draw icon
|
|
ctx.beginPath();
|
|
ctx.lineWidth = 2;
|
|
ctx.moveTo(ox, oy+r);
|
|
ctx.arc(ox+r, oy+r, r, (Math.PI / 180) * 180, (Math.PI / 180) * 270, false);
|
|
ctx.lineTo(ox+(l-r), oy);
|
|
ctx.arc(ox+(l-r), oy+r, r, (Math.PI / 180) * 270, 0, false);
|
|
ctx.lineTo(ox+l, h/2-bh+oy);
|
|
ctx.lineTo(ox+l+bl, h/2-bh+oy);
|
|
ctx.lineTo(ox+l+bl, h/2+bh+oy);
|
|
ctx.lineTo(ox+l, h/2+bh+oy);
|
|
ctx.lineTo(ox+l, oy+h-r);
|
|
ctx.arc(ox+(l-r), oy+h-r, r, 0, (Math.PI / 180) * 90, false);
|
|
ctx.lineTo(ox+r, oy+h);
|
|
ctx.arc(ox+r, oy+h-r, r, (Math.PI / 180) * 90, (Math.PI / 180) * 180, false);
|
|
ctx.lineTo(ox, oy+r);
|
|
ctx.strokeStyle = "#FFFFFF";
|
|
ctx.stroke();
|
|
|
|
// draw filled value
|
|
if(fl>1){
|
|
ctx.beginPath();
|
|
ctx.fillStyle = "#FFFFFF";
|
|
ctx.moveTo(fx, fy+fr);
|
|
ctx.arc(fx+fr, fy+fr, fr, (Math.PI / 180) * 180, (Math.PI / 180) * 270, false);
|
|
ctx.lineTo(fx+(fl-fr), fy);
|
|
ctx.arc(fx+(fl-fr), fy+fr, fr, (Math.PI / 180) * 270, 0, false);
|
|
ctx.lineTo(fx+fl, fy+fh-fr);
|
|
ctx.arc(fx+(fl-fr), fy+fh-fr, fr, 0, (Math.PI / 180) * 90, false);
|
|
ctx.lineTo(fx+fr, fy+fh);
|
|
ctx.arc(fx+fr, fy+fh-fr, fr, (Math.PI / 180) * 90, (Math.PI / 180) * 180, false);
|
|
ctx.lineTo(fx, fy+fr);
|
|
ctx.fill();
|
|
}
|
|
}
|
|
|
|
function mobileNavbar() {
|
|
var x = document.getElementById("Navbar");
|
|
if (x.className === "navbar") {
|
|
x.className += " responsive";
|
|
} else {
|
|
x.className = "navbar";
|
|
}
|
|
}
|
|
</script>
|
|
</head>
|
|
<body>
|
|
<div class="navbar" id="Navbar">
|
|
<logo id="batContainer">
|
|
<canvas id="batCanvas" height="24" width="50" style="vertical-align:middle;"></canvas>
|
|
<span id="batValue" style="color:#FFFF; padding-right:20px; vertical-align:middle; font-size:17px;">-</span>
|
|
</logo>
|
|
<logo id="ssid" style="vertical-align:middle; font-size:32px;"></logo>
|
|
|
|
<a class="active" href="/settings.html"><img height="32px" src=""></a>
|
|
|
|
<a href="/models.html"><img height="32px" src=""></a>
|
|
|
|
<a href="/index.html"><img height="32px" src=""></a>
|
|
|
|
<a href="javascript:void(0);" class="icon" onclick="mobileNavbar()">
|
|
<img height="32px" src="">
|
|
</a>
|
|
</div>
|
|
|
|
<div>
|
|
<div class="titlebar">
|
|
<span style="color: #808080;" id="settingsLabel"></span>
|
|
</div>
|
|
<div class="buttonbar">
|
|
<button type="button" class="button saveButton" onclick="saveParameter()" id="saveBtn"></button>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="wrapper main_container">
|
|
<div class="tabs">
|
|
<div class="tab">
|
|
<input type="radio" name="css-tabs" id="tab-1" checked class="tab-switch">
|
|
<label for="tab-1" class="tab-label" id="tabGeneral"></label>
|
|
<div class="tab-content">
|
|
<h2 id="wifiHeading"></h2>
|
|
<div>
|
|
<big id="homeWifiSSID"></big>
|
|
<select id="ssid_STA">
|
|
</select>
|
|
<small id="homeWifiSSIDdesc"></small>
|
|
</div>
|
|
<div>
|
|
<big id="homeWifiPW"></big>
|
|
<input type="password" id="password_STA">
|
|
</div>
|
|
<div style="margin-top:50px;">
|
|
<big id="APwifiSSID"></big>
|
|
<input type="text" id="ssid_AP">
|
|
<small id="APwifiSSIDdesc"></small>
|
|
</div>
|
|
<div>
|
|
<big id="APwifiPW"></big>
|
|
<input type="password" id="password_AP">
|
|
<small id="APwifiPWdesc"></small>
|
|
</div>
|
|
<div style="margin-top:60px;">
|
|
<label style="vertical-align: middle; margin-right: 30px" class="switch">
|
|
<input id="enableUpdate" type="checkbox">
|
|
<span class="slider"></span>
|
|
</label>
|
|
<big id="checkUpdate"></big>
|
|
</div>
|
|
<div style="margin-top:20px;">
|
|
<label style="vertical-align: middle; margin-right: 30px" class="switch">
|
|
<input id="enableOTA" type="checkbox">
|
|
<span class="slider"></span>
|
|
</label>
|
|
<big id="enableOTAlabel"></big>
|
|
</div>
|
|
<h2 style="margin-top:100px;" id="modelDBheading"></h2>
|
|
<div style="margin-top:30px;">
|
|
<div>
|
|
<div>
|
|
<small id="modelDBdesc"></small>
|
|
</div>
|
|
<a href="/models.json" download="models.json">
|
|
<button type="button" class="button backupButton" id="backupBTN"></button>
|
|
</a>
|
|
<div style="margin-top:30px;">
|
|
<small id="backupDesc"></small>
|
|
<form method="post" enctype="multipart/form-data">
|
|
<div class="upload-btn-wrapper">
|
|
<button class="btn" id="file-upload-filename"></button>
|
|
<input type="file" name="myfile" id="file-upload"/>
|
|
</div>
|
|
<button type="submit" class="button uploadButton" id="uploadBTN"></button>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<script>
|
|
var input = document.getElementById( 'file-upload' );
|
|
var infoArea = document.getElementById( 'file-upload-filename' );
|
|
|
|
input.addEventListener( 'change', showFileName );
|
|
|
|
function showFileName( event ) {
|
|
var input = event.srcElement;
|
|
var fileName = input.files[0].name;
|
|
infoArea.textContent = fileName;
|
|
}
|
|
</script>
|
|
<h2 style="margin-top:100px;" id="updateHeading"></h2>
|
|
<div style="margin-top:20px;">
|
|
<small id="updateDesc"></small>
|
|
<div style="margin-top:20px;">
|
|
<button type="button" class="button updateButton" onclick="location.href='/update';" id="updateBTN"></button>
|
|
</div>
|
|
</div>
|
|
<h2 style="margin-top:100px;" id="aboutHeading"></h2>
|
|
<div style="margin-top:20px;">
|
|
<small id="aboutDesc"></small>
|
|
<div style="margin-top:20px;">
|
|
<button type="button" class="button donateButton" onclick="location.href='https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=R69PMKTCXQBUU&source=url';" id="donateBTN"></button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="tab">
|
|
<input type="radio" name="css-tabs" id="tab-2" class="tab-switch">
|
|
<label for="tab-2" class="tab-label" id="tabMechanics"></label>
|
|
<div class="tab-content">
|
|
<div>
|
|
<big id="mechanicsTypeHeading"></big>
|
|
<select id="mechanicsType">
|
|
<option value="0" id="mechanics0"></option>
|
|
<option value="1" id="mechanics1"></option>
|
|
<option value="2" id="mechanics2"></option>
|
|
<option value="3" id="mechanics3"></option>
|
|
</select>
|
|
</div>
|
|
<div>
|
|
<big id="nLoadcellsHeading"></big>
|
|
<select id="nLoadcells">
|
|
<option value="2">2</option>
|
|
<option value="3">3</option>
|
|
</select>
|
|
</div>
|
|
<div>
|
|
<big id="dist1label"></big>
|
|
<input type="text" id="distanceX1">
|
|
</div>
|
|
<div>
|
|
<big id="dist2label"></big>
|
|
<input type="text" id="distanceX2">
|
|
</div>
|
|
<div>
|
|
<big id="dist3label"></big>
|
|
<input type="text" id="distanceX3">
|
|
</div>
|
|
<div style="margin-top:30px;">
|
|
<small id="calHelpTxt"></small>
|
|
</div>
|
|
<div style="margin-top:30px;">
|
|
<big id="refWgLabel"></big>
|
|
<input type="text" id="refWeight">
|
|
</div>
|
|
<div>
|
|
<big id="refCGLabel"></big>
|
|
<input type="text" id="refCG">
|
|
</div>
|
|
<div style="margin-top:20px;">
|
|
<small id="autoCalDesc"></small>
|
|
</div>
|
|
<div style="margin-top:10px;">
|
|
<button type="button" class="button calButton" onclick="autoCalibrate()" id="autoCalBTN"></button>
|
|
</div>
|
|
<div style="margin-top:10px;">
|
|
<small id="lc1Label"></small><small id="lc1">-</small>
|
|
<small id="lc2Label"></small><small id="lc2">-</small>
|
|
<small id="lc3Label"></small><small id="lc3">-</small>
|
|
</div>
|
|
<div style="margin-top:10px;">
|
|
<button type="button" class="button tareButton" onclick="tare()" id="tareBtn"></button>
|
|
</div>
|
|
<div style="margin-top:50px;">
|
|
<big id="cal1Label"></big>
|
|
<input type="text" id="calFactorLoadcell1">
|
|
</div>
|
|
<div>
|
|
<big id="cal2Label"></big>
|
|
<input type="text" id="calFactorLoadcell2">
|
|
</div>
|
|
<div>
|
|
<big id="cal3Label"></big>
|
|
<input type="text" id="calFactorLoadcell3">
|
|
</div>
|
|
<div style="margin-top:50px; margin-left: 30px;">
|
|
<img style="max-width: 100%" src="CG_scale_mechanics.png">
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="tab">
|
|
<input type="radio" name="css-tabs" id="tab-3" class="tab-switch">
|
|
<label for="tab-3" class="tab-label" id="tabBattery"></label>
|
|
<div class="tab-content">
|
|
<div>
|
|
<big id="batteryTypeLabel"></big>
|
|
<select id="batType">
|
|
<option value="0" id="batT0"></option>
|
|
<option value="1" id="batT1"></option>
|
|
<option value="2">LiPo</option>
|
|
<option value="3">Li-ion</option>
|
|
<option value="4">LiFePo</option>
|
|
<option value="5">Nixx</option>
|
|
</select>
|
|
<small id="batteryTypeDesc"></small>
|
|
</div>
|
|
<div>
|
|
<big id="nBatCells"></big>
|
|
<input type="text" id="batCells">
|
|
</div>
|
|
<div>
|
|
<big id="R1label"></big>
|
|
<input type="text" id="resistorR1">
|
|
</div>
|
|
<div>
|
|
<big id="R2label"></big>
|
|
<input type="text" id="resistorR2">
|
|
</div>
|
|
<div style="margin-top:30px; margin-left: 30px;">
|
|
<img src="Resistor.png">
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div style="color:#808080; text-align:center; font-size:12px;">(c) 2020 M. Lehmann - Version: <span id="cgscaleVersion">--</span></div>
|
|
<script>
|
|
setTranslation("en");
|
|
getHead();
|
|
getParameter();
|
|
getWiFiNetworks();
|
|
getRawValue();
|
|
</script>
|
|
</body>
|
|
</html>
|