Ein "Wegdriften" könnte ich mir auch nur so erklären, wenn immer nur Positionen zwischen den Endlagen angefahren werden. Laut eigener Aussage werden die Rollladen aber jeden Tag mindestens einmal komplett geöffnet. Danach müssten sie wieder "im Tritt" sein...
Beiträge von horkatz
-
-
um den Router bei bedarf zu rebooten. Natürlich über Remote so faul wie ich bin
Über den Sinn und Unsinn vom "harten" Rebooten des Routers wurde ja schon des Öfteren diskutiert. Welchen Grund gibt es denn, ständig den Router neu zu booten? Wenn er sich "aufhängt", dann erreichst du auch den Shelly nicht mehr...
Jeder normale Reboot sollte über das WebUI oder einen HTTP-Request an den Router durchgeführt werden (wenn er letzteres kann...). -
Ein guter Gedankengang...
-
Wie sind denn die Fristen für die Bewegung eingestellt?
Evtl hier mal größere Werte eingeben...Der Inhalt kann nicht angezeigt werden, da Sie keine Berechtigung haben, diesen Inhalt zu sehen. Nachtrag: Wenn die Endlage erreicht wurde, fließt kein Strom mehr. Das erkennt der Shelly als "offen" oder "geschlossen".
Wie du die Kalibrierung startest, dürfte egal sein... -
Etwas derartiges habe ich noch nie gehört. Wenn am Rollladen nichts verändert wird, dann muss auch kein zweites Mal kalibriert werden. Wie viele Rollladen zeigen dieses Verhalten? Sind sie leichtgängig? Sind die Endlagen richtig eingestellt, oder schießt der Rollladen bei der Bewegung übers Ziel hinaus?
-
Wenn es eine normale Ziehtreppe ist, kann man auch einen herkömmlichen Aufputz-Schalter mit großer Wippe an die richtige Stelle schrauben, dann noch ein Stück Holz als Betätiger, fertig. Man muss manuell einschalten, man kann manuell ausschalten, vergisst man letzteres, wird ausgeschaltet, wenn die Treppe hochgeklappt wird. So habe ich es beim Garagenspeicher gelöst.
-
Jeder wie er mag...
-
Vor 1,5 Jahren war der 2.5 schon ein alter Hut und abgekündigt. 2.5er habe ich nur 4 Stück, bei 3en habe ich mittlerweile die Kondensatoren getauscht, einer läuft noch so seit etwa 4 Jahren...
-
M.E. sollte dies auch via Website gehen.
Innerhalb meines Ortes geht es an verschiedenen Standorten, warum sollte es dann nicht weltweit gehen? Voraussetzung ist die Anbindung an die Cloud (wenn es einfach sein soll).
-
An einer Stelle ist eine Art Komandozentrale geplant, wo man eben alle im Wohn-/Essbereich steuern kann
Von vielen Herstellern gibt es 4-fach-Taster, von Busch-Jaeger leider nicht...
Ich habe daher einen Shelly 4-fach-Taster in einen Alpha-Nea-Rahmen gebaut. Wenn es sich vermeiden lässt, dann würde ich aber keine Shelly Taster und/oder Steckdosen verwenden, die Taster sind nicht besonders hochwertig und halten sicher nicht so lange wie Markenware. -
-
Der Shelly macht auch nichts anderes als der Taster, nur etwas komfortabler und mit mehr Möglichkeiten. Wenn der Taster die Phase auf einen der beiden Ausgänge schaltet, dann muss es auch mit dem Shelly gehen.
Waren beide Shellys neu?
Schließe doch mal einen Shelly provisorisch an einen Schukostecker mit Kabel an, als Last nimmst du je eine Lampenfassung mit Leuchtmittel, dann probiere aus, ob sich was tut. Gerne auch mal Fotos posten (auch von dem Shelly in der Wand)... -
Wenn der Kontakt für 230V geeignet ist (die meisten Magnetkontakte sind es nicht!), dann kannst du ihn direkt an den Shelly anschließen, andernfalls brauchst du zusätzlich ein ADDON.
-
Verwenden darf man ihn schon. Nur nicht in dieser Konstellation.
-
Tu dir einen Gefallen und wirf' die Trennrelais raus. Selbst wenn das WLAN ausfallen sollte (was, wenn man ehrlich ist, nahezu nie passiert, außer bei Stromausfall, dann bewegt sich eh nichts mehr), du hast an jedem Rollladen einen Doppeltaster und kannst einzeln auch ohne WLAN fahren. Wenn der Zentraltaster an einen Shelly angeschlossen wird, kannst du weitere Aktionen ausführen (Double-, Triple- und Longpush), z.B. Schattenpositionen anfahren usw. Wie viele Rollladen sind es denn insgesamt?
-
Kann ich alle Trennrelais durch 2PM ersetzen und 2 Taster parallel an den Eingängen der Shellys anschliessen ?
Also den Zentralschalter jeweils parallel zu den lokalen Schaltern am Shelly ?Das kannst du machen, führt aber dazu, dass dadurch alle Taster parallel angeklemmt sind. Jeder ist dann ein Zentraltaster und steuert alle Rollladen.
Besser ist es, hinter den Zentralschalter einen weiteren Shelly zu setzen, zum Beispiel einen I4, oder einen 2PM. Dieser steuert dann über Aktionen die anderen Rollladen.Edit: Wenn der Zentraltaster unbedingt kabelgebunden sein muss, dann braucht er für jeden "Slave" einen eigenen Kontakt. Das ließe sich über Relais mit vielen Schließern realisieren, ist aber aufwändig und unnötig.
Die Aktionen funktionieren ohne Cloud, nur das WLAN muss aktiv sein... -
auch ein anderer 2PM bringt das gleiche Ergebnis.
Kann mir nicht vorstellen, dass 2 neue Shellys defekt sind. Wenn es wirklich richtig angeschlossen war, dann müsste es funktionieren...
-
Der richtige Shelly wäre der Shelly 1 Gen3 oder Gen4. Ab Gen3 kann der BluButton direkt mit dem Shelly kommunizieren, er wird als BTHome Device eingebunden.
-
benötigt der Shelly zwingend den tatsächlichen L-Leiter an L und den N-Leiter an N?
Nein, wenn du den Shelly über einen Schukostecker versorgen würdest, kannst du diesen ja auch um 180° verdreht einstecken. Wenn am Schalter wirklich der Neutralleiter geschaltet wird, dann musst du den Shelly "verpolt" anschließen, L und N vertauschen. Du brauchst aber trotzdem L und N zur Versorgung des Shelly, vermutlich sind braun und gelb-grün gar nicht angeschlossen und enden in einer Dose, wenn du Pech hast, direkt beim Rollladen. Wenn ohnehin der braune Draht angeklemmt werden muss, dann könnte man es auch direkt richtig klemmen. Wichtig ist auch, dass der Rollladen die gleiche Phase hat, wie der Shelly, das ist bei dir nicht sicher, wenn wirklich der N geschaltet wird...
-
Das Script ist nicht von mir, du findest es auch unter github.
Du musst die MAC-Adresse des BluButton anpassen (Achtung: Kleinbuchstaben verwenden) und die Aktionen anpassen (unten siehst du meine Aktionen).
Wenn du nicht alle 4 Möglichkeiten nutzen willst, dann den "http-Teil" weglassen.Code
Alles anzeigen/** * This script lets you use your Gen2 device as a gateway between Shelly BLU button1 and other Shelly devices (no matter Gen1 or Gen2) * by sending local requests by their local IP APIs. * * What you should change before using it: * > bluButtonAddress -> You should put the mac address of your blu button here. * This script will help you find the mac address: https://github.com/ALLTERCO/shelly-script-examples/blob/main/ble-shelly-scanner.js * * > actions -> You should put the urls here to be executed at the specified event. Urls that shoudl be called on single/short push * of the button, must be placed in the singlePush object. This applies to the double and triple push as well. Example below. * * Limitations: * > At the moment there is a limit of 5 RPC calls at the same time and because of this, the script will execute every 3 urls with a 1 second delay. * Limitations can be check here: https://shelly-api-docs.shelly.cloud/gen2/Scripts/ShellyScriptLanguageFeatures#resource-limits * * > The order of the execution of the urls can't be guaranteed */ /** =============================== CHANGE HERE =============================== */ let CONFIG = { bluButtonAddress: "1a:b2:c3:d4:55:ef", //the mac address of shelly blu button1 that will trigger the actions actions: { //urls to be called on a event //when adding urls you must separate them with commas and put them in quotation marks singlePush: [ //urls that will be executed at singlePush event from the blu button1 "http://127.0.0.1/relay/0?turn=toggle" ], doublePush: [ //urls that will be executed at doublePush event from the blu button1 "http://192.168.2.66/relay/0?turn=toggle" ], triplePush: [ //urls that will be executed at triplePush event from the blu button1 "http://192.168.2.47/relay/0?turn=on" ], longPush: [ //urls that will be executed at longPush event from the blu button1 "http://192.168.2.41/color/0?turn=on&red=255&green=0&blue=0&white=0&gain=100&effect=3&timer=10", "http://192.168.2.42/color/0?turn=on&red=0&green=255&blue=0&white=0&gain=100&effect=3&timer=20" ] } }; /** =============================== STOP CHANGING HERE =============================== */ let urlsPerCall = 3; let urlsQueue = []; let callsCounter = 0; let ALLTERCO_MFD_ID_STR = "0ba9"; let BTHOME_SVC_ID_STR = "fcd2"; let uint8 = 0; let int8 = 1; let uint16 = 2; let int16 = 3; let uint24 = 4; let int24 = 5; let BTH = {}; BTH[0x00] = { n: "pid", t: uint8 }; BTH[0x01] = { n: "Battery", t: uint8, u: "%" }; BTH[0x05] = { n: "Illuminance", t: uint24, f: 0.01 }; BTH[0x1a] = { n: "Door", t: uint8 }; BTH[0x20] = { n: "Moisture", t: uint8 }; BTH[0x2d] = { n: "Window", t: uint8 }; BTH[0x3a] = { n: "Button", t: uint8 }; function getByteSize(type) { if (type === uint8 || type === int8) return 1; if (type === uint16 || type === int16) return 2; if (type === uint24 || type === int24) return 3; //impossible as advertisements are much smaller; return 255; } let BTHomeDecoder = { utoi: function (num, bitsz) { let mask = 1 << (bitsz - 1); return num & mask ? num - (1 << bitsz) : num; }, getUInt8: function (buffer) { return buffer.at(0); }, getInt8: function (buffer) { return this.utoi(this.getUInt8(buffer), 8); }, getUInt16LE: function (buffer) { return 0xffff & ((buffer.at(1) << 8) | buffer.at(0)); }, getInt16LE: function (buffer) { return this.utoi(this.getUInt16LE(buffer), 16); }, getUInt24LE: function (buffer) { return ( 0x00ffffff & ((buffer.at(2) << 16) | (buffer.at(1) << 8) | buffer.at(0)) ); }, getInt24LE: function (buffer) { return this.utoi(this.getUInt24LE(buffer), 24); }, getBufValue: function (type, buffer) { if (buffer.length < getByteSize(type)) return null; let res = null; if (type === uint8) res = this.getUInt8(buffer); if (type === int8) res = this.getInt8(buffer); if (type === uint16) res = this.getUInt16LE(buffer); if (type === int16) res = this.getInt16LE(buffer); if (type === uint24) res = this.getUInt24LE(buffer); if (type === int24) res = this.getInt24LE(buffer); return res; }, unpack: function (buffer) { //beacons might not provide BTH service data if (typeof buffer !== "string" || buffer.length === 0) return null; let result = {}; let _dib = buffer.at(0); result["encryption"] = _dib & 0x1 ? true : false; result["BTHome_version"] = _dib >> 5; if (result["BTHome_version"] !== 2) return null; //can not handle encrypted data if (result["encryption"]) return result; buffer = buffer.slice(1); let _bth; let _value; while (buffer.length > 0) { _bth = BTH[buffer.at(0)]; if (typeof _bth === "undefined") { console.log("BTH: unknown type"); break; } buffer = buffer.slice(1); _value = this.getBufValue(_bth.t, buffer); if (_value === null) break; if (typeof _bth.f !== "undefined") _value = _value * _bth.f; result[_bth.n] = _value; buffer = buffer.slice(getByteSize(_bth.t)); } return result; }, }; function callQueue() { if(callsCounter < 6 - urlsPerCall) { for(let i = 0; i < urlsPerCall && i < urlsQueue.length; i++) { let url = urlsQueue.splice(0, 1)[0]; callsCounter++; Shelly.call("HTTP.GET", { url: url, timeout: 5 }, function(_, error_code, _, data) { if(error_code !== 0) { console.log("Calling", data.url, "failed"); } else { console.log("Calling", data.url, "successed"); } callsCounter--; }, { url: url } ); } } //if there are more urls in the queue if(urlsQueue.length > 0) { Timer.set( 1000, //the delay false, function() { callQueue(); } ); } } let lastPacketId = 0x100; function bleScanCallback(event, result) { //exit if the call is not for a received result if (event !== BLE.Scanner.SCAN_RESULT) { return; } //exit if the data is not coming from a Shelly Blu button1 and if the mac address doesn't match if ( typeof result.local_name === "undefined" || typeof result.addr === "undefined" || result.local_name.indexOf("SBBT") !== 0 || result.addr !== CONFIG.bluButtonAddress ) { return; } let servData = result.service_data; //exit if service data is null/device is encrypted if(servData === null || typeof servData === "undefined" || typeof servData[BTHOME_SVC_ID_STR] === "undefined") { console.log("Can't handle encrypted devices"); return; } let receivedData = BTHomeDecoder.unpack(servData[BTHOME_SVC_ID_STR]); //exit if unpacked data is null or the device is encrypted if(receivedData === null || typeof receivedData === "undefined" || receivedData["encryption"]) { console.log("Can't handle encrypted devices"); return; } //exit if the event is duplicated if (lastPacketId === receivedData.pid) { return; } lastPacketId = receivedData["pid"]; //getting and execuing the action let actionType = ["", "singlePush", "doublePush", "triplePush", "longPush"][receivedData["Button"]]; let actionUrls = CONFIG.actions[actionType]; //exit if the event doesn't exist in the config if(typeof actionType === "undefined") { console.log("Unknown event type in the config"); return; } //save all urls into the queue for the current event for(let i in actionUrls) { urlsQueue.push(actionUrls[i]); } callQueue(); } function bleScan() { //check whether the bluethooth is enabled let bleConfig = Shelly.getComponentConfig("ble"); //exit if the bluetooth is not enabled if(bleConfig.enable === false) { console.log("BLE is not enabled"); return; } //start the scanner let bleScanner = BLE.Scanner.Start({ duration_ms: BLE.Scanner.INFINITE_SCAN, active: true }); //exist if the scanner can not be started if(bleScanner === false) { console.log("Error when starting the BLE scanner"); return; } BLE.Scanner.Subscribe(bleScanCallback); console.log("BLE is successfully started"); } function init() { //exit if there isn't a config if(typeof CONFIG === "undefined") { console.log("Can't read the config"); return; } //exit if there isn't a blu button address if(typeof CONFIG.bluButtonAddress !== "string") { console.log("Error with the Shelly BLU button1's address"); return; } //exit if there isn't action object if(typeof CONFIG.actions === "undefined") { console.log("Can't find the actions object in the config"); return; } //start the ble scan bleScan(); } //init the script init();