edit_config_param.html 38 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>Edit Config</title>
  5. <meta charset="utf-8">
  6. <style>
  7. h1 {font-size: 2em;}
  8. h2 {font-size: 1.5em; margin-block-start: 0.0em; margin-block-end: 0.2em;}
  9. h3 {font-size: 1.2em;}
  10. p {font-size: 1em;}
  11. .button {
  12. padding: 5px 20px;
  13. width: 211px;
  14. font-size: 16px;
  15. }
  16. textarea {
  17. font-size: 14px;
  18. }
  19. </style>
  20. </head>
  21. <body style="font-family: arial; padding: 0px 10px;">
  22. <table style="width:100%">
  23. <tr>
  24. <td>
  25. <h2>Config.ini:</h2>
  26. </td>
  27. <td>
  28. <button class="button" id="Edit_Config_Direct" onclick="editConfigDirect()" style="display:none">Edit Config.ini direct</button>
  29. <input type="checkbox" id="ExpertModus_enabled" value="1" onclick = 'UpdateExpertModus()' unchecked><label for="ExpertModus_enabled"> Expertenmodus </label>
  30. </td>
  31. </tr>
  32. </table>
  33. <br>
  34. <div id = "divall" style="display:none">
  35. <table>
  36. <tr>
  37. <th width="20px" style="text-align: left;">
  38. Enable
  39. </th>
  40. <th width="200px" style="text-align: left;">
  41. Parameter
  42. </th>
  43. <th style="text-align: left;">
  44. Value
  45. </th>
  46. <th style="text-align: left;">
  47. Information
  48. </th>
  49. </tr>
  50. <tr>
  51. <td colspan="4" style="padding-left: 20px;"><h4>MakeImage</h4></td>
  52. </tr>
  53. <tr>
  54. <td width="20px" style="padding-left: 40px;">
  55. <input type="checkbox" id="MakeImage_LogImageLocation_enabled" value="1" onclick = 'document.getElementById("MakeImage_LogImageLocation_value1").disabled = !document.getElementById("MakeImage_LogImageLocation_value1").disabled' unchecked >
  56. </td>
  57. <td width="200px">
  58. <class id="MakeImage_LogImageLocation_text" style="color:black;">LogImageLocation</class>
  59. </td>
  60. <td>
  61. <input type="text" name="name" id="MakeImage_LogImageLocation_value1">
  62. </td>
  63. <td style="font-size: 80%;">
  64. Location to store raw images for logging
  65. </td>
  66. </tr>
  67. <tr>
  68. <td width="20px" style="padding-left: 40px;">
  69. <td"><input type="checkbox" id="MakeImage_LogfileRetentionInDays_enabled" value="1" onclick = 'document.getElementById("MakeImage_LogfileRetentionInDays_value1").disabled = !document.getElementById("MakeImage_LogfileRetentionInDays_value1").disabled' unchecked ></td>
  70. </td>
  71. <td>
  72. <class id="MakeImage_LogfileRetentionInDays_text" style="color:black;">LogfileRetentionInDays</class>
  73. </td>
  74. <td>
  75. <input type="number" id="MakeImage_LogfileRetentionInDays_value1" size="13" min="0" step="1">
  76. </td>
  77. <td style="font-size: 80%;">
  78. Time to keep the raw image (in days -"0" = forever)
  79. </td>
  80. </tr>
  81. <tr class="expert" id="ex1">
  82. <td width="20px" style="padding-left: 40px;">
  83. </td>
  84. <td>
  85. <class id="MakeImage_WaitBeforeTakingPicture_text" style="color:black;">WaitBeforeTakingPicture</class>
  86. </td>
  87. <td>
  88. <input type="number" id="MakeImage_WaitBeforeTakingPicture_value1" size="13" min="0" step="any">
  89. </td>
  90. <td style="font-size: 80%;">
  91. Wait time between illumination switch on and take the picture (in seconds)
  92. </td>
  93. </tr>
  94. <tr class="expert" id="ex2">
  95. <td width="20px" style="padding-left: 40px;">
  96. </td>
  97. <td>
  98. <class id="MakeImage_ImageQuality_text" style="color:black;">ImageQuality</class>
  99. </td>
  100. <td>
  101. <input type="number" id="MakeImage_ImageQuality_value1" size="13" min="0" max="63">
  102. </td>
  103. <td style="font-size: 80%;">
  104. Quality index for picture (default = "5" - "0" high ... "63" low)
  105. </td>
  106. </tr>
  107. <tr class="expert" id="ex3">
  108. <td width="20px" style="padding-left: 40px;">
  109. </td>
  110. <td>
  111. <class id="MakeImage_ImageSize_text" style="color:black;">ImageSize</class>
  112. </td>
  113. <td>
  114. <select id="MakeImage_ImageSize_value1">
  115. <option value="0" selected>VGA</option>
  116. <option value="1" >QVGA</option>
  117. </select>
  118. </td>
  119. <td style="font-size: 80%;">
  120. Picture size camera (default = "VGA")
  121. </td>
  122. </tr>
  123. <tr class="expert" id="Brightness_ex3">
  124. <td width="20px" style="padding-left: 40px;">
  125. </td>
  126. <td>
  127. <class id="MakeImage_Brightness_text" style="color:black;">Brightness</class>
  128. </td>
  129. <td>
  130. <input type="number" id="MakeImage_Brightness_value1" size="13" min="-2" max="2">
  131. </td>
  132. <td style="font-size: 80%;">
  133. Image Brightness (-2 .. 2 - default = "0")
  134. </td>
  135. </tr>
  136. <tr class="expert" id="MakeImage_FixedExposure_ex10">
  137. <td width="20px" style="padding-left: 40px;">
  138. </td>
  139. <td width="200px">
  140. <class id="MakeImage_FixedExposure_text" style="color:black;">FixedExposure</class>
  141. </td>
  142. <td>
  143. <select id="MakeImage_FixedExposure_value1">
  144. <option value="0" selected>true</option>
  145. <option value="1" >false</option>
  146. </select>
  147. </td>
  148. <td style="font-size: 80%;">
  149. Fixes the illumination setting of camera at the startup and uses this later --> individual round is faster
  150. </td>
  151. </tr>
  152. <!--
  153. <tr class="expert" id="Contrast_ex3">
  154. <td width="20px" style="padding-left: 40px;">
  155. </td>
  156. <td>
  157. <class id="MakeImage_Contrast_text" style="color:black;">Contrast</class>
  158. </td>
  159. <td>
  160. <input type="number" id="MakeImage_Contrast_value1" size="13" min="-2" max="2">
  161. </td>
  162. <td style="font-size: 80%;">
  163. Image Contrast (-2 .. 2 - default = "0")
  164. </td>
  165. </tr>
  166. <tr class="expert" id="Saturation_ex3">
  167. <td width="20px" style="padding-left: 40px;">
  168. </td>
  169. <td>
  170. <class id="MakeImage_Saturation_text" style="color:black;">Saturation</class>
  171. </td>
  172. <td>
  173. <input type="number" id="MakeImage_Saturation_value1" size="13" min="-2" max="2">
  174. </td>
  175. <td style="font-size: 80%;">
  176. Image Saturation (-2 .. 2 - default = "0")
  177. </td>
  178. </tr>
  179. -->
  180. <tr class="expert" id="ex4">
  181. <td colspan="4" style="padding-left: 20px;"><h4>Alignment</h4></td>
  182. </tr>
  183. <tr class="expert" id="ex6">
  184. <td width="20px" style="padding-left: 40px;">
  185. </td>
  186. <td width="200px">
  187. <class id="Alignment_SearchFieldX_text" style="color:black;">SearchFieldX</class>
  188. </td>
  189. <td>
  190. <input type="number" name="name" id="Alignment_SearchFieldX_value1" size="13" min="1" step="1">
  191. </td>
  192. <td style="font-size: 80%;">
  193. x size (width) in which the reference is searched (default = "20")
  194. </td>
  195. </tr>
  196. <tr class="expert" id="ex8">
  197. <td width="20px" style="padding-left: 40px;">
  198. </td>
  199. <td>
  200. <class id="Alignment_SearchFieldY_text" style="color:black;">SearchFieldY</class>
  201. </td>
  202. <td>
  203. <input type="number" name="name" id="Alignment_SearchFieldY_value1" size="13" min="1">
  204. </td>
  205. <td style="font-size: 80%;">
  206. y size (height) in which the reference is searched (default = "20")
  207. </td>
  208. </tr>
  209. <tr class="expert" id="AlignmentAlgo_ex8">
  210. <td width="20px" style="padding-left: 40px;">
  211. <input type="checkbox" id="Alignment_AlignmentAlgo_enabled" value="1" onclick = 'document.getElementById("Alignment_AlignmentAlgo_value1").disabled = !document.getElementById("Alignment_AlignmentAlgo_value1").disabled' unchecked >
  212. </td>
  213. <td>
  214. <class id="Alignment_AlignmentAlgo_text" style="color:black;">AlignmentAlgo</class>
  215. </td>
  216. <td>
  217. <select id="Alignment_AlignmentAlgo_value1">
  218. <option value="0" selected>Default</option>
  219. <option value="1" >HighAccurity</option>
  220. <option value="2" >Fast</option>
  221. </select>
  222. </td>
  223. <td style="font-size: 80%;">
  224. "Default" = use only R-Channel, "HighAccurity" = use all Channels (RGB, 3x slower), <br> "Fast" (First time RGB, then only check if image is shifted)
  225. </td>
  226. </tr>
  227. <tr id="Category_Digits_ex4">
  228. <td colspan="4" style="padding-left: 20px;">
  229. <h4><input type="checkbox" id="Category_Digits_enabled" value="1" onclick = 'UpdateAfterCategoryCheck()' unchecked >Digits</h4></td>
  230. </tr>
  231. <tr>
  232. <td width="20px" style="padding-left: 40px;">
  233. </td>
  234. <td width="200px">
  235. <class id="Digits_Model_text" style="color:black;">Model</class>
  236. </td>
  237. <td>
  238. <input type="text" id="Digits_Model_value1">
  239. </td>
  240. <td style="font-size: 80%;">
  241. path to CNN model file for image recognition
  242. </td>
  243. </tr>
  244. <tr>
  245. <td width="20px" style="padding-left: 40px;">
  246. <input type="checkbox" id="Digits_LogImageLocation_enabled" value="1" onclick = 'document.getElementById("Digits_LogImageLocation_value1").disabled = !document.getElementById("Digits_LogImageLocation_value1").disabled' unchecked >
  247. </td>
  248. <td>
  249. <class id="Digits_LogImageLocation_text" style="color:black;">LogImageLocation</class>
  250. </td>
  251. <td>
  252. <input type="text" name="name" id="Digits_LogImageLocation_value1">
  253. </td>
  254. <td style="font-size: 80%;">
  255. Location to store separated digits for logging
  256. </td>
  257. </tr>
  258. <tr>
  259. <td width="20px" style="padding-left: 40px;">
  260. <td"><input type="checkbox" id="Digits_LogfileRetentionInDays_enabled" value="1" onclick = 'document.getElementById("Digits_LogfileRetentionInDays_value1").disabled = !document.getElementById("Digits_LogfileRetentionInDays_value1").disabled' unchecked ></td>
  261. </td>
  262. <td>
  263. <class id="Digits_LogfileRetentionInDays_text" style="color:black;">LogfileRetentionInDays</class>
  264. </td>
  265. <td>
  266. <input type="number" id="Digits_LogfileRetentionInDays_value1" min="0" step="1">
  267. </td>
  268. <td style="font-size: 80%;">
  269. Time to keep the separated digit images (in days -"0" = forever)
  270. </td>
  271. </tr>
  272. <tr class="expert" id="ex9">
  273. <td width="20px" style="padding-left: 40px;">
  274. </td>
  275. <td>
  276. <class id="Digits_ModelInputSize_text" style="color:black;">ModelInputSize</class>
  277. </td>
  278. <td>
  279. x: <input type="number" id="Digits_ModelInputSize_value1" style="width: 30px;" min="1" step="1">
  280. y: <input type="number" id="Digits_ModelInputSize_value2" style="width: 30px;" min="1" step="1">
  281. </td>
  282. <td style="font-size: 80%;">
  283. Size of the input image for the CNN model
  284. </td>
  285. </tr>
  286. <tr class="expert" id="ex4">
  287. <td colspan="4" style="padding-left: 20px;">
  288. <h4><input type="checkbox" id="Category_Analog_enabled" value="1" onclick = 'UpdateAfterCategoryCheck()' unchecked > Analog</h4></td>
  289. </tr>
  290. <tr>
  291. <td width="20px" style="padding-left: 40px;"> </td>
  292. <td width="200px"> <class id="Analog_Model_text" style="color:black;">Model</class> </td>
  293. <td> <input type="text" id="Analog_Model_value1"> </td>
  294. <td style="font-size: 80%;"> path to CNN model file for image recognition</td>
  295. </tr>
  296. <tr>
  297. <td width="20px" style="padding-left: 40px;">
  298. <input type="checkbox" id="Analog_LogImageLocation_enabled" value="1" onclick = 'document.getElementById("Analog_LogImageLocation_value1").disabled = !document.getElementById("Analog_LogImageLocation_value1").disabled' unchecked >
  299. </td>
  300. <td> <class id="Analog_LogImageLocation_text" style="color:black;">LogImageLocation</class> </td>
  301. <td> <input type="text" name="name" id="Analog_LogImageLocation_value1"> </td>
  302. <td style="font-size: 80%;"> Location to store separated digits for logging </td>
  303. </tr>
  304. <tr>
  305. <td width="20px" style="padding-left: 40px;">
  306. <td"><input type="checkbox" id="Analog_LogfileRetentionInDays_enabled" value="1" onclick = 'document.getElementById("Analog_LogfileRetentionInDays_value1").disabled = !document.getElementById("Analog_LogfileRetentionInDays_value1").disabled' unchecked ></td>
  307. </td>
  308. <td> <class id="Analog_LogfileRetentionInDays_text" style="color:black;">LogfileRetentionInDays</class> </td>
  309. <td> <input type="number" id="Analog_LogfileRetentionInDays_value1" min="0" step="1"> </td>
  310. <td style="font-size: 80%;"> Time to keep the separated digit images (in days -"0" = forever) </td>
  311. </tr>
  312. <tr class="expert" id="Analog_ExtendedResolution_ex10">
  313. <td width="20px" style="padding-left: 40px;">
  314. <input type="checkbox" id="Analog_ExtendedResolution_enabled" value="1" onclick = 'document.getElementById("Analog_ExtendedResolution_value1").disabled = !document.getElementById("Analog_ExtendedResolution_value1").disabled' unchecked >
  315. </td>
  316. <td width="200px">
  317. <class id="Analog_ExtendedResolution_text" style="color:black;">ExtendedResolution</class>
  318. </td>
  319. <td>
  320. <select id="Analog_ExtendedResolution_value1">
  321. <option value="0" selected>true</option>
  322. <option value="1" >false</option>
  323. </select>
  324. </td>
  325. <td style="font-size: 80%;">
  326. Enable to use the after point resolution for the last analog counter
  327. </td>
  328. </tr>
  329. ExtendedResolution
  330. <tr class="expert" id="ex10">
  331. <td width="20px" style="padding-left: 40px;"> </td>
  332. <td> <class id="Analog_ModelInputSize_text" style="color:black;">ModelInputSize</class> </td>
  333. <td>
  334. x: <input type="number" id="Analog_ModelInputSize_value1" style="width: 30px;" min="1" step="1">
  335. y: <input type="number" id="Analog_ModelInputSize_value2" style="width: 30px;" min="1" step="1">
  336. </td>
  337. <td style="font-size: 80%;"> Size of the input image for the CNN model </td>
  338. </tr>
  339. <tr>
  340. <td colspan="4" style="padding-left: 20px;"><h4>PostProcessing</h4></td>
  341. </tr>
  342. <tr>
  343. <td width="20px" style="padding-left: 40px;">
  344. <input type="checkbox" id="PostProcessing_DecimalShift_enabled" value="1" onclick = 'document.getElementById("PostProcessing_DecimalShift_value1").disabled = !document.getElementById("PostProcessing_DecimalShift_value1").disabled' unchecked >
  345. </td>
  346. <td width="200px">
  347. <class id="PostProcessing_DecimalShift_text" style="color:black;">DecimalShift</class>
  348. </td>
  349. <td>
  350. <input type="number" id="PostProcessing_DecimalShift_value1" step="1">
  351. </td>
  352. <td style="font-size: 80%;">
  353. shift the digit separator within the digital digits (positiv and negativ)
  354. </td>
  355. </tr>
  356. <tr>
  357. <td width="20px" style="padding-left: 40px;">
  358. <input type="checkbox" id="PostProcessing_PreValueUse_enabled" value="1" onclick = 'document.getElementById("PostProcessing_PreValueUse_value1").disabled = !document.getElementById("PostProcessing_PreValueUse_value1").disabled' unchecked >
  359. </td>
  360. <td width="200px">
  361. <class id="PostProcessing_PreValueUse_text" style="color:black;">PreValueUse</class>
  362. </td>
  363. <td>
  364. <select id="PostProcessing_PreValueUse_value1">
  365. <option value="0" selected>true</option>
  366. <option value="1" >false</option>
  367. </select>
  368. </td>
  369. <td style="font-size: 80%;">
  370. Enable to use the previous read value for consistency checks - also on reboots
  371. </td>
  372. </tr>
  373. <tr class="expert" id="ex11">
  374. <td width="20px" style="padding-left: 40px;">
  375. <input type="checkbox" id="PostProcessing_PreValueAgeStartup_enabled" value="1" onclick = 'document.getElementById("PostProcessing_PreValueAgeStartup_value1").disabled = !document.getElementById("PostProcessing_PreValueAgeStartup_value1").disabled' unchecked >
  376. </td>
  377. <td width="200px">
  378. <class id="PostProcessing_PreValueAgeStartup_text" style="color:black;">PreValueAgeStartup</class>
  379. </td>
  380. <td>
  381. <input type="number" id="PostProcessing_PreValueAgeStartup_value1" size="13" min="0">
  382. </td>
  383. <td style="font-size: 80%;">
  384. Time (in minutes), how long a previous read value is valid after reboot (default = 720 min)
  385. </td>
  386. </tr>
  387. <tr>
  388. <td width="20px" style="padding-left: 40px;">
  389. <input type="checkbox" id="PostProcessing_AllowNegativeRates_enabled" value="1" onclick = 'document.getElementById("PostProcessing_AllowNegativeRates_value1").disabled = !document.getElementById("PostProcessing_AllowNegativeRates_value1").disabled' unchecked >
  390. </td>
  391. <td width="200px">
  392. <class id="PostProcessing_AllowNegativeRates_text" style="color:black;">AllowNegativeRates</class>
  393. </td>
  394. <td>
  395. <select id="PostProcessing_AllowNegativeRates_value1">
  396. <option value="0" selected>true</option>
  397. <option value="1" >false</option>
  398. </select>
  399. </td>
  400. <td style="font-size: 80%;">
  401. Set on "false" to ensure, that only positive changes are accepted (typically for counter)
  402. </td>
  403. </tr>
  404. <tr>
  405. <td width="20px" style="padding-left: 40px;">
  406. <input type="checkbox" id="PostProcessing_MaxRateValue_enabled" value="1" onclick = 'document.getElementById("PostProcessing_MaxRateValue_value1").disabled = !document.getElementById("PostProcessing_MaxRateValue_value1").disabled' unchecked >
  407. </td>
  408. <td width="200px">
  409. <class id="PostProcessing_MaxRateValue_text" style="color:black;">MaxRateValue</class>
  410. </td>
  411. <td>
  412. <input type="number" id="PostProcessing_MaxRateValue_value1" size="13" min="0" step="any">
  413. </td>
  414. <td style="font-size: 80%;">
  415. Maximum change of reading from one to the next readout
  416. </td>
  417. </tr>
  418. <tr class="expert" id="ex12">
  419. <td width="20px" style="padding-left: 40px;">
  420. <input type="checkbox" id="PostProcessing_ErrorMessage_enabled" value="1" onclick = 'document.getElementById("PostProcessing_ErrorMessage_value1").disabled = !document.getElementById("PostProcessing_ErrorMessage_value1").disabled' unchecked >
  421. </td>
  422. <td width="200px">
  423. <class id="PostProcessing_ErrorMessage_text" style="color:black;">ErrorMessage</class>
  424. </td>
  425. <td>
  426. <select id="PostProcessing_ErrorMessage_value1">
  427. <option value="0" selected>true</option>
  428. <option value="1" >false</option>
  429. </select>
  430. </td>
  431. <td style="font-size: 80%;">
  432. Do not show error message in return value - in error case, the last valid number will be send out
  433. </td>
  434. </tr>
  435. <tr>
  436. <td width="20px" style="padding-left: 40px;">
  437. <input type="checkbox" id="PostProcessing_CheckDigitIncreaseConsistency_enabled" value="1" onclick = 'document.getElementById("PostProcessing_CheckDigitIncreaseConsistency_value1").disabled = !document.getElementById("PostProcessing_CheckDigitIncreaseConsistency_value1").disabled' unchecked >
  438. </td>
  439. <td width="200px">
  440. <class id="PostProcessing_CheckDigitIncreaseConsistency_text" style="color:black;">CheckDigitIncreaseConsistency</class>
  441. </td>
  442. <td>
  443. <select id="PostProcessing_CheckDigitIncreaseConsistency_value1">
  444. <option value="0" selected>true</option>
  445. <option value="1" >false</option>
  446. </select>
  447. </td>
  448. <td style="font-size: 80%;">
  449. Activate to enalbe additional consistency check - especially zero crossing check between digits
  450. </td>
  451. </tr>
  452. <tr>
  453. <td colspan="4" style="padding-left: 20px;"><h4><input type="checkbox" id="Category_MQTT_enabled" value="1" onclick = 'UpdateAfterCategoryCheck()' unchecked > MQTT</h4></td>
  454. </tr>
  455. <tr>
  456. <td width="20px" style="padding-left: 40px;">
  457. <input type="checkbox" id="MQTT_Uri_enabled" value="1" onclick = 'document.getElementById("MQTT_Uri_value1").disabled = !document.getElementById("MQTT_Uri_value1").disabled' unchecked >
  458. </td>
  459. <td width="200px">
  460. <class id="MQTT_Uri_text" style="color:black;">Uri</class>
  461. </td>
  462. <td>
  463. <input type="text" id="MQTT_Uri_value1">
  464. </td>
  465. <td style="font-size: 80%;">
  466. URI to the MQTT broker including port: http:\\IP-ADRESS:port
  467. </td>
  468. </tr>
  469. <tr>
  470. <td width="20px" style="padding-left: 40px;">
  471. <input type="checkbox" id="MQTT_Topic_enabled" value="1" onclick = 'document.getElementById("MQTT_Topic_value1").disabled = !document.getElementById("MQTT_Topic_value1").disabled' unchecked >
  472. </td>
  473. <td width="200px">
  474. <class id="MQTT_Topic_text" style="color:black;">Topic</class>
  475. </td>
  476. <td>
  477. <input type="text" id="MQTT_Topic_value1">
  478. </td>
  479. <td style="font-size: 80%;">
  480. MQTT topic, in which the value is registered
  481. </td>
  482. </tr>
  483. <tr>
  484. <td width="20px" style="padding-left: 40px;">
  485. <input type="checkbox" id="MQTT_TopicError_enabled" value="1" onclick = 'document.getElementById("MQTT_TopicError_value1").disabled = !document.getElementById("MQTT_TopicError_value1").disabled' unchecked >
  486. </td>
  487. <td width="200px">
  488. <class id="MQTT_TopicError_text" style="color:black;">TopicError</class>
  489. </td>
  490. <td>
  491. <input type="text" id="MQTT_TopicError_value1">
  492. </td>
  493. <td style="font-size: 80%;">
  494. MQTT topic, in which the error status is reported (empty = no error)
  495. </td>
  496. </tr>
  497. <tr>
  498. <td width="20px" style="padding-left: 40px;">
  499. <input type="checkbox" id="MQTT_ClientID_enabled" value="1" onclick = 'document.getElementById("MQTT_ClientID_value1").disabled = !document.getElementById("MQTT_ClientID_value1").disabled' unchecked >
  500. </td>
  501. <td width="200px">
  502. <class id="MQTT_ClientID_text" style="color:black;">ClientID</class>
  503. </td>
  504. <td>
  505. <input type="text" id="MQTT_ClientID_value1">
  506. </td>
  507. <td style="font-size: 80%;">
  508. ClientID to connect to the MQTT broker
  509. </td>
  510. </tr>
  511. <tr>
  512. <td width="20px" style="padding-left: 40px;">
  513. <input type="checkbox" id="MQTT_user_enabled" value="1" onclick = 'document.getElementById("MQTT_user_value1").disabled = !document.getElementById("MQTT_user_value1").disabled' unchecked >
  514. </td>
  515. <td width="200px">
  516. <class id="MQTT_user_text" style="color:black;">user</class>
  517. </td>
  518. <td>
  519. <input type="text" id="MQTT_user_value1">
  520. </td>
  521. <td style="font-size: 80%;">
  522. user for MQTT authenficiation
  523. </td>
  524. </tr>
  525. <tr>
  526. <td width="20px" style="padding-left: 40px;">
  527. <input type="checkbox" id="MQTT_password_enabled" value="1" onclick = 'document.getElementById("MQTT_password_value1").disabled = !document.getElementById("MQTT_password_value1").disabled' unchecked >
  528. </td>
  529. <td width="200px">
  530. <class id="MQTT_password_text" style="color:black;">password</class>
  531. </td>
  532. <td>
  533. <input type="text" id="MQTT_password_value1">
  534. </td>
  535. <td style="font-size: 80%;">
  536. password for MQTT authenficiation
  537. </td>
  538. </tr>
  539. <tr>
  540. <td colspan="4" style="padding-left: 20px;"><h4>AutoTimer</h4></td>
  541. </tr>
  542. <tr class="expert" id="ex13">
  543. <td width="20px" style="padding-left: 40px;">
  544. <input type="checkbox" id="AutoTimer_AutoStart_enabled" value="1" onclick = 'document.getElementById("AutoTimer_AutoStart_value1").disabled = !document.getElementById("AutoTimer_AutoStart_value1").disabled' unchecked >
  545. </td>
  546. <td width="200px">
  547. <class id="AutoTimer_AutoStart_text" style="color:black;">AutoStart</class>
  548. </td>
  549. <td>
  550. <select id="AutoTimer_AutoStart_value1">
  551. <option value="0" selected>true</option>
  552. <option value="1" >false</option>
  553. </select>
  554. </td>
  555. <td style="font-size: 80%;">
  556. Start the image recognition immediatly after power up. false is basically for debugging.
  557. </td>
  558. </tr>
  559. <tr>
  560. <td width="20px" style="padding-left: 40px;">
  561. <input type="checkbox" id="AutoTimer_Intervall_enabled" value="1" onclick = 'document.getElementById("AutoTimer_Intervall_value1").disabled = !document.getElementById("AutoTimerg_Intervall_value1").disabled' unchecked >
  562. </td>
  563. <td width="200px">
  564. <class id="AutoTimer_Intervall_text" style="color:black;">Intervall</class>
  565. </td>
  566. <td>
  567. <input type="number" id="AutoTimer_Intervall_value1" size="13" min="3" step="any">
  568. </td>
  569. <td style="font-size: 80%;">
  570. Intervall in which the counter is read (in minutes). Number must be greater than 3 minutes.
  571. </td>
  572. </tr>
  573. <tr>
  574. <td colspan="4" style="padding-left: 20px;"><h4>Debug</h4></td>
  575. </tr>
  576. <tr>
  577. <td width="20px" style="padding-left: 40px;">
  578. <input type="checkbox" id="Debug_Logfile_enabled" value="1" onclick = 'document.getElementById("Debug_Logfile_value1").disabled = !document.getElementById("Debug_Logfile_value1").disabled' unchecked >
  579. </td>
  580. <td width="200px">
  581. <class id="Debug_Logfile_text" style="color:black;">Logfile</class>
  582. </td>
  583. <td>
  584. <select id="Debug_Logfile_value1">
  585. <option value="0" selected>true</option>
  586. <option value="1" >false</option>
  587. </select>
  588. </td>
  589. <td style="font-size: 80%;">
  590. Turn on/off the extended logging
  591. </td>
  592. </tr>
  593. <tr>
  594. <td width="20px" style="padding-left: 40px;">
  595. <td"><input type="checkbox" id="Debug_LogfileRetentionInDays_enabled" value="1" onclick = 'document.getElementById("Debug_LogfileRetentionInDays_value1").disabled = !document.getElementById("Debug_LogfileRetentionInDays_value1").disabled' unchecked ></td>
  596. </td>
  597. <td>
  598. <class id="Debug_LogfileRetentionInDays_text" style="color:black;">LogfileRetentionInDays</class>
  599. </td>
  600. <td>
  601. <input type="number" id="Debug_LogfileRetentionInDays_value1" size="13" min="0" step="1">
  602. </td>
  603. <td style="font-size: 80%;">
  604. Time to keep the log files (in days - "0" = forever)
  605. </td>
  606. </tr>
  607. <tr>
  608. <td colspan="4" style="padding-left: 20px;"><h4>System</h4></td>
  609. </tr>
  610. <tr>
  611. <td width="20px" style="padding-left: 40px;">
  612. <td"><input type="checkbox" id="System_TimeZone_enabled" value="1" onclick = 'document.getElementById("System_TimeZone_value1").disabled = !document.getElementById("System_TimeZone_value1").disabled' unchecked ></td>
  613. </td>
  614. <td>
  615. <class id="System_TimeZone_text" style="color:black;">TimeZone</class>
  616. </td>
  617. <td>
  618. <input type="text" id="System_TimeZone_value1">
  619. </td>
  620. <td style="font-size: 80%;">
  621. Time zone in POSIX syntax (Europe/Berlin = "CET-1CEST,M3.5.0,M10.5.0/3" - incl. daylight saving)
  622. </td>
  623. </tr>
  624. <tr class="expert" id="ex16">
  625. <td width="20px" style="padding-left: 40px;">
  626. <td"><input type="checkbox" id="System_TimeServer_enabled" value="1" onclick = 'document.getElementById("System_TimeServer_value1").disabled = !document.getElementById("System_TimeServer_value1").disabled' unchecked ></td>
  627. </td>
  628. <td>
  629. <class id="System_TimeServer_text" style="color:black;">TimeServer</class>
  630. </td>
  631. <td>
  632. <input type="text" id="System_TimeServer_value1">
  633. </td>
  634. <td style="font-size: 80%;">
  635. Time server to synchronize system time (default: "pool.ntp.org" - used if nothing is specified)
  636. </td>
  637. </tr>
  638. <tr class="expert" id="System_Hostname">
  639. <td width="20px" style="padding-left: 40px;">
  640. <td"><input type="checkbox" id="System_Hostname_enabled" value="1" onclick = 'document.getElementById("System_Hostname_value1").disabled = !document.getElementById("System_Hostname_value1").disabled' unchecked ></td>
  641. </td>
  642. <td>
  643. <class id="System_Hostname_text" style="color:black;">Hostname</class>
  644. </td>
  645. <td>
  646. <input type="text" id="System_Hostname_value1">
  647. </td>
  648. <td style="font-size: 80%;">
  649. Hostname for server - will be transfered to wlan.ini at next startup)
  650. </td>
  651. </tr>
  652. </table>
  653. <p>
  654. <button class="button" onclick="saveTextAsFile()">Update Config.ini</button>
  655. </p>
  656. <p>
  657. </p>
  658. <p>
  659. <button class="button" id="reboot" type="button" onclick="doReboot()">Reboot to activate updates</button>
  660. </p>
  661. </div>
  662. <script type="text/javascript" src="./gethost.js"></script>
  663. <script type="text/javascript" src="./readconfigcommon.js"></script>
  664. <script type="text/javascript" src="./readconfigparam.js"></script>
  665. <script type="text/javascript">
  666. var canvas = document.getElementById('canvas'),
  667. basepath = "http://192.168.178.22";
  668. param;
  669. category;
  670. function LoadConfigNeu() {
  671. basepath = getbasepath();
  672. if (!loadConfig(basepath)) {
  673. alert("Config.ini could not be loaded!\nPlease reload the page.");
  674. return;
  675. }
  676. loadConfig(basepath);
  677. ParseConfig();
  678. param = getConfigParameters();
  679. category = getConfigCategory();
  680. UpdateInput();
  681. UpdateExpertModus();
  682. document.getElementById("divall").style.display = '';
  683. }
  684. function WriteParameter(_param, _category, _cat, _name, _optional, _select = false, _anzpara = 1){
  685. if (_param[_cat][_name]["found"]){
  686. if (_optional) {
  687. document.getElementById(_cat+"_"+_name+"_enabled").checked = _param[_cat][_name]["enabled"];
  688. for (var j = 1; j <= _anzpara; ++j) {
  689. document.getElementById(_cat+"_"+_name+"_value"+j).disabled = !_param[_cat][_name]["enabled"];
  690. }
  691. }
  692. document.getElementById(_cat+"_"+_name+"_text").style="color:black;"
  693. if (_select) {
  694. var textToFind = _param[_cat][_name]["value1"];
  695. var dd = document.getElementById(_cat+"_"+_name+"_value1");
  696. for (var i = 0; i < dd.options.length; i++) {
  697. if (dd.options[i].text.toLowerCase() === textToFind.toLowerCase()) {
  698. dd.selectedIndex = i;
  699. break;
  700. }
  701. }
  702. }
  703. else {
  704. for (var j = 1; j <= _anzpara; ++j) {
  705. document.getElementById(_cat+"_"+_name+"_value"+j).value = _param[_cat][_name]["value"+j];
  706. }
  707. }
  708. }
  709. else {
  710. if (_optional) {
  711. document.getElementById(_cat+"_"+_name+"_enabled").disabled = true;
  712. for (var j = 1; j <= _anzpara; ++j) {
  713. document.getElementById(_cat+"_"+_name+"_value"+j).disabled = true;
  714. }
  715. }
  716. document.getElementById(_cat+"_"+_name+"_text").style="color:lightgrey;"
  717. }
  718. ///////////////// am Ende, falls Kategorie als gesamtes nicht ausgewählt --> deaktivieren
  719. if (_category[_cat]["enabled"] == false)
  720. {
  721. if (_optional) {
  722. document.getElementById(_cat+"_"+_name+"_enabled").disabled = true;
  723. for (var j = 1; j <= _anzpara; ++j) {
  724. document.getElementById(_cat+"_"+_name+"_value"+j).disabled = true;
  725. }
  726. }
  727. document.getElementById(_cat+"_"+_name+"_text").style="color:lightgrey;"
  728. }
  729. EnDisableItem(_category[_cat]["enabled"], _param, _category, _cat, _name, _optional);
  730. }
  731. function EnDisableItem(_status, _param, _category, _cat, _name, _optional)
  732. {
  733. _status = _param[_cat][_name]["found"] && _category[_cat]["enabled"];
  734. _color = "color:lightgrey;";
  735. if (_status) {
  736. _color = "color:black;";
  737. }
  738. if (_optional) {
  739. document.getElementById(_cat+"_"+_name+"_enabled").disabled = !_status;
  740. document.getElementById(_cat+"_"+_name+"_enabled").style=_color;
  741. }
  742. if (!_param[_cat][_name]["enabled"]) {
  743. _status = false;
  744. _color = "color:lightgrey;";
  745. }
  746. document.getElementById(_cat+"_"+_name+"_text").disabled = !_status;
  747. document.getElementById(_cat+"_"+_name+"_text").style = _color;
  748. if (_param[_cat][_name]["anzParam"] == 2) {
  749. _color = "width: 30px;" + _color;
  750. }
  751. for (var j = 1; j <= _param[_cat][_name]["anzParam"]; ++j) {
  752. document.getElementById(_cat+"_"+_name+"_value"+j).disabled = !_status;
  753. document.getElementById(_cat+"_"+_name+"_value"+j).style=_color;
  754. }
  755. }
  756. function ReadParameter(_param, _cat, _name, _optional, _select = false){
  757. if (_param[_cat][_name]["found"]){
  758. if (_optional) {
  759. _param[_cat][_name]["enabled"] = document.getElementById(_cat+"_"+_name+"_enabled").checked;
  760. }
  761. if (_select) {
  762. var sel = document.getElementById(_cat+"_"+_name+"_value1");
  763. _param[_cat][_name]["value1"] = sel.options[sel.selectedIndex].text;
  764. }
  765. else {
  766. for (var j = 1; j <= _param[_cat][_name]["anzParam"]; ++j) {
  767. _param[_cat][_name]["value"+j] = document.getElementById(_cat+"_"+_name+"_value"+j).value;
  768. }
  769. }
  770. }
  771. }
  772. function UpdateInput() {
  773. document.getElementById("Category_Analog_enabled").checked = category["Analog"]["enabled"];
  774. document.getElementById("Category_Digits_enabled").checked = category["Digits"]["enabled"];
  775. document.getElementById("Category_MQTT_enabled").checked = category["MQTT"]["enabled"];
  776. WriteParameter(param, category, "MakeImage", "LogImageLocation", true);
  777. WriteParameter(param, category, "MakeImage", "LogfileRetentionInDays", true);
  778. WriteParameter(param, category, "MakeImage", "WaitBeforeTakingPicture", false);
  779. WriteParameter(param, category, "MakeImage", "ImageQuality", false);
  780. WriteParameter(param, category, "MakeImage", "Brightness", false);
  781. // WriteParameter(param, category, "MakeImage", "Contrast", false);
  782. // WriteParameter(param, category, "MakeImage", "Saturation", false);
  783. WriteParameter(param, category, "MakeImage", "ImageSize", false, true, true);
  784. WriteParameter(param, category, "MakeImage", "FixedExposure", false, true, true);
  785. WriteParameter(param, category, "Alignment", "SearchFieldX", false);
  786. WriteParameter(param, category, "Alignment", "SearchFieldY", false);
  787. WriteParameter(param, category, "Alignment", "AlignmentAlgo", true, true, true);
  788. WriteParameter(param, category, "Digits", "Model", false);
  789. WriteParameter(param, category, "Digits", "LogImageLocation", true);
  790. WriteParameter(param, category, "Digits", "LogfileRetentionInDays", true);
  791. WriteParameter(param, category, "Digits", "ModelInputSize", false, false, 2);
  792. WriteParameter(param, category, "Analog", "Model", false);
  793. WriteParameter(param, category, "Analog", "LogImageLocation", true);
  794. WriteParameter(param, category, "Analog", "LogfileRetentionInDays", true);
  795. WriteParameter(param, category, "Analog", "ExtendedResolution", true, true);
  796. WriteParameter(param, category, "Analog", "ModelInputSize", false, false, 2);
  797. WriteParameter(param, category, "PostProcessing", "DecimalShift", true);
  798. WriteParameter(param, category, "PostProcessing", "PreValueUse", true, true);
  799. WriteParameter(param, category, "PostProcessing", "PreValueAgeStartup", true);
  800. WriteParameter(param, category, "PostProcessing", "AllowNegativeRates", true, true);
  801. WriteParameter(param, category, "PostProcessing", "MaxRateValue", true);
  802. WriteParameter(param, category, "PostProcessing", "ErrorMessage", true, true);
  803. WriteParameter(param, category, "PostProcessing", "CheckDigitIncreaseConsistency", true, true);
  804. WriteParameter(param, category, "MQTT", "Uri", true);
  805. WriteParameter(param, category, "MQTT", "Topic", true);
  806. WriteParameter(param, category, "MQTT", "TopicError", true);
  807. WriteParameter(param, category, "MQTT", "ClientID", true);
  808. WriteParameter(param, category, "MQTT", "user", true);
  809. WriteParameter(param, category, "MQTT", "password", true);
  810. WriteParameter(param, category, "AutoTimer", "AutoStart", true, true);
  811. WriteParameter(param, category, "AutoTimer", "Intervall", true);
  812. WriteParameter(param, category, "Debug", "Logfile", true, true);
  813. WriteParameter(param, category, "Debug", "LogfileRetentionInDays", true);
  814. WriteParameter(param, category, "System", "TimeZone", true);
  815. WriteParameter(param, category, "System", "Hostname", true);
  816. WriteParameter(param, category, "System", "TimeServer", true);
  817. }
  818. function ReadParameterAll()
  819. {
  820. category["Analog"]["enabled"] = document.getElementById("Category_Analog_enabled").checked;
  821. category["Digits"]["enabled"] = document.getElementById("Category_Digits_enabled").checked;
  822. category["MQTT"]["enabled"] = document.getElementById("Category_MQTT_enabled").checked;
  823. ReadParameter(param, "MakeImage", "LogImageLocation", true);
  824. ReadParameter(param, "MakeImage", "LogfileRetentionInDays", true);
  825. ReadParameter(param, "MakeImage", "WaitBeforeTakingPicture", false);
  826. ReadParameter(param, "MakeImage", "ImageQuality", false);
  827. ReadParameter(param, "MakeImage", "Brightness", false);
  828. // ReadParameter(param, "MakeImage", "Contrast", false);
  829. // ReadParameter(param, "MakeImage", "Saturation", false);
  830. ReadParameter(param, "MakeImage", "ImageSize", false, true);
  831. ReadParameter(param, "MakeImage", "FixedExposure", false, true);
  832. ReadParameter(param, "Alignment", "SearchFieldX", false);
  833. ReadParameter(param, "Alignment", "SearchFieldY", false);
  834. ReadParameter(param, "Alignment", "AlignmentAlgo", true, true);
  835. ReadParameter(param, "Digits", "Model", false);
  836. ReadParameter(param, "Digits", "LogImageLocation", true);
  837. ReadParameter(param, "Digits", "LogfileRetentionInDays", true);
  838. ReadParameter(param, "Digits", "ModelInputSize", false, false, 2);
  839. ReadParameter(param, "Analog", "Model", false);
  840. ReadParameter(param, "Analog", "LogImageLocation", true);
  841. ReadParameter(param, "Analog", "LogfileRetentionInDays", true);
  842. ReadParameter(param, "Analog", "ExtendedResolution", true, true);
  843. ReadParameter(param, "Analog", "ModelInputSize", false, false, 2);
  844. ReadParameter(param, "PostProcessing", "DecimalShift", true);
  845. ReadParameter(param, "PostProcessing", "PreValueUse", true, true);
  846. ReadParameter(param, "PostProcessing", "PreValueAgeStartup", true);
  847. ReadParameter(param, "PostProcessing", "AllowNegativeRates", true, true);
  848. ReadParameter(param, "PostProcessing", "MaxRateValue", true);
  849. ReadParameter(param, "PostProcessing", "ErrorMessage", true, true);
  850. ReadParameter(param, "PostProcessing", "CheckDigitIncreaseConsistency", true, true);
  851. ReadParameter(param, "MQTT", "Uri", true);
  852. ReadParameter(param, "MQTT", "Topic", true);
  853. ReadParameter(param, "MQTT", "TopicError", true);
  854. ReadParameter(param, "MQTT", "ClientID", true);
  855. ReadParameter(param, "MQTT", "user", true);
  856. ReadParameter(param, "MQTT", "password", true);
  857. ReadParameter(param, "AutoTimer", "AutoStart", true, true);
  858. ReadParameter(param, "AutoTimer", "Intervall", true);
  859. ReadParameter(param, "Debug", "Logfile", true, true);
  860. ReadParameter(param, "Debug", "LogfileRetentionInDays", true);
  861. ReadParameter(param, "System", "TimeZone", true);
  862. ReadParameter(param, "System", "Hostname", true);
  863. ReadParameter(param, "System", "TimeServer", true);
  864. FormatDecimalValue(param, "PostProcessing", "MaxRateValue");
  865. }
  866. function WriteConfig(){
  867. ReadParameterAll();
  868. return setConfigParameters(param, category);
  869. }
  870. function FormatDecimalValue(_param, _cat, _name) {
  871. for (var j = 1; j <= _param[_cat][_name]["anzParam"]; ++j) {
  872. var _val = _param[_cat][_name]["value"+j];
  873. _val = _val.replace(",", ".");
  874. _param[_cat][_name]["value"+j] = _val;
  875. }
  876. }
  877. function UpdateAfterCategoryCheck() {
  878. ReadParameterAll();
  879. category["Analog"]["enabled"] = document.getElementById("Category_Analog_enabled").checked;
  880. category["Digits"]["enabled"] = document.getElementById("Category_Digits_enabled").checked;
  881. UpdateInput();
  882. }
  883. function UpdateExpertModus()
  884. {
  885. var _style = 'display:none;';
  886. if (document.getElementById("ExpertModus_enabled").checked) {
  887. _style = '';
  888. document.getElementById("Edit_Config_Direct").style.display = "";
  889. }
  890. else
  891. {
  892. document.getElementById("Edit_Config_Direct").style.display = "none";
  893. }
  894. const expert = document.querySelectorAll(".expert");
  895. for (var i = 0; i < expert.length; i++) {
  896. document.getElementById(expert[i].id).style = _style;
  897. }
  898. }
  899. function saveTextAsFile()
  900. {
  901. if (confirm("Are you sure you want to update \"config.ini\"?")) {
  902. var textToSave = WriteConfig();
  903. FileDeleteOnServer("/config/config.ini", basepath);
  904. FileSendContent(textToSave, "/config/config.ini", basepath);
  905. }
  906. }
  907. function doReboot() {
  908. if (confirm("Are you sure you want to reboot the ESP32?")) {
  909. var stringota = "/reboot";
  910. window.location = stringota;
  911. window.location.href = stringota;
  912. window.location.assign(stringota);
  913. window.location.replace(stringota);
  914. }
  915. }
  916. function editConfigDirect() {
  917. if (confirm("Did you save your changes?")) {
  918. var stringota = "/edit_config.html";
  919. window.location = stringota;
  920. window.location.href = stringota;
  921. window.location.assign(stringota);
  922. window.location.replace(stringota);
  923. }
  924. }
  925. LoadConfigNeu();
  926. </script>
  927. </body>
  928. </html>