NEWS
E-INK Display OpenEPaperLink - Displayanzeige mit Batterie
-
Das das mit Javascript zusammen hängt hatte ich auch schon gedacht. Die Bildchen werden ja schließlich immer sehr schnell erstellt.
-
War ein Fehler.
-
Läuft das Puppeteer script eigentlich noch?
Bei mir kommt folgender fehler:
javascript.0 21:47:14.718 warn script.js.common.TestScripte.epaperTEST_1: request package is deprecated - please use httpGet (or a stable lib like axios) instead! javascript.0 21:47:14.721 error at Object.<anonymous> (script.js.common.TestScripte.epaperTEST_1:42:13)
-
@webranger sagte in E-INK Display OpenEPaperLink - Displayanzeige mit Batterie:
Läuft das Puppeteer script eigentlich noch?
Bei mir kommt folgender fehler:
javascript.0 21:47:14.718 warn script.js.common.TestScripte.epaperTEST_1: request package is deprecated - please use httpGet (or a stable lib like axios) instead! javascript.0 21:47:14.721 error at Object.<anonymous> (script.js.common.TestScripte.epaperTEST_1:42:13)
Na ja, das mit dem httpGet ist aber schon etwas älter.
Nimm dieses hier.
Das funktioniert. Es gibt aber im Moment wohl kleine Probleme mit Javascript.
Siehe
-
Mal was ganz anderes. Ich habe hier ein ST-GR 29000 Display was sich alle paar Stunden (1 mal in 24 Stunden, unregelmäßige Zeit) verabschiedet.
Standort kann es nicht sein. Nimm ich kurz die Batterien raus läuft es auch wieder.
Der Inhalt wird mit einem JSON beschickt.
Ist das einfach kaputt oder noch ne andere Idee? -
@emd said in E-INK Display OpenEPaperLink - Displayanzeige mit Batterie:
Ich bedanke mich bei euch allen und vorallem bei @BananaJoe !
Ich weiß nicht warum, aber es geht nun, habe in der zwischenzeit gefühlt 1000 Sachen geändert und mit einmal geht es.
Keine Ahnung wo da der Fehler lag...MfG
eMdLäuft dein script noch? Ich habe auch das Bild im /tmp/ Ordner vom iobroker und einen Code 200 aber irgendwie zeigt er mir im AP Temp nichts an.
Log vom AP bleibt leider leer@all Kann ich das Bild nicht auch irgendwo speichern wo sich der Tag das abholen kann?
-
Bin mir nicht sicher ob das zur Fehlersuche beiträgt, aber wenn ich in VIS etwas ändere, erscheinen die von mir beschriebenen Fehlermeldungen.
Wenn ich den Javaskript und den Puppeteer Adapter NACH den Änderungen neu starte, kommen die Meldungen so wie es schein nicht mehr.
-
@beowolf Eventuell hängt es mit dem Widget auf das das Skript wartet zusammen? Sollte es das nach einer Änderung nicht mehr geben, wäre das ein Grund.
-
Ich bin jetzt aber auch dazu übergegangen, das ich die TAGs die nur einfache Werte von z.B. HM-Heizungsventilen anzeigen, mit diesem Blockly zu versorgen.
<xml xmlns="https://developers.google.com/blockly/xml"> <variables> <variable id="e.-?J1RG(1E03apliOsd">url</variable> <variable id="eMqV!m8?ZCdqN2].w`xb">TagMini1</variable> <variable id="*)}|9mHpKcV3YN}|a_t5">jsonMini1</variable> </variables> <block type="procedures_defcustomreturn" id="Q)=N/g,e;;C$aa#GZ/g6" x="738" y="388"> <mutation statements="false"> <arg name="url" varid="e.-?J1RG(1E03apliOsd"></arg> </mutation> <field name="NAME">encodeURL</field> <field name="SCRIPT">dXJsID0gZW5jb2RlVVJJQ29tcG9uZW50KHVybCk7DQpyZXR1cm4gdXJsOw==</field> <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment> </block> <block type="on_ext" id="P$af/8byEUS#qCA]5B-P" x="738" y="413"> <mutation xmlns="http://www.w3.org/1999/xhtml" items="4"></mutation> <field name="CONDITION">ne</field> <field name="ACK_CONDITION"></field> <value name="OID0"> <shadow type="field_oid" id="qKgG$O[{3RUIQEMyX@84"> <field name="oid">hm-rpc.0.NEQ1405541.4.ACTUAL_TEMPERATURE</field> </shadow> </value> <value name="OID1"> <shadow type="field_oid" id="1=$zeB_8NZ{``1IKhA@;"> <field name="oid">hm-rpc.0.NEQ1405541.4.SET_TEMPERATURE</field> </shadow> </value> <value name="OID2"> <shadow type="field_oid" id="3xv_){1%Z-Px_oc=|ee]"> <field name="oid">hm-rpc.0.NEQ1405541.4.VALVE_STATE</field> </shadow> </value> <value name="OID3"> <shadow type="field_oid" id="1%z%;+tP3g0pYuG^87_*"> <field name="oid">hm-rpc.0.NEQ1405541.4.BATTERY_STATE</field> </shadow> </value> <statement name="STATEMENT"> <block type="variables_set" id="}kvQ}B#.rViPjfKc-HTi"> <field name="VAR" id="eMqV!m8?ZCdqN2].w`xb">TagMini1</field> <value name="VALUE"> <block type="text" id="AS0{YNAIOlM%S|LO,c(?"> <field name="TEXT">00007E1BDCCFB291</field> </block> </value> <next> <block type="variables_set" id="k02GjbFfyHgTN`gcO-Da"> <field name="VAR" id="*)}|9mHpKcV3YN}|a_t5">jsonMini1</field> <value name="VALUE"> <block type="procedures_callcustomreturn" id="m+$OB%}5|)Pwa;Sp_8Xz"> <mutation name="encodeURL"> <arg name="url"></arg> </mutation> <value name="ARG0"> <block type="text_join" id="%7M,-4ru#q{/k6KDWMHm"> <mutation items="11"></mutation> <value name="ADD0"> <block type="text" id="KG:U*zHU9}`ZAfY=W0tK"> <field name="TEXT">[ {"text": [10,10,"Hauswirtschaftsraum","fonts/bahnschrift30",2]},</field> </block> </value> <value name="ADD1"> <block type="text" id="J8kE(`F|;UG(UnXYIXH/"> <field name="TEXT">{"line": [10,35,374,35,1]},</field> </block> </value> <value name="ADD2"> <block type="text" id="n|(:Q;;@|/rl*,,eDMQ0"> <field name="TEXT">{"text": [10,50,"Aktuelle Temperatur:","fonts/bahnschrift20",1]}, {"text": [240,50,"</field> </block> </value> <value name="ADD3"> <block type="get_value" id="Ivop[TTx6k8izC(a}Lh$"> <field name="ATTR">val</field> <field name="OID">hm-rpc.0.NEQ1405541.4.ACTUAL_TEMPERATURE</field> </block> </value> <value name="ADD4"> <block type="text" id=".;[edg]Q8Y}~9~$]`WGh"> <field name="TEXT">°C","fonts/bahnschrift20",2]}, {"text": [10,80,"Eingestellte Temperatur:","fonts/bahnschrift20",1]}, {"text": [240,80,"</field> </block> </value> <value name="ADD5"> <block type="get_value" id="!vH6u](8OPQ3|j4+-R0`"> <field name="ATTR">val</field> <field name="OID">hm-rpc.0.NEQ1405541.4.SET_TEMPERATURE</field> </block> </value> <value name="ADD6"> <block type="text" id="10FFF9ZLy|n:h)tY)c|m"> <field name="TEXT">°C","fonts/bahnschrift20",2]}, {"text": [10,110,"Aktuelle Ventilstellung:","fonts/bahnschrift20",1]}, {"text": [240,110,"</field> </block> </value> <value name="ADD7"> <block type="get_value" id="N~fNY_bADcQ(?eeOcd70"> <field name="ATTR">val</field> <field name="OID">hm-rpc.0.NEQ1405541.4.VALVE_STATE</field> </block> </value> <value name="ADD8"> <block type="text" id="#7e9sI0@iu:c/+?Dr@Z."> <field name="TEXT"> %","fonts/bahnschrift20",2]}, {"text": [10,140,"Batteriespannung:","fonts/bahnschrift20",1]}, {"text": [240,140,"</field> </block> </value> <value name="ADD9"> <block type="get_value" id="M=3Q06RUua?Te,a?1Ui;"> <field name="ATTR">val</field> <field name="OID">hm-rpc.0.NEQ1405541.4.BATTERY_STATE</field> </block> </value> <value name="ADD10"> <block type="text" id="8Mjb{3)XGWhzToz{:.]t"> <field name="TEXT"> V","fonts/bahnschrift20",2]} ]</field> </block> </value> </block> </value> </block> </value> <next> <block type="http_post" id="AoQ+~mSdktWzhHgxGz#C"> <field name="TIMEOUT">15</field> <field name="UNIT">sec</field> <field name="TYPE">text</field> <value name="URL"> <shadow type="text" id="qh|GfefbC0op9nMhC4nk"> <field name="TEXT">http://192.168.49.186/jsonupload</field> </shadow> </value> <value name="DATA"> <block type="text_join" id="YiM(/:1NU2PK@ysCbT8$"> <mutation items="4"></mutation> <value name="ADD0"> <block type="text" id="sY#__Tq@9.DrJShh~Ant"> <field name="TEXT">mac=</field> </block> </value> <value name="ADD1"> <block type="variables_get" id="^ag2u;YyTY9!dP{tJ|}c"> <field name="VAR" id="eMqV!m8?ZCdqN2].w`xb">TagMini1</field> </block> </value> <value name="ADD2"> <block type="text" id="k:I$k7w),ZmO9hEwr:$W"> <field name="TEXT">&json=</field> </block> </value> <value name="ADD3"> <block type="variables_get" id="MEQ/.CHU]v1WHbuc@`Ly"> <field name="VAR" id="*)}|9mHpKcV3YN}|a_t5">jsonMini1</field> </block> </value> </block> </value> </block> </next> </block> </next> </block> </statement> </block> </xml>
Das läuft deutlich einfacher.
Alle anderen TAGs, z.B. die TAGs die den Inhalt von Terminkalendern anzeigen sollen, versorge ich mit dem "Puppeteer-Skript".
Es scheint, das das etwas Ruhe in dieser ganzen "Screenshot-Abfragerei" gebracht hat.
Wenn jemand eine Idee hat, wie ich das was vom ical Adapter zur Verfügung gestellt wird, sauber auf den größeren TAG darstellen kann, immer her damit. Bitte nicht den Google-Ansatz. Da ist die Anzeige auf größeren TAGs ganz anderes als wenn man das zu einem kleinen TAGs sendet.
-
Ich hab jetzt mal einen anderen Ansatz verfolgt und mit hilfe von ChatGPT ein script erstellt welches mir mit Puppeteer einen Screenshoot erstellt und dann per ftp auf eine diskstation schiebt die eh bei mir im Keller steht. Dort kann sich nun openEPaper Link das Bild abholen und macht dieses auch.
const puppeteer = require("puppeteer"); const ftp = require("basic-ftp"); // Funktion für die Hauptlogik async function captureAndUpload() { const client = new ftp.Client(); client.ftp.verbose = true; try { // Browser starten const browser = await puppeteer.launch(); const page = await browser.newPage(); // Seite laden und warten, bis sie vollständig geladen ist await page.goto("http://192.168.178.80:8082/vis/index.html?xxxxxxxxxx", { waitUntil: "networkidle0" }); console.log("Seite vollständig geladen."); // Screenshot erstellen const clipRegion = { x: 0, y: 0, width: 296, height: 128 }; const screenshotPath = "/tmp/screenshot.jpg"; await page.screenshot({ path: screenshotPath, type: "jpeg", quality: 100, clip: clipRegion }); console.log("Screenshot gespeichert:", screenshotPath); await browser.close(); // FTP-Verbindung herstellen await client.access({ host: "192.168.xxx.xx", user: "xxxxxxx", password: "xxxxxxx", secure: false }); console.log("Mit FTP-Server verbunden"); // Datei hochladen await client.uploadFrom(screenshotPath, "/web/screenshot.jpg"); console.log("Screenshot erfolgreich hochgeladen!"); } catch (err) { console.error("Fehler:", err.message); } finally { client.close(); } } // Scheduler: alle 60 Minuten ausführen schedule("*/60 * * * *", async () => { console.log("Starte Screenshot- und Uploadprozess..."); await captureAndUpload(); });
Jetzt ist es aber so das das Bild korekt erstellt wird und auch abgeholt wird.
Im tmp Ordner wird es richtig angezeigt und dann auf dem Tag dann nicht mehr.Was könnte das sein bzw wo dran liegt das?
-
@webranger Deine Auflösung ist auf 296 x 128 gesetzt jedoch hat das genutzte Display eine Auflösung von 384 x 184
-
@atc sagte in E-INK Display OpenEPaperLink - Displayanzeige mit Batterie:
384
Danke! So einfach kann es sein. Habe tätsächlich gedacht weil kleiner ist muss doch erst recht angezeigt werden.
Damit kann ich jetzt arbeiten und funktioniert
-
@holgerwolf Ich gebe mir mal selbst Antwort:
Anderes Display, gleicher Inhalt und Standort läuft seit einigen Tagen durchAlso hat das Display wohl ne Macke