Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Off Topic
  4. Darstellung einer Pulsoximetriekurve

NEWS

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    11
    1
    362

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.6k

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    9.5k

Darstellung einer Pulsoximetriekurve

Geplant Angeheftet Gesperrt Verschoben Off Topic
61 Beiträge 5 Kommentatoren 7.9k Aufrufe 4 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • AlexAxelA AlexAxel

    @homoran wie hast du das hinbekommen. Mir reicht ja transparent oder schwarz. Wenn ich background setze, sieht das so aus:

    7273a00b-a1a5-4de6-aae6-8d03ec000d59-grafik.png

    62f0599d-a778-45fe-8e34-0029aadab5b8-grafik.png

    HomoranH Nicht stören
    HomoranH Nicht stören
    Homoran
    Global Moderator Administrators
    schrieb am zuletzt editiert von Homoran
    #52

    @alexaxel sagte in Darstellung einer Pulsoximetriekurve:

    Mir reicht ja transparent

    dann schreib das dahin :grin:
    oder clear

    EDIT:
    Blödsinn, nicht im iFrame widget, sondern im Flot
    Screenshot_20231231-135913_Firefox.jpg

    deswegen fragte ich ja was das "history Widget" sein soll

    kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

    Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

    der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

    AlexAxelA 1 Antwort Letzte Antwort
    0
    • AlexAxelA AlexAxel

      Hallo Leute, ich brauche mal Euer Wissen / Eure Hilfe bei einem Problemchen:

      Ich habe ein fertiges Pulsoximeter via ESP32/Bluetooth/Wifi und MQTT Protokoll angezapft und somit eine "Brücke" gebastelt,um die Werte als Datenpunkte darzustellen. Das klappt soweit auch sehr gut:

      Bildschirmfoto vom 2023-12-24 11-18-46.png

      Nun arbeite ich daran, die Blutdruckkurve, die das Gerät darstellt und als CustomCaracteristics bereit stellt. Naja kurz gesagt ich habe ein Array von ca. 30 bytes, die eine kleine Kurve mit einem Wertebereich von 0-255 darstellen. Also die Daten habe ich auch.

      Meine Defizite liegen eher woanders. Ich finde einfach keine Lösung die Daten schön darzustellen. Habe schon 2 Anätze, die nicht funktionieren:

      1. Schleife in JS bauen, die jedes Byte nacheinander in ein Datenpunkt schreibt und das Livechart schaut auf diesen. Leider sagt der Scripteditor, dass ich den Datenpunkt zu häufig aktualisiere. (ca 1000 mal pro Minute). Das Array wird ca. in 0,5 Sekunden intervall über MQTT geupdated.

      2. Ich erzeuge keine unnötige Umrechnung mit neuen Datenpunkten, sondern nehme gleich das Array und zeichne mit dem HTML objekt und JS die Kurve mit senkrechten Linien selber und rotiere dann die aktuellen Werte. Ich habe angefangen Linien mal zeitlich einzeln darzustellen. ChatGTP hat mir dabei geholfen:

      <!DOCTYPE html>
      <html lang="en">
      <head>
          <meta charset="UTF-8">
          <meta name="viewport" content="width=device-width, initial-scale=1.0">
          <title>Vertical Lines Animation</title>
      </head>
      <body>
          <canvas id="myCanvas" width="200" height="200"></canvas>
      
          <script>
              // JavaScript-Funktion zum Zeichnen von 10 roten senkrechten Linien im Abstand von 10 Pixeln
              function drawVerticalLines() {
                  // Canvas-Element und 2D-Kontext abrufen
                  var canvas = document.getElementById("myCanvas");
                  var ctx = canvas.getContext("2d");
      
                  // Anzahl der Linien und der Abstand zwischen den Linien
                  var numLines = 10;
                  var lineSpacing = 10;
      
                  // Funktion zum Zeichnen einer Linie
                  function drawLine(x) {
                      ctx.beginPath();
                      ctx.moveTo(x, 0);
                      ctx.lineTo(x, canvas.height);
                      ctx.strokeStyle = "red";
                      ctx.stroke();
                  }
      
                  // Funktion zum animierten Zeichnen der Linien
                  function drawLinesSequentially(index) {
                      if (index < numLines) {
                          var x = index * (lineSpacing + 1); // 1 Pixel Lücke zwischen den Linien
                          drawLine(x);
                          setTimeout(function () {
                              drawLinesSequentially(index + 1);
                          }, 1000); // Eine Sekunde Verzögerung zwischen den Linien
                      }
                  }
      
                  // Starte die Animation
                  drawLinesSequentially(0);
              }
      
              // Die Funktion aufrufen, wenn die Seite geladen ist
              window.onload = drawVerticalLines;
          </script>
      </body>
      </html>
      
      

      Leider werden die Striche nicht zeitlich dargestellt.
      Das unglaubliche: Lade ich den gleichen Code auf eine offline HTML Seite vom Desktop, funktioniert es. Ich habe das Gefühl, dass Animationen in HTML mit SetTimeout im IO Broker nicht funktionieren.

      Habt Ihr eine Lösung ? Gerne auch ganz andere Alternativen. Letztendlich soll die View so eine Kurve darstellen, wie ungefähr hier:
      Bildschirmfoto vom 2023-12-24 11-31-23.png

      (Hinweis, ich baue kein Medizinprodukt. Es ist einfach hilfreich im Haushalt, wenn überall Tablets an der Wand hängen und Alexa, ein paar Meldungen macht, wenn der Fingersensor ab und ein paar Werte zu hoch oder niedrig sind. Das Gerät selber hat auch eigene Warnfunktionen).

      Vielen Dank Euch allen !!!

      VG
      Alex

      AlexAxelA Offline
      AlexAxelA Offline
      AlexAxel
      schrieb am zuletzt editiert von
      #53

      :warning: Ich möchte alle Mitlesenden und Begeisternden IOBler noch einmal deutlich daraufhinweisen, dass dies nur für private Zwecke eingesetzt werden darf.

      Ein Produkt, dass für professionelle medizinische Zwecke bestimmt ist, muss dem Medizinprodukte-Gesetzt entsprechen! Die Anforderungen an eine MPG-konforme Lösung ist weit mehr als das bisschen basteln und coden. Also unsere Basteleien bitte nicht im professionellen Bereich, wie in der Pflege und oder in Einrichtungen verwenden! ... und für den privaten Gebrauch immer einen Plan B haben. So alarmiert bei mir immer noch das MPG-Konforme Pulsoximeter mit seinem eigenen Alarmlautsprecher.

      So... das lag mir noch am Herzen... Ich wünsche allen ein Frohen Neues 2024 !! Alex:-)

      1 Antwort Letzte Antwort
      2
      • HomoranH Homoran

        @alexaxel sagte in Darstellung einer Pulsoximetriekurve:

        Mir reicht ja transparent

        dann schreib das dahin :grin:
        oder clear

        EDIT:
        Blödsinn, nicht im iFrame widget, sondern im Flot
        Screenshot_20231231-135913_Firefox.jpg

        deswegen fragte ich ja was das "history Widget" sein soll

        AlexAxelA Offline
        AlexAxelA Offline
        AlexAxel
        schrieb am zuletzt editiert von
        #54

        @homoran Achso du nimmst ein ganz anderes Objekt. Ich hab das hier genommen. Live History Chart:
        c3dd86cf-5640-49f4-960b-4314a18e494d-grafik.png

        Kann Flot auch in Echtzeit die Kurve so schnell zeichnen, dass 2 Kurven pro sekunde gezeichnet werden und diese nach links scrollen ?

        HomoranH 1 Antwort Letzte Antwort
        0
        • AlexAxelA AlexAxel

          @homoran Achso du nimmst ein ganz anderes Objekt. Ich hab das hier genommen. Live History Chart:
          c3dd86cf-5640-49f4-960b-4314a18e494d-grafik.png

          Kann Flot auch in Echtzeit die Kurve so schnell zeichnen, dass 2 Kurven pro sekunde gezeichnet werden und diese nach links scrollen ?

          HomoranH Nicht stören
          HomoranH Nicht stören
          Homoran
          Global Moderator Administrators
          schrieb am zuletzt editiert von Homoran
          #55

          @alexaxel sagte in Darstellung einer Pulsoximetriekurve:

          Kann Flot auch in Echtzeit die Kurve so schnell zeichnen, dass 2 Kurven pro sekunde gezeichnet werden und diese nach links scrollen ?

          hab ich noch nie probiert.
          So schnell steigt der Rheinpegel nicht

          allerdings wird bei der Datenrate die History DB sehr schnell sehr groß

          kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

          Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

          der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

          Ralla66R 1 Antwort Letzte Antwort
          0
          • HomoranH Homoran

            @alexaxel sagte in Darstellung einer Pulsoximetriekurve:

            Kann Flot auch in Echtzeit die Kurve so schnell zeichnen, dass 2 Kurven pro sekunde gezeichnet werden und diese nach links scrollen ?

            hab ich noch nie probiert.
            So schnell steigt der Rheinpegel nicht

            allerdings wird bei der Datenrate die History DB sehr schnell sehr groß

            Ralla66R Offline
            Ralla66R Offline
            Ralla66
            Most Active
            schrieb am zuletzt editiert von Ralla66
            #56

            @homoran sagte in Darstellung einer Pulsoximetriekurve:

            allerdings wird bei der Datenrate die History DB sehr schnell sehr groß

            so war auch mein Gedanke und viel Traffic erzeugt der eigentlich nicht notwendig ist.
            Da wir ja nicht im medizinischen Bereich sind sollten weniger Byte in der Datenübertragung
            reichen.

            HomoranH 1 Antwort Letzte Antwort
            0
            • Ralla66R Ralla66

              @homoran sagte in Darstellung einer Pulsoximetriekurve:

              allerdings wird bei der Datenrate die History DB sehr schnell sehr groß

              so war auch mein Gedanke und viel Traffic erzeugt der eigentlich nicht notwendig ist.
              Da wir ja nicht im medizinischen Bereich sind sollten weniger Byte in der Datenübertragung
              reichen.

              HomoranH Nicht stören
              HomoranH Nicht stören
              Homoran
              Global Moderator Administrators
              schrieb am zuletzt editiert von
              #57

              @ralla66 bleibt außerdem die Frage, ob eine lange Vorhaltezeit notwendig ist.
              Wenn ich nur eine Nacht monitoren will, reicht ein Tag.
              Das ist dann auch nicht wirklich kritisch.

              kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

              Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

              der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

              AlexAxelA Ralla66R 2 Antworten Letzte Antwort
              0
              • HomoranH Homoran

                @ralla66 bleibt außerdem die Frage, ob eine lange Vorhaltezeit notwendig ist.
                Wenn ich nur eine Nacht monitoren will, reicht ein Tag.
                Das ist dann auch nicht wirklich kritisch.

                AlexAxelA Offline
                AlexAxelA Offline
                AlexAxel
                schrieb am zuletzt editiert von
                #58

                @homoran Ich schreibe nur die Frequenz und den O2 Wert in einer externen SQL DB. Das History Chart schaut aber nur auf einem anderen DP, der gar nicht historisch weggeschrieben wird. Das sind also flüchtige Kurvendaten. Quasi immer der Punkt der gemalten Live-Kurve der 4 Takte des Herzens.

                1 Antwort Letzte Antwort
                0
                • HomoranH Homoran

                  @ralla66 bleibt außerdem die Frage, ob eine lange Vorhaltezeit notwendig ist.
                  Wenn ich nur eine Nacht monitoren will, reicht ein Tag.
                  Das ist dann auch nicht wirklich kritisch.

                  Ralla66R Offline
                  Ralla66R Offline
                  Ralla66
                  Most Active
                  schrieb am zuletzt editiert von
                  #59

                  @homoran

                  sehe ich auch so,
                  und wenn sich ein Progger gelangweilt fühlt kann dieser noch einen Code schreiben
                  wo Wifi / Mqtt und Device ID per Gui eingefügt werden kann.
                  Nicht jeder hat / kann mit der Arduino IDE umgehen.
                  So hätten viele User was davon, flashen, Daten eigeben, fertig ist die Laube.

                  Chris 1C 1 Antwort Letzte Antwort
                  1
                  • Ralla66R Ralla66

                    @homoran

                    sehe ich auch so,
                    und wenn sich ein Progger gelangweilt fühlt kann dieser noch einen Code schreiben
                    wo Wifi / Mqtt und Device ID per Gui eingefügt werden kann.
                    Nicht jeder hat / kann mit der Arduino IDE umgehen.
                    So hätten viele User was davon, flashen, Daten eigeben, fertig ist die Laube.

                    Chris 1C Offline
                    Chris 1C Offline
                    Chris 1
                    schrieb am zuletzt editiert von
                    #60

                    Schreibe hier mal 2-Zeiler, um dem Thema zu folgen.

                    Habe seit Weihnachten eine einfache SmartWatch, welche nicht-medizinische Näherungswerte zu Blutdruck, Puls, Haut-Temperatur, Blutsauerstoff etc liefert, welche ich doch gerne statt mittelmäßiger H-Band-App in ioBroker/postgreSQL einpflegen würde. EInfach zur groben Kontrolle, wenn es irgendwo scheinbar starke Abweichungen gibt.

                    Gruss von der Ostsee
                    Chris

                    bpi-m5 (ioBroker), rock3a (postgreSQL), lamobo R1 (OpenWRT), Tasmota-ZB, Tasmota-IR

                    1 Antwort Letzte Antwort
                    0
                    • HomoranH Homoran

                      @ralla66 sagte in Darstellung einer Pulsoximetriekurve:

                      aus einer DB eine Kurve darstellen, siehst du da Möglichkeiten ?

                      nur wenn die Daten über iob geloggt wurden.

                      Aber ich glaube dass diese Frage bereits mal behandelt wurde. Leider weiss ich nicht mit welcher DB und welchem Ergebnis

                      Chris 1C Offline
                      Chris 1C Offline
                      Chris 1
                      schrieb am zuletzt editiert von
                      #61

                      @homoran said in Darstellung einer Pulsoximetriekurve:

                      @ralla66 sagte in Darstellung einer Pulsoximetriekurve:

                      aus einer DB eine Kurve darstellen, siehst du da Möglichkeiten ?
                      nur wenn die Daten über iob geloggt wurden.
                      Aber ich glaube dass diese Frage bereits mal behandelt wurde. Leider weiss ich nicht mit welcher DB und welchem Ergebnis

                      Wäre es nicht sinnvoller die Daten extern ein zu speisen, statt via ioB, um eine korrekte Timestamp zu haben?
                      Wenn ich mich recht entsinne, dann verwendet ioB für die Datenbank (bei mir postgreSQL) den jetzt-Wert, was zu Problemen führt.
                      Ich hatte da Probleme, als ich Vorhersagen & Meßwerte vom BSH OpenData-Server einspeisen wollte.

                      bpi-m5 (ioBroker), rock3a (postgreSQL), lamobo R1 (OpenWRT), Tasmota-ZB, Tasmota-IR

                      1 Antwort Letzte Antwort
                      0
                      Antworten
                      • In einem neuen Thema antworten
                      Anmelden zum Antworten
                      • Älteste zuerst
                      • Neuste zuerst
                      • Meiste Stimmen


                      Support us

                      ioBroker
                      Community Adapters
                      Donate

                      781

                      Online

                      32.5k

                      Benutzer

                      81.8k

                      Themen

                      1.3m

                      Beiträge
                      Community
                      Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                      ioBroker Community 2014-2025
                      logo
                      • Anmelden

                      • Du hast noch kein Konto? Registrieren

                      • Anmelden oder registrieren, um zu suchen
                      • Erster Beitrag
                        Letzter Beitrag
                      0
                      • Home
                      • Aktuell
                      • Tags
                      • Ungelesen 0
                      • Kategorien
                      • Unreplied
                      • Beliebt
                      • GitHub
                      • Docu
                      • Hilfe