Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Lightmanager Air und iobroker

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    Lightmanager Air und iobroker

    This topic has been deleted. Only users with topic management privileges can see it.
    • A
      aleks-83 last edited by

      Ich will mich da nicht zu weit aus dem Fenster lehnen, aber man kann soweit ich weiß alle Buttons die man im Lightmanager (per Airstudio) anglegt hat, steuern.

      Ich nutze zwar nur zwei buttons, um meinen Beamer Lift rauf und runter zu fahren, aber szenen sollten gehen.
      Dazu vllt mal hier schauen.

      v522533 1 Reply Last reply Reply Quote 1
      • v522533
        v522533 @aleks-83 last edited by

        @aleks-83

        Danke Dir

        1 Reply Last reply Reply Quote 1
        • A
          aleks-83 last edited by

          Gerne.

          P.S. Bei hilfreichen Antworten ruhig den Beitrag positiv bewerten 🙂

          1 Reply Last reply Reply Quote 0
          • D
            dos1973 last edited by

            ich nutze den Air...

            auslesen der marker - ip im script anpassen
            params.json

            // Startvariablen:
            // -----------------------------------------------------------------------------
            
            var logOn           = false;     // Skript Logausgabe ein- (true) / ausschalten (false). Fehler werden immer ausgegeben.
            var forecreation    = true;    // Default: false. true: Datenpunkte werden überschrieben (wenn z.B. Bezeichnungen geändert wurden)
            var http = require('http');     // Node Module http verwenden
            var RQoptions = {             // URL, die abgefragt, bzw. gesendet werden soll
                  host: '192.168.10.71',
                  path: '/params.json',
                  method: 'GET',
                  headers: {
                    'User-Agent' : 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/57.0.2987.133 Safari/537.36',
                    'content-Type': 'text/plain',
                    'Accept' : 'application/json, text/javascript'
                  }
            };
            var stringMARKERgesamt  = "0000000000000000000000000000000000000000000000000000000000000000";
            
            // Datenpunkte anlegen:
            // -----------------------------------------------------------------------------
            // Marker:
            var idMarker1 = "lmair.marker.01";     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idMarker1, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: 'LMAir Marker 01',
                 desc: 'LMAir Marker 01',
                 type: 'boolean',
                 def:  false,
                 role: 'value'
            });
            var idMarker2 = "lmair.marker.02";     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idMarker2, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: 'LMAir Marker 02',
                 desc: 'LMAir Marker 02',
                 type: 'boolean',
                 def:  false,
                 role: 'value'
            });
            var idMarker3 = "lmair.marker.03";     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idMarker3, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: 'LMAir Marker 03',
                 desc: 'LMAir Marker 03',
                 type: 'boolean',
                 def:  false,
                 role: 'value'
            });
            var idMarker4 = "lmair.marker.04";     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idMarker4, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: 'LMAir Marker 04',
                 desc: 'LMAir Marker 04',
                 type: 'boolean',
                 def:  false,
                 role: 'value'
            });
            var idMarker5 = "lmair.marker.05";     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idMarker5, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: 'LMAir Marker 05',
                 desc: 'LMAir Marker 05',
                 type: 'boolean',
                 def:  false,
                 role: 'value'
            });
            var idMarker6 = "lmair.marker.06";     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idMarker6, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: 'LMAir Marker 06',
                 desc: 'LMAir Marker 06',
                 type: 'boolean',
                 def:  false,
                 role: 'value'
            });
            var idMarker7 = "lmair.marker.07";     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idMarker7, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: 'LMAir Marker 07',
                 desc: 'LMAir Marker 07',
                 type: 'boolean',
                 def:  false,
                 role: 'value'
            });
            var idMarker8 = "lmair.marker.08";     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idMarker8, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: 'LMAir Marker 08',
                 desc: 'LMAir Marker 08',
                 type: 'boolean',
                 def:  false,
                 role: 'value'
            });
            var idMarker9 = "lmair.marker.09";     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idMarker9, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: 'LMAir Marker 09',
                 desc: 'LMAir Marker 09',
                 type: 'boolean',
                 def:  false,
                 role: 'value'
            });
            var idMarker10 = "lmair.marker.10";     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idMarker10, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: 'LMAir Marker 10',
                 desc: 'LMAir Marker 10',
                 type: 'boolean',
                 def:  false,
                 role: 'value'
            });
            var idMarker11 = "lmair.marker.11";     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idMarker11, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: 'LMAir Marker 11',
                 desc: 'LMAir Marker 11',
                 type: 'boolean',
                 def:  false,
                 role: 'value'
            });
            var idMarker12 = "lmair.marker.12";     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idMarker12, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: 'LMAir Marker 12',
                 desc: 'LMAir Marker 12',
                 type: 'boolean',
                 def:  false,
                 role: 'value'
            });
            var idMarker13 = "lmair.marker.13";     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idMarker13, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: 'LMAir Marker 13',
                 desc: 'LMAir Marker 13',
                 type: 'boolean',
                 def:  false,
                 role: 'value'
            });
            var idMarker14 = "lmair.marker.14";     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idMarker14, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: 'LMAir Marker 14',
                 desc: 'LMAir Marker 14',
                 type: 'boolean',
                 def:  false,
                 role: 'value'
            });
            var idMarker15 = "lmair.marker.15";     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idMarker15, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: 'LMAir Marker 15',
                 desc: 'LMAir Marker 15',
                 type: 'boolean',
                 def:  false,
                 role: 'value'
            });
            var idMarker16 = "lmair.marker.16";     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idMarker16, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: 'LMAir Marker 16',
                 desc: 'LMAir Marker 16',
                 type: 'boolean',
                 def:  false,
                 role: 'value'
            });
            
            // Manueller Button:
            var idButton = "lmair.marker_manuell_auslesen"; 							// Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idButton, 0, forecreation, {                                  // Datenpunkt wird angelegt
                 name: 'LMAir Marker auslesen',
                 desc: 'Marker von LMAir auslesen',
                 type: 'boolean',
                 role: 'button'/*,
                 smartName: {
                     de: 'LMAir Marker auslesen'
                 }*/
            });
            
            // Funktionen:
            // -----------------------------------------------------------------------------
            // Daten abfragen:
            function DatenAuslesen() {
                var req = http.get(RQoptions, function(res) {
                if(logOn) log('STATUS: ' + res.statusCode);               // Statuscode
                if(logOn) log('HEADERS: ' + JSON.stringify(res.headers)); // Header (Rückmeldung vom Webserver)
                // Buffer the body entirely for processing as a whole.
                var bodyChunks  = [];
                var chunkLine   = 0;
                res.on('data', function(chunk) {
                    chunkLine = chunkLine + 1;
                    if(logOn)  log("Zeilennummer: " + chunkLine+ " ,Inhalt: " +  chunk);
                    // Hier können die einzelnen Zeilen verarbeitet werden...
                    bodyChunks.push(chunk);
                }).on('end', function() {
                    if(logOn) log("ARRAY mit den einzelnen Zeilen: " + bodyChunks);
                    if(logOn) log("ARRAY Länge: " + bodyChunks.length);
            
                    var body = Buffer.concat(bodyChunks);// erhaltene Daten
                    if(logOn) log('BODY: ' + body);     // ...und/oder das Gesamtergebnis.
                    
                    DatenVerarbeiten(body);				// Abrufen der Bearbeitungs-Funktion
                    });
                });
                req.on('error', function(e) { // Fehler abfangen
                    log('ERROR: ' + e.message,"warn");
                    return("error");
                });
            }
            
            // Daten verarbeiten:
            function DatenVerarbeiten(result) {
                var json = JSON.parse(result);
            	
            	if (json !== null) {
            	    stringMARKERgesamt = json["marker state"];
            	    var wertMARKERvon = 1;
            	    var wertMARKERbis = 16;
            	    var stringMARKERkurz = stringMARKERgesamt.slice(wertMARKERvon-1, wertMARKERbis);
            	    
            	    var wertDURCHLAUF = 1;
            	    while (wertDURCHLAUF <= wertMARKERbis) {
            	        var wertMARKERaktuell = stringMARKERgesamt.slice(wertDURCHLAUF-1, wertDURCHLAUF);
            	        wertMARKERaktuell = parseFloat(wertMARKERaktuell);
            	        
            	        WertePruefen(wertMARKERaktuell, wertDURCHLAUF);
            	        
            	        wertDURCHLAUF++;
            	    }
            	} else {
            		log ("Fehler beim Einlesen der Daten.");
            	}
            }
            
            // Werte überprüfen und anpassen:
            function WertePruefen (MarkerWERT, MarkerNR) {
                if (MarkerWERT === 1) {
                    MarkerWERT = true;
                } else if (MarkerWERT === 0) {
                    MarkerWERT = false;
                } else {
                    log ("Marker-Wert fehlerhaft");
                }
                
                switch (MarkerNR) {
                    case 1:
                        idMARKERaktuell = "javascript.0." + idMarker1;          // Marker 01
                        break;
                    case 2:
                        idMARKERaktuell = "javascript.0." + idMarker2;          // Marker 02
                        break;
                    case 3:
                        idMARKERaktuell = "javascript.0." + idMarker3;          // Marker 03
                        break;
                    case 4:
                        idMARKERaktuell = "javascript.0." + idMarker4;          // Marker 04
                        break;
                    case 5:
                        idMARKERaktuell = "javascript.0." + idMarker5;          // Marker 05
                        break;
                    case 6:
                        idMARKERaktuell = "javascript.0." + idMarker6;          // Marker 06
                        break;
                    case 7:
                        idMARKERaktuell = "javascript.0." + idMarker7;          // Marker 07
                        break;
                    case 8:
                        idMARKERaktuell = "javascript.0." + idMarker8;          // Marker 08
                        break;
                    case 9:
                        idMARKERaktuell = "javascript.0." + idMarker9;          // Marker 09
                        break;
                    case 10:
                        idMARKERaktuell = "javascript.0." + idMarker10;         // Marker 10
                        break;
                    case 11:
                        idMARKERaktuell = "javascript.0." + idMarker11;         // Marker 11
                        break;
                    case 12:
                        idMARKERaktuell = "javascript.0." + idMarker12;         // Marker 12
                        break;
                    case 13:
                        idMARKERaktuell = "javascript.0." + idMarker13;         // Marker 13
                        break;
                    case 14:
                        idMARKERaktuell = "javascript.0." + idMarker14;         // Marker 14
                        break;
                    case 15:
                        idMARKERaktuell = "javascript.0." + idMarker15;         // Marker 15
                        break;
                    case 16:
                        idMARKERaktuell = "javascript.0." + idMarker16;         // Marker 16
                        break;
                    default:
                        log ("fehlerhafter Marker");
                        break;
                }
                if (idMARKERaktuell !== null) {
                    if (getState(idMARKERaktuell).val !== MarkerWERT) setState(idMARKERaktuell, MarkerWERT);
                } else {
                    log ("Markerpfad fehlerhaft");
                }
            }
            
            
            // Start und Intervall:sekunden  '* 2 * * * *'
            // --------------------------------------------------------------------------
            setTimeout(DatenAuslesen, 1000);        // Beim Skriptstart die Werte auslesen
            schedule('*/10 * * * * *', DatenAuslesen);  // alle 10sekunden
            
            // Button-Aktivierung:
            on({id: "javascript.0." + idButton, change:'any'}, function (dp) {
                DatenAuslesen();
            });
            

            weather.json, falls Temp Sensoren vorhanden sind

            var logOn           = false;     // Skript Logausgabe ein- (true) / ausschalten (false). Fehler werden immer ausgegeben.
            var forecreation    = true;    // Default: false. true: Datenpunkte werden überschrieben (wenn z.B. Bezeichnungen geändert wurden)
            var http = require('http');     // Node Module http verwenden
            var RQoptions = {             // URL, die abgefragt, bzw. gesendet werden soll
                  host: '192.168.10.71',
                  path: '/weather.json',
                  method: 'GET',
                  headers: {
                    'User-Agent' : 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/57.0.2987.133 Safari/537.36',
                    'content-Type': 'text/plain',
                    'Accept' : 'application/json, text/javascript'
                  }
            };
            
            // Datenpunkte anlegen:
            // -----------------------------------------------------------------------------
            	// Datenpunkt-Variablen:
            	// -------------------------------------------------------------------------
            	var idVariablenDP;
            	var dpGruppe;
            	var dpPunkt;
            	// -------------------------------------------------------------------------
            
            // --- GRUPPE "channel0"
            var dpGruppe = "channel0";
            var dpPunkt = "temperature";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            var dpPunkt = "humidity";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            
            // --- GRUPPE "channel1"
            var dpGruppe = "channel1";
            var dpPunkt = "temperature";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            var dpPunkt = "humidity";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            // --- GRUPPE "channel2"
            var dpGruppe = "channel2-bad";
            var dpPunkt = "temperature";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            var dpPunkt = "humidity";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            // --- GRUPPE "channel3"
            var dpGruppe = "channel3";
            var dpPunkt = "temperature";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            var dpPunkt = "humidity";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            // --- GRUPPE "channel4"
            var dpGruppe = "channel4";
            var dpPunkt = "temperature";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            var dpPunkt = "humidity";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            // --- GRUPPE "channel5"
            var dpGruppe = "channel5";
            var dpPunkt = "temperature";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            var dpPunkt = "humidity";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            // --- GRUPPE "channel6"
            var dpGruppe = "channel6-daniel";
            var dpPunkt = "temperature";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            var dpPunkt = "humidity";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            // --- GRUPPE "channel7"
            var dpGruppe = "channel7-jessica";
            var dpPunkt = "temperature";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            var dpPunkt = "humidity";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            // --- GRUPPE "channel8"
            var dpGruppe = "channel8-schlafzimmer";
            var dpPunkt = "temperature";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            var dpPunkt = "humidity";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            // --- GRUPPE "channel9"
            var dpGruppe = "channel9-kueche";
            var dpPunkt = "temperature";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            var dpPunkt = "humidity";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            // --- GRUPPE "channel10"
            var dpGruppe = "channel10-wohnzimmer";
            var dpPunkt = "temperature";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            var dpPunkt = "humidity";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            
            // --- GRUPPE "channel11"
            var dpGruppe = "channel11";
            var dpPunkt = "temperature";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            var dpPunkt = "humidity";
            var idVariablenDP = "lmair.temp-sensoren." + dpGruppe + "." + dpPunkt;     // Pfad und Name, unter dem in der Javascript-Instanz der Datenpunkte angelegt wird
            createState(idVariablenDP, 0, forecreation, {                        // Datenpunkt wird angelegt
                 name: dpPunkt,               // <-- !!!!!
                 desc: dpPunkt + ' von ' + dpGruppe,      // <-- !!!!!
                 type: 'number',
                 def:  0.0,
                 role: 'value'
            });
            
            
            // Funktionen:
            // -----------------------------------------------------------------------------
            function DatenAuslesen() {
                var req = http.get(RQoptions, function(res) {
                if(logOn) log('STATUS: ' + res.statusCode);               // Statuscode
                if(logOn) log('HEADERS: ' + JSON.stringify(res.headers)); // Header (Rückmeldung vom Webserver)
                // Buffer the body entirely for processing as a whole.
                var bodyChunks  = [];
                var chunkLine   = 0;
                res.on('data', function(chunk) {
                    chunkLine = chunkLine + 1;
                    if(logOn)  log("Zeilennummer: " + chunkLine+ " ,Inhalt: " +  chunk);
                    // Hier können die einzelnen Zeilen verarbeitet werden...
                    bodyChunks.push(chunk);
                }).on('end', function() {
                    if(logOn) log("ARRAY mit den einzelnen Zeilen: " + bodyChunks);
                    if(logOn) log("ARRAY Länge: " + bodyChunks.length);
            
                    var body = Buffer.concat(bodyChunks);// erhaltene Daten
            
                    if(logOn) log('BODY: ' + body);     // ...und/oder das Gesamtergebnis.
                    DatenVerarbeiten(body);				// Abrufen der Bearbeitungs-Funktion
                    });
                });
                req.on('error', function(e) { // Fehler abfangen
                    log('ERROR: ' + e.message,"warn");
                    return("error");
                });
            }
            // -----------------------------------------------------------------------------
            function DatenVerarbeiten(result) {
                var json = JSON.parse(result);
            	
            	if (json !== null) {
            		// GRUPPE "channel0"
            		setState("javascript.0.lmair.temp-sensoren.channel0.temperature", parseFloat(json.channel0.temperature));
            		setState("javascript.0.lmair.temp-sensoren.channel0.humidity", parseFloat(json.channel0.humidity));
                    // GRUPPE "channel1"
            		setState("javascript.0.lmair.temp-sensoren.channel1.temperature", parseFloat(json.channel1.temperature));
            		setState("javascript.0.lmair.temp-sensoren.channel1.humidity", parseFloat(json.channel1.humidity));
            		// GRUPPE "channel2"
            		setState("javascript.0.lmair.temp-sensoren.channel2-bad.temperature", parseFloat(json.channel2.temperature));
            		setState("javascript.0.lmair.temp-sensoren.channel2-bad.humidity", parseFloat(json.channel2.humidity));
            		// GRUPPE "channel3"
            		setState("javascript.0.lmair.temp-sensoren.channel3.temperature", parseFloat(json.channel3.temperature));
            		setState("javascript.0.lmair.temp-sensoren.channel3.humidity", parseFloat(json.channel3.humidity));
            		// GRUPPE "channel4"
            		setState("javascript.0.lmair.temp-sensoren.channel4.temperature", parseFloat(json.channel4.temperature));
            		setState("javascript.0.lmair.temp-sensoren.channel4.humidity", parseFloat(json.channel4.humidity));
            		// GRUPPE "channel5"
            		setState("javascript.0.lmair.temp-sensoren.channel5.temperature", parseFloat(json.channel5.temperature));
            		setState("javascript.0.lmair.temp-sensoren.channel5.humidity", parseFloat(json.channel5.humidity));
            		// GRUPPE "channel6"
            		setState("javascript.0.lmair.temp-sensoren.channel6-daniel.temperature", parseFloat(json.channel6.temperature));
            		setState("javascript.0.lmair.temp-sensoren.channel6-daniel.humidity", parseFloat(json.channel6.humidity));
            		// GRUPPE "channel7"
            		setState("javascript.0.lmair.temp-sensoren.channel7-jessica.temperature", parseFloat(json.channel7.temperature));
            		setState("javascript.0.lmair.temp-sensoren.channel7-jessica.humidity", parseFloat(json.channel7.humidity));
            		// GRUPPE "channel8"
            		setState("javascript.0.lmair.temp-sensoren.channel8-schlafzimmer.temperature", parseFloat(json.channel8.temperature));
            		setState("javascript.0.lmair.temp-sensoren.channel8-schlafzimmer.humidity", parseFloat(json.channel8.humidity));
            		// GRUPPE "channel9"
            		setState("javascript.0.lmair.temp-sensoren.channel9-kueche.temperature", parseFloat(json.channel9.temperature));
            		setState("javascript.0.lmair.temp-sensoren.channel9-kueche.humidity", parseFloat(json.channel9.humidity));
            		// GRUPPE "channel10"
            		setState("javascript.0.lmair.temp-sensoren.channel10-wohnzimmer.temperature", parseFloat(json.channel10.temperature));
            		setState("javascript.0.lmair.temp-sensoren.channel10-wohnzimmer.humidity", parseFloat(json.channel10.humidity));
            		// GRUPPE "channel11"
            		setState("javascript.0.lmair.temp-sensoren.channel11.temperature", parseFloat(json.channel11.temperature));
            		setState("javascript.0.lmair.temp-sensoren.channel11.humidity", parseFloat(json.channel11.humidity));
            	} else {
            		log ("Fehler beim Einlesen der Daten.");
            	}
            }
            
            // Beim Skriptstart die Werte auslesen:
            // --------------------------------------------------------------------------
            setTimeout(DatenAuslesen, 1000);
            
            // Werte automatisch aktualisieren:
            // --------------------------------------------------------------------------
            schedule('*/45 * * * * *', DatenAuslesen);  // alle 30 sekunden 
            //
            //
            

            schalten der Szenen, iobroker typisch mit "true/ false"

            //schaltet die LW Spots via LM
            
            const idVis = 'javascript.0.lmair.marker.03'; // ID des Datenpunktes, der auf Vis reagiert (false/true)
            const idMarker = 'javascript.0.lmair.marker.03';
            const request = require('request');
            const url = 'http://192.168.10.71/control?key=';
            const js = 'system.adapter.javascript.' + instance;
            
            on({id: idVis, change: 'ne', fromNe: js}, function(dp) { // Triggern bei Wertänderung durch Vis
               var key = '19'; // aus
               if(dp.state.val) key = '18'; //ein
               request(url + key, function(error, response, body) {
                  if(error) log('Fehler Request Steckdose', 'error');
               });
            });
            

            allerdings bin ich noch nicht auf dem derzeitigen aktuellen Air Stand 9.5
            sollte m.E aber noch genauso funktionieren

            Credits für die Script gehen hier ans Forum... wurde alles von Hilfsbereiten usern erstellt.

            v522533 P 2 Replies Last reply Reply Quote 1
            • v522533
              v522533 @dos1973 last edited by

              @dos1973

              vielen Dank

              1 Reply Last reply Reply Quote 0
              • P
                poyo @dos1973 last edited by

                @dos1973 Vielen dank für die Scripte.
                Habe allerdings ein ein Problem mit schalten der Szenen über Blockly.
                Szene geht kurz auf true und sofort auf false, und wird nicht geschaltet.
                Manuelles schalten über Vis geht ohne Probleme.

                Hast du vielleicht ein Tip für mich ?
                Mein Blockly script sieht so aus:

                Bildschirmfoto 2020-02-02 um 14.41.51.png

                1 Reply Last reply Reply Quote 0
                • D
                  dos1973 last edited by

                  warum nutzt du das vorherige script nicht?

                  1 Reply Last reply Reply Quote 0
                  • P
                    poyo last edited by

                    Ich nutze dein Script ja, ich schalte damit die Szenen vom Lightmanager.
                    Funktioniert auch einwandfrei, was nicht funktioniert ist über einen trigger in einem Blockly script zum Beispiel wenn die Anwesenheit Erkennung true dann schalte das Licht an mit Datenpunkt LMair Marker 07.
                    LMair Marker 07 geht kurz auf true und dann wieder auf false und Szene wird nicht geschaltet.

                    D 1 Reply Last reply Reply Quote 0
                    • D
                      dos1973 @poyo last edited by

                      @poyo
                      du musst in deinem Blocky nicht die marker Schalter sonder die Szenen aus dem LM aufrufen, das funktioniert nur mit dem Script.

                      http://LM-IP/control?key=Deine Szenen

                      P 1 Reply Last reply Reply Quote 0
                      • P
                        poyo @dos1973 last edited by poyo

                        @dos1973 Das mache ich ja LMair Marker 07 ist mein Datenpunkt der die Szene 7 mit deinem Script schaltet, funktioniert auch manuell über vis und über die Objektverwaltung .Das blockly script schaltet den Datenpunkt LMair Marker 07 die Szene 7 kurz auf true und dann wieder false aber die Szene wird nicht geschaltet.Irgendwas mach ich im Blockly falsch.

                        1 Reply Last reply Reply Quote 0
                        • D
                          dos1973 last edited by dos1973

                          nur zum Verständnis:
                          bei Anwesenheit wird auf dem AIR der Marker 7 eingeschaltet, richtig?

                          sobald der Marker7 vom AIR zum iobroker synchronisiert wird geht das licht an, oder?, alles ohne Blockly

                          1 Reply Last reply Reply Quote 0
                          • P
                            poyo last edited by

                            Ich hab jetzt hinbekommen, hat etwas gedauert bis ich das verstanden habe.
                            Mit deinem Script kann ich wohl nur über vis die Szenen schalten.
                            Hab jetzt so über Blockly gelöst siehe bild.
                            Bildschirmfoto 2020-02-02 um 23.20.37.png

                            Trotzdem Danke

                            D 1 Reply Last reply Reply Quote 0
                            • D
                              dos1973 @poyo last edited by

                              @poyo
                              schön das es jetzt klappt, das hatte ich ja vorher schon beschrieben...
                              ja, das script lässt nur aus der Vis das schalten.

                              1 Reply Last reply Reply Quote 0
                              • StM47
                                StM47 last edited by

                                Hallo,

                                ich nutze auch den Lightmanager Air ebenfalls mit dem Harmony Adapter und Alexa 2. Es funktioniert auch alles soweit ganz gut.

                                Ich möchte meine Jalousien mit dem Yahka (Homekit Adapter) steuern. Hat das schon jemand hin bekommen?

                                1 Reply Last reply Reply Quote 0
                                • First post
                                  Last post

                                Support us

                                ioBroker
                                Community Adapters
                                Donate
                                FAQ Cloud / IOT
                                HowTo: Node.js-Update
                                HowTo: Backup/Restore
                                Downloads
                                BLOG

                                425
                                Online

                                31.9k
                                Users

                                80.1k
                                Topics

                                1.3m
                                Posts

                                lightmanager javascript
                                6
                                22
                                3335
                                Loading More Posts
                                • Oldest to Newest
                                • Newest to Oldest
                                • Most Votes
                                Reply
                                • Reply as topic
                                Log in to reply
                                Community
                                Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                The ioBroker Community 2014-2023
                                logo