NEWS
Pi 3 als Bluetooth LE Scanner (Beispielscript)
-
2.) oder einfach das Skript stoppen, 30 Sekunden warten und dann alle Datenpunkte löschen, in dem Du den Zweig Bluetooth auswählst und diesen inkl. aller Unterpunkte löschst. Einmal Objekte aktualisieren und das Skript wieder starten.
Wenn Du das dann wieder hast, dass für ein Gerät nur der Channel angelegt wird, kannst DU das noch einmal wiederholen oder wir müssen mit den Logs auf Debug2 Level ran.
. `
Hab ich nun zweimal gemacht. Nützt nichts.Aber ich habe wohl ein größeres Problem
1146_unbenannt.png -
Hab ich nun zweimal gemacht. Nützt nichts.
Aber ich habe wohl ein größeres Problem `
Nein, Du hast kein größeres Problem. Das läuft auch so.
Mir ist das noch nicht aufgefallen, weil auf dem Raspberry Pi 3 noch eine alte ioBroker Version läuft. Die neue meckert, wenn man die Datentypen unsauber benutzt. Habe ich wohl gemacht :oops:
Ist aber kein großer Akt das zu korrigieren.
Wenn Du 40 MB Ram übrig hast, kannst Du eine eigene Javascript-Instanz für das Skript aufmachen (ist dann wie ein eigener Adapter) und den Loglevel auf Error stellen. Dann läuft das Log nicht voll.
Ich komme leider erst am Wochenende dazu das Skript zu überarbeiten. Das Thema, dass nur der Channel angelegt wird, dürfte allerdings etwas knifflig werden, da ich es nicht nachstellen kann. Die Datenpunkttypen korrigiere ich.
-
Hab ich nun zweimal gemacht. Nützt nichts. `
Was Du noch mal machen kannst.
Den Bluetooth-Zweig noch einmal löschen und in den Javascript-Adapter Einstellungen für die Instanz den Haken bei "erlaube setObject" rausnehmen.
Eventuell geht es dann. Ansonsten hilft es den Fehler einzugrenzen.
-
Hab ich nun zweimal gemacht. Nützt nichts. `
Was Du noch mal machen kannst.
Den Bluetooth-Zweig noch einmal löschen und in den Javascript-Adapter Einstellungen für die Instanz den Haken bei "erlaube setObject" rausnehmen.
Eventuell geht es dann. Ansonsten hilft es den Fehler einzugrenzen. `
Alles gut! Nix gemacht und heute Morgen werden alle drei G-Tags komplett angezeigtDie Warnungen bleiben, aber machen wohl kein Problem. Ich teste mal deine Hinweise aus…
-
Selbst heilender Code
Gesendet von iPhone mit Tapatalk
-
Hab jetzt mal etwas mit den drei G-Tags rumgespielt.
2 werde ich permanent in die Autos legen. So soll dann in VIS angezeigt werden, ob die Autos da sind.
Zusätzlich könnte ich mir abends eine Nachricht zuschicken lassen, wenn das Auto nicht in der Nähe ist, dann steht es wahrscheinlich auf der anderen Straßenseite wo man Werkstags nur von 14:00 - 7:00 Uhr parken darf. Ich fahre meist gegen 7:15 - 7:30 zur Arbeit
Schick wäre es auch zu sehen welches Auto vorne steht, aber das scheint von der Auflösung nicht zu klappen:
1146_g-tag-empfang.gif -
Schick wäre es auch zu sehen welches Auto vorne steht, aber das scheint von der Auflösung nicht zu klappen: `
Interessanter Anwendungsfall. Zur Erkennung der Reihenfolge der Autos kann ich mir vorstellen, dass die Genauigkeit dazu nicht ausreicht.
Du könntest aber die schwankenden Entfernungen in Mittelwerte umwandeln und dann mal schauen, ob eine Unterscheidung je nach Stellplatz besser wird.
-
Schick wäre es auch zu sehen welches Auto vorne steht, aber das scheint von der Auflösung nicht zu klappen: `
Interessanter Anwendungsfall. Zur Erkennung der Reihenfolge der Autos kann ich mir vorstellen, dass die Genauigkeit dazu nicht ausreicht.
Du könntest aber die schwankenden Entfernungen in Mittelwerte umwandeln und dann mal schauen, ob eine Unterscheidung je nach Stellplatz besser wird. `
Ja, genau. Daran habe ich auch gleich gedacht. Aber beim Umsetzen der Programmierung hätte ich mein Problem -
Ja, genau. Daran habe ich auch gleich gedacht. Aber beim Umsetzen der Programmierung hätte ich mein Problem `
Schau Dir das mal an den Charts an, ob das was bei Dir bringt. In Flot bekommst Du eine gewisse Glättung hin,wenn Du bei dem Datenpunkt unter "Art" statt "minmax" "mittel" einstellst.
Wenn das was bringt, kann man ein Miniskript schreiben, welche einen "geglätteten" Datenpunkt erzeugt.
Wenn Du die Warnungen weghaben willst:
Der Datenpunkt war im Skript falsch angelegt:
"Distanz" : { "init": 0, "dp": { "name": 'Bluetooth Device Distanz', "desc": 'Bluetooth Device errechnete Entfernung', "type": 'number', "unit": 'm', "role": 'value' }
Unter "type" stand dort "float" (gibt es als Type in ioBroker nicht).
Wenn Du das so im Skript änderst (solltest Du wg. möglicher neuer Geräte trotzdem tun), hat das keine Auswirkung, da die Datenpunkte schon angelegt sind.
Zur Korrektur:
Die Distanz-Datenpunkte in den Objekten korrigieren (Objekte/Datenpunkt, Zahrad für Einstellungen). Dort steht unter "Allgemein/Type"nun wahrscheinlich "boolean". Das muss für jedes Gerät auf "Zahl" geändert werden.
-
Schau Dir das mal an den Charts an, ob das was bei Dir bringt. In Flot bekommst Du eine gewisse Glättung hin,wenn Du bei dem Datenpunkt unter "Art" statt "minmax" "mittel" einstellst.
Wenn das was bringt, kann man ein Miniskript schreiben, welche einen "geglätteten" Datenpunkt erzeugt. `
Ja, bringt was
1146_entfernung_gemittelt.gif -
schön das es klappt
Gesendet von iPhone mit Tapatalk
-
Unter "type" stand dort "float" (gibt es als Type in ioBroker nicht).
Wenn Du das so im Skript änderst (solltest Du wg. möglicher neuer Geräte trotzdem tun), hat das keine Auswirkung, da die Datenpunkte schon angelegt sind.
Zur Korrektur:
Die Distanz-Datenpunkte in den Objekten korrigieren (Objekte/Datenpunkt, Zahrad für Einstellungen). Dort steht unter "Allgemein/Type"nun wahrscheinlich "boolean". Das muss für jedes Gerät auf "Zahl" geändert werden. `
Yeah! Keine Warnungen mehr Danke! -
So, jetzt habe ich auch das Bluetooth Script von ruhr70 auf dem NUC als Unterhost installiert 8-)
Klappt sehr gut, die Funkfeuerkanonen namens Apple TVs zeigt er auch sofort an, aber mein iPhone 6S will er nicht anzeigen.
Egal ob mit Ubuntu per Bluetooth verbunden oder nicht. In dem Script habe ich im ersten Teil auch die Blacklists alle sauber gemacht und auch den Spamfilter auf false gesetzt. Das iPhone will er aber nicht anzeigen
Gerade das ist mir aber wichtig, weil ich mit (nur) dessen Abwesenheit mir per Pushover Meldungen über die HM Fenstersensoren senden lassen will (davon habe ich gestern 20 Stück gelötet, also Spaß sieht anders aus!). Also quasi eine primitive Alarmanlage im Haus.
Danke für Infos und besonderen Dank an ruhr70 für das tolle Script!
edit: vielleicht kann man hier http://forum.iobroker.net/viewtopic.php … 976#p24976 den Fehler mit der Distanz gleich ausbessern um eine "saubere" Version zu haben. Habs per Hand bei mir vorm einkopieren gemacht.
-
Das iPhone ist leider nicht dafür geeignet. Außer Du findest eine App, wo es sich z.B als iBeacon nutzen lässt. Ich meine aber iOS lässt das nicht zu.
Alternativen:
_ diverse Fitnessarmbänder
_ Gigaset G-Tag
_ blukii (oder so ähnlich) die haben ganz brauchbare Schlüsselanhänger oder Tags, die man sich an der Kleidung Heften kann
_ Beispiele stehen ganz am Anfang
Gesendet von iPad mit Tapatalk
-
Mh, ich dachte, weil beim Auto meldet es sich ja auch automatisch an… [emoji26]
Gesendet von iPhone mit Tapatalk
-
Mh, ich dachte, weil beim Auto meldet es sich ja auch automatisch an… [emoji26]
Gesendet von iPhone mit Tapatalk `
https://blog.passkit.com/configure-ipho … ansmitter/
Von unterwegs gegoogelt. Scheint also eine Lösung zu geben.
Dann gibt es bestimmt auch Apps.
Gesendet von iPad mit Tapatalk
-
Mit der App könnte es funktionieren:
„Beacon-tx“ von Luca Ciciriello
Gesendet von iPad mit Tapatalk
-
Diese App, und alle die ich ausprobiert habe, hören leider auf zu senden sobald der Bildschirm aus ist.
Schade, aber irgendwas muss das iPhone doch standardmäßig aussenden, mit dem Auto verbindet er sich auch automatisch und sofort beim einsteigen ohne mein zutun. Aber vermutlich scannt da das iPhone nur, ob das (bekannte) Auto da ist.
Dann muss ich mir doch so einen Schlüsselanhänger-Beacon besorgen oder ich nutze die Geofency App.
Du hast doch auch den TI Sensor. Den kann man ja auch als Beacon missbrauchen. Bei mir schaltet er sich leider nur nach einer gewissen Zeit aus und man muss ihn manuell per Knopfdruck aktivieren. Ist das bei dir auch so? Wie kann man den dann im Dauereinsatz einbinden?
-
hey,
habe heute meinen Rasp 3 bekommen, sofort installiert und iobroker als slave eingebunden.
leider funktioniert das Script nicht, bekomme folgende Fehlermeldung:
22:36:43.387 [info] javascript.0 Stop script script.js.Bluetooth 22:36:43.392 [info] javascript.1 Stop script script.js.Bluetooth 22:36:43.368 [info] javascript.2 Stop script script.js.Bluetooth 22:36:43.466 [info] javascript.2 Start javascript script.js.Bluetooth 22:36:43.467 [error] javascript.2 script.js.Bluetooth: Cannot find module 'debug' at Module._compile (module.js:409:26), at Object.Module._extensions..js (module.js:416:10), at Module.load (module.js:343:32), at Function.Module._load (module.js:300:12), at Module.require (module.js:353:17), at require (internal/module.js:12:17), at Object. (/opt/iobroker/node_modules/iobroker.javascript/node_modules/noble/index.js:1:75), at Module._compile (module.js:409:26), at Object.Module._extensions..js (module.js:416:10), at Module.load (module.js:343:32), at Function.Module._load (module.js:300:12), at Module.require (module.js:353:17), at require (internal/module.js:12:17), at sandbox.require (/opt/iobroker/node_modules/iobroker.javascript/javascript.js:644:32), at script.js.Bluetooth:353:15 22:36:43.467 [info] javascript.2 script.js.Bluetooth: --== script.js.Bluetooth ==-- gestartet. Instanz: "javascript.2.", Loglevel: debug2 22:36:43.467 [info] javascript.2 script.js.Bluetooth: debug2: Vars, Loglevel und Scriptname gesetzt 22:36:43.468 [error] javascript.2 script.js.Bluetooth: node.js Module "noble" steht nicht zur Verfügung 22:36:43.468 [error] javascript.2 script.js.Bluetooth: Voraussetzung für noble: https://github.com/sandeepmistry/noble#prerequisites 22:36:43.468 [info] javascript.2 script.js.Bluetooth: Liste bluetoothBlacklistManufacturerData auf gültige Werte geprüft. Anzahl Einträge: 3 22:36:43.468 [info] javascript.2 script.js.Bluetooth: Liste bluetoothBlacklistMac auf gültige Werte geprüft. Anzahl Einträge: 2 22:36:43.468 [info] javascript.2 script.js.Bluetooth: warn: Das Skript wurde nicht gestartet. Siehe Fehlermeldungen. 22:36:43.468 [info] javascript.2 script.js.Bluetooth: registered 0 subscriptions and 0 schedules
was mache ich falsch?
ich habe 3 javascript instanzen
2 auf dem "main" System
1 auf dem client-rasp 3
das logs script liegt auf dem rasp 3 im global ordner
das bluetooth script ebenfalls auf dem rasp 3 im "root" Verzeichnis der Scripts
in den Instanzen steht im Config "noble" - Ohne die " - und das Hackerl darunter ist gesetzt
was mache ich falsch?
Bitte Hilfe
-
Hast du dir diese seite mal angesehen, die im log als hinweis erscheint
https://github.com/sandeepmistry/noble#prerequisites
Gruß
Rainer