Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Visualisierung
    4. Material Design Widgets: JSON Chart Widget

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Material Design Widgets: JSON Chart Widget

    This topic has been deleted. Only users with topic management privileges can see it.
    • B
      BigDragan last edited by BigDragan

      Ich habe auch gleich eine Frage. Könnte das gleiche oder ähnliches Problem wie bei @ofri2607 sein.
      Ich versuche bei meinen Bar Chart die Ränder von den Balken deutlich sichtbar gestalten.
      Dafür habe ich folgende Parameter in die JSON eingefügt.
      "barBorderColor": "#000000",
      "barBorderWidth": 5,
      Es gibt aber keine Veränderung.
      9b4a8196-2cbf-45c3-87f6-8860656e82c9-image.png
      Wenn ich die Monate zurückschalte bis es keine Daten in der Datenbank es gibt, dann sieht man die Veränderung bei der Legende.
      944e3466-d57d-42f9-a2da-ddfe05b901e7-image.png
      Was noch auffällig ist, ist das seltsame Verhalten im Editor. Ich habe das mal mit Handy SLO-MO aufgenommen. Wenn das Widget refresht wird, dann sind die schwarzen Ränder deutlich sichtbar, wenn der Graph skaliert wird, sind die Ränder wieder weg.

      IMB_1lVZ6O.GIF

      Das ist die JSON zum Video:

      {
      	"axisLabels": ["Jan", "Feb", "Mrz", "Apr"],
      	"graphs": [{
      		  "type": "bar",
      		  "data": [40, 22, 160, 92],
      		  "color": "#FF4800",
      		  "barBorderColor": "#000000",
      		  "barBorderWidth": 5,
      		  "legendText": "HZ"
      	}  
      ]
      }
      

      Es scheint schon so, als wenn die Parameter greifen, aber dann doch durch irgendwelche Standardwerte übergebügelt werden.

      Hat jemand eine Erklärung für dieses Phänomen?
      Wird dieses Widget überhaupt noch supportet, weiß das jemand?
      Sonst würde ich diesen Fehler (wenn es sich so bestätigt) bei GitHub in die issues stellen.

      Danke!
      Gruß

      E 1 Reply Last reply Reply Quote 0
      • E
        Eggi1234 @BigDragan last edited by

        Hallo zusammen.
        Irgendwie muss ich mir zu der frühen Stunde die Augen waschen. Aber bei der Suche in den Adaptern wird mir der Material Design Adapter nicht angezeigt.
        Auf welcher Leitung steh ich da grad?

        4d7efe54-3152-4e0b-8fc6-aaaff879fe09-image.png

        sigi234 1 Reply Last reply Reply Quote 0
        • sigi234
          sigi234 Forum Testing Most Active @Eggi1234 last edited by sigi234

          @eggi1234

          Screenshot (341).png

          Wenn installiert Instanz hinzufügen.

          Screenshot (342).png

          E 1 Reply Last reply Reply Quote 0
          • E
            Eggi1234 @sigi234 last edited by

            @sigi234
            Danke. Nun geht's

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

              Hi zusammen,
              ich haben mir ein Json für das Chart (materialdesign) formatiert aber ich bekomme 2-3 Sachen nicht hin, wäre dankbar wenn mir jemand ein Tipp geben kann.

              so schauts bisher aus.
              Bildschirmfoto 2023-11-07 um 23.47.36.png

              • ich möchte gerne jedem balken eine andere Farbe geben, aber ich bekomme es mit der Linie nicht hin... den Farbverlauf hatte ich hinbekommen aber das gefällt mir nicht, aber individuell klappt einfach nicht

              • ich möchte die Linien im Diagramm gerne entfernen

              • ich würde auf den Balken Werte die kw/h anzeigen und die Werte links gerne entfernen.

              Herzlichen Dank im voraus

              
              {
                  "axisLabels": ["Sa", "So", "Mo", "Di", "Mi", "Do", "Fr", "Sa", "So", "Mo"],
              	"graphs": [{
              			"type": "line",
              			"data": [5.7, 9.5, 7.7, 5.9, 7.4, 5.5, 6.7, 9.8, 2, 7.6],
              			"yAxis_id": 0,
                          "yAxis_show": false,
                          "yAxis_gridLines_border_show": false,
                          "yAxis_gridLines_ticks_show": false,
              			"yAxis_gridLines_show": false,
              			"barIsStacked": true,
                          "line_pointSize":3,
                          "line_Thickness":4,
              			"datalabel_show": true,
                          "color": "#ff9900",
                          "datalabel_color": "#000000",
              			"line_UseFillColor": false,
                          "yAxis_gridLines_show": false,
                          "yAxis_appendix": " kw/h",
                          "datalabel_fontFamily": "RobotoCondensed-Light",
              			"datalabel_fontSize": 14
              
               
                          
              	}, {
              		"type": "bar",
              		"barIsStacked": true,
              		"data": [5.7, 9.5, 7.7, 5.9, 7.4, 5.5, 6.7, 9.8, 2, 7.6],
              		"yAxis_id": 0,
              		"barStackId": 0,
                      "datalabel_show": false,
              		"color": "#4f6765",
              		"datalabel_color": "#FFFFFF",
              		"datalabel_align": "start"
              	}
              		]
              	}
              

              edit:
              das mit den Linien habe ich hinbekommen, ich musste die Werte von der "line" zu "bar" verschieben

                          "yAxis_show": false,
                          "yAxis_gridLines_border_show": false,
                          "yAxis_gridLines_ticks_show": false,
              	    "yAxis_gridLines_show": false,
              

              nur noch die Farben...

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

                Ich bräuchte auch mal Hilfe:

                {
                  "graphs": [
                    {
                      "data": [
                        {
                          "t": 1699887600000,
                          "y": 12
                        },
                        {
                          "t": 1699891200000,
                          "y": 13
                        },
                        {
                          "t": 1699894800000,
                          "y": 13
                        },
                        {
                          "t": 1699898400000,
                          "y": 13
                        },
                        {
                          "t": 1699902000000,
                          "y": 13
                        },
                        {
                          "t": 1699905600000,
                          "y": 13
                        },
                        {
                          "t": 1699909200000,
                          "y": 13
                        },
                        {
                          "t": 1699912800000,
                          "y": 13
                        },
                        {
                          "t": 1699916400000,
                          "y": 13
                        },
                        {
                          "t": 1699920000000,
                          "y": 13
                        },
                        {
                          "t": 1699923600000,
                          "y": 12
                        },
                        {
                          "t": 1699927200000,
                          "y": 12
                        },
                        {
                          "t": 1699930800000,
                          "y": 11
                        },
                        {
                          "t": 1699934400000,
                          "y": 11
                        },
                        {
                          "t": 1699938000000,
                          "y": 11
                        },
                        {
                          "t": 1699941600000,
                          "y": 11
                        },
                        {
                          "t": 1699945200000,
                          "y": 10
                        },
                        {
                          "t": 1699948800000,
                          "y": 10
                        },
                        {
                          "t": 1699952400000,
                          "y": 10
                        },
                        {
                          "t": 1699956000000,
                          "y": 11
                        },
                        {
                          "t": 1699959600000,
                          "y": 10
                        },
                        {
                          "t": 1699963200000,
                          "y": 10
                        },
                        {
                          "t": 1699966800000,
                          "y": 10
                        },
                        {
                          "t": 1699970400000,
                          "y": 9
                        },
                        {
                          "t": 1699974000000,
                          "y": 9
                        },
                        {
                          "t": 1699977600000,
                          "y": 9
                        },
                        {
                          "t": 1699981200000,
                          "y": 9
                        },
                        {
                          "t": 1699984800000,
                          "y": 10
                        },
                        {
                          "t": 1699988400000,
                          "y": 10
                        },
                        {
                          "t": 1699992000000,
                          "y": 10
                        },
                        {
                          "t": 1699995600000,
                          "y": 10
                        },
                        {
                          "t": 1699999200000,
                          "y": 10
                        },
                        {
                          "t": 1700002800000,
                          "y": 10
                        },
                        {
                          "t": 1700006400000,
                          "y": 9
                        },
                        {
                          "t": 1700010000000,
                          "y": 9
                        }
                      ],
                      "type": "line",
                      "legendText": "",
                      "tooltip_title": "Temperatur",
                      "tooltip_MaxDigits": 2,
                      "tooltip_AppendText": " °C",
                      "datalabel_color": [
                        "#00731a",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#00731a",
                        "#00731a",
                        "#006a2d",
                        "#006a2d",
                        "#006a2d",
                        "#006a2d",
                        "#006040",
                        "#006040",
                        "#006040",
                        "#006a2d",
                        "#006040",
                        "#006040",
                        "#006040",
                        "#005653",
                        "#005653",
                        "#005653",
                        "#005653",
                        "#006040",
                        "#006040",
                        "#006040",
                        "#006040",
                        "#006040",
                        "#006040",
                        "#005653",
                        "#005653"
                      ],
                      "line_PointColor": [
                        "#00731a",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#00731a",
                        "#00731a",
                        "#006a2d",
                        "#006a2d",
                        "#006a2d",
                        "#006a2d",
                        "#006040",
                        "#006040",
                        "#006040",
                        "#006a2d",
                        "#006040",
                        "#006040",
                        "#006040",
                        "#005653",
                        "#005653",
                        "#005653",
                        "#005653",
                        "#006040",
                        "#006040",
                        "#006040",
                        "#006040",
                        "#006040",
                        "#006040",
                        "#005653",
                        "#005653"
                      ],
                      "line_PointColorBorder": [
                        "#00731a",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#007d06",
                        "#00731a",
                        "#00731a",
                        "#006a2d",
                        "#006a2d",
                        "#006a2d",
                        "#006a2d",
                        "#006040",
                        "#006040",
                        "#006040",
                        "#006a2d",
                        "#006040",
                        "#006040",
                        "#006040",
                        "#005653",
                        "#005653",
                        "#005653",
                        "#005653",
                        "#006040",
                        "#006040",
                        "#006040",
                        "#006040",
                        "#006040",
                        "#006040",
                        "#005653",
                        "#005653"
                      ],
                      "yAxis_show": "false",
                      "yAxis_appendix": " °C",
                      "xAxis_timeFormats": {
                        "millisecond": "H:mm:ss.SSS",
                        "second": "H:mm:ss",
                        "minute": "dd.[\\n]H:mm",
                        "hour": "dd.[\\n]H:mm",
                        "day": "dd[\\n]DD.MM",
                        "week": "dd[\\n]DD.MM",
                        "month": "MMM[\\n]YYYY",
                        "quarter": "[Q]Q - YYYY",
                        "year": "YYYY"
                      }
                    }
                  ]
                }
                

                1bdac7ff-e1d8-46ad-87a8-cf9f0ac6d65a-grafik.png
                Wie bekomme ich da die Tage in Deutsch rein?
                Wie man sieht sind die Daten durch ein Skript als Timestamps hinterlegt.
                Gibts einen Parameter mit dem ich die Locale übergeben kann oder muss ich das Skript umschreiben, um über die axisLabels die entsprechende Beschriftung zu erreichen?

                Edit:

                Das "Problem" scheint bei der Darstellung in Vis 2.0 zu liegen...
                in der 1er wird es ordnungsgemäß dargestellt...

                f5b92253-6766-46c0-a2cb-de1c9a771262-grafik.png

                T 1 Reply Last reply Reply Quote 0
                • T
                  tourer4778 @Boronsbruder last edited by tourer4778

                  Hallo, Das JsonChart ist für mich ganz neu und ich bin etwas am ausprobieren, anhand von Beispielen.
                  Ich würde gerne unten den Zeitstempen auf Tag.Monat ändern, bekomme es aber nicht hin. Wo müsste ich das machen und wie?

                  {
                    "graphs": [
                      {
                        "type": "bar",
                        "barIsStacked": true,
                        "barStackId": 1,
                        "color": "#ff0505",
                        "legendText": "WW",
                        "yAxis_id": 0,
                        "yAxis_show": true,
                        "yAxis_minimumDigits": 0,
                        "yAxis_maximumDigits": 0,
                        "yAxis_appendix": " kW",
                        "yAxis_min": 0,
                        "datalabel_show": true,
                        "datalabel_color": "#ff0505",
                        "line_pointSize": 13,
                        "xAxis_timeFormats": {
                          "day": "MM.TT"
                        },
                        "data": [
                          {
                            "t": 29.11,
                            "y": 2
                          },
                          {
                            "t": 30.11,
                            "y": 3
                          },
                          {
                            "t": 31.11,
                            "y": 5
                          }
                        ]
                      },
                      {
                        "type": "bar",
                        "barIsStacked": true,
                        "barStackId": 1,
                        "color": "#05ff31",
                        "legendText": "HZz",
                        "yAxis_id": 0,
                        "yAxis_show": true,
                        "yAxis_min": 0,
                        "datalabel_show": true,
                        "datalabel_color": "#05ff31",
                        "line_pointSize": 13,
                        "xAxis_timeFormats": {
                          "day": "MM.TT"
                        },
                        "data": [
                          {
                            "t": 29.11,
                            "y": 6
                          },
                          {
                            "t": 30.11,
                            "y": 5
                          },
                          {
                            "t": 31.11,
                            "y": 3
                          }
                        ]
                      }
                    ]
                  }
                  

                  c8ad2ca9-32fe-413c-88a8-878dd77aa940-grafik.png

                  O 1 Reply Last reply Reply Quote 0
                  • O
                    Oli @tourer4778 last edited by

                    @tourer4778
                    Versuche mal "MMM.D"

                    Bin erst wieder nächste Woche am Rechner und könnte erst da nachschauen

                    T Boronsbruder 2 Replies Last reply Reply Quote 0
                    • T
                      tourer4778 @Oli last edited by

                      @oli
                      Hat leider nicht funktioniert

                      1 Reply Last reply Reply Quote 0
                      • Boronsbruder
                        Boronsbruder @Oli last edited by Boronsbruder

                        @oli
                        ich hab bei mir unter xAxis_timeFormats

                        day: "dd[\\n]DD.MM"
                        

                        also bei dir wahrscheinlich dann

                        day: "DD.MM"
                        

                        Moment Time Formats
                        Da findest du die passenden Tokens

                        O T 2 Replies Last reply Reply Quote 0
                        • O
                          Oli @Boronsbruder last edited by

                          @boronsbruder
                          Du hast natürlich recht, so muss es eingetragen werden

                          1 Reply Last reply Reply Quote 0
                          • E
                            Einwurf22 last edited by

                            Hallo.
                            Ich bin noch am Anfang was diesen Adapter betrifft.
                            Ich habe auch kaum Erfahrung was JSON angeht.

                            Besteht die Möglichkeit mit dem Bar Chart Widget mit Datenpunkten ohne JSON das links oben abgebildete Widget nachzubilden.
                            2022-04-23_10-10-06.png

                            Mir fehlt zum einen die Einstellung, abstand von Balken zu Balken und dann auch noch abstand als Doppelbalken (gelb/grau wie abgebildet).
                            Zum anderen, wenn ich versuche einen Rahmen Farbe und Rahmenbreite einzustellen, passiert nichts.
                            160b20e1-a028-46f1-857c-3748652a7bd5-image.png
                            kann mir bitte jemand behilflich sein.
                            Danke!
                            Gruß

                            1 Reply Last reply Reply Quote 0
                            • T
                              tourer4778 @Boronsbruder last edited by

                              @boronsbruder
                              @Oli
                              Erst einmal Danke für die Hilfe.
                              Da ich momentan meine ganze Strucktur ändere, ist mir aufgefallen, das meine History DP alle so abgespeichert werden.

                                {
                                  "val": 9.4,
                                  "ack": 0,
                                  "ts": 1698902401480,
                                  "q": 0,
                                  "c": "script.js.Keller.Heizung",
                                  "user": "system.user.admin",
                                  "from": "system.adapter.history.0"
                                },
                                {
                                  "val": 9.4,
                                  "ack": 0,
                                  "ts": 1698894000262,
                                  "q": 0,
                                  "c": "script.js.Keller.Heizung",
                                  "user": "system.user.admin"
                                }
                              usw...
                              ]
                              

                              Das ist doch schon eine arte Json. Ist es möglich, diese direkt mit dem JsonChart aufzurufen?

                              O 1 Reply Last reply Reply Quote 0
                              • O
                                Oli @tourer4778 last edited by

                                @tourer4778
                                es wurde mal ein Skript erstellt, wie du History Datenpunkte in das JSON Chart Widget bringst.

                                siehe:
                                https://forum.iobroker.net/topic/31871/material-design-widgets-json-chart-widget/5

                                T 1 Reply Last reply Reply Quote 0
                                • T
                                  tourer4778 @Oli last edited by

                                  @oli
                                  id: 'CPU.Auslastung',
                                  id: 'CPU.Durchschnitt',
                                  Das sind ja die beiden History Datenpunkte
                                  Hier kann ich dann meine eintragen, zum beispiel
                                  0_userdata.0.Haus.Stromzähler.History.Verbrauch_Tag

                                  Genau so wie der Ziel DP idTarget: 'IoBroker',
                                  oder ?

                                  Boronsbruder 1 Reply Last reply Reply Quote 0
                                  • Boronsbruder
                                    Boronsbruder @tourer4778 last edited by Boronsbruder

                                    @tourer4778
                                    nope...

                                    idChannel: 'linkeddevices.0.System.LXC.IoBroker' -> '0_userdata.0.Haus.Stromzähler.History'
                                    
                                    id: 'CPU.Auslastung' -> 'Verbrauch_Tag'
                                    

                                    idTarget ist in Kombination mit strukturchannel ( // Name Eures Ziel Datenpunktes, wird aus 'strukturChannel' + 'idDatenpunkt' zusammengesetzt) der Datenpunkt in dem der Json gespeichert wird.
                                    strukturchannel ist auch der Pfad in dem Controlelemente entnommen werden, wie z.B. let idTimeIntervalDatenpunkt = ${strukturChannel}.Control.timeInterval` // Datenpunkt um Zeitinterval bei Graph zu ändern

                                    Anmerkung: Ich habe das Skript nur kurz überflogen... deswegen können die Informationen auch fehlerhaft sein

                                    1 Reply Last reply Reply Quote 0
                                    • V
                                      Vippis last edited by

                                      Hallo,
                                      wie stelle ich es ein, dass die xAxis bei allen JSON Graphs die gleichen Intervalle hat? Ich möchte immer einen Tag von 0 Uhr bis 23 Uhr in 1h Intervallen darstellen. Aber leider werden die Achsen-Intervalle immer nach den Daten erstellt und sind dann immer unterschiedlich?

                                      1 Reply Last reply Reply Quote 0
                                      • S
                                        stenmic @frank2604 last edited by

                                        @frank2604
                                        Hallo, und danke für dein influx2-Script

                                        Ist es möglich, dass das Cahrt eine waagrechte Linie anzeigt mit nur einem Datenpunkt?
                                        Ich möchte mir den max Wert zeichnen lassen.

                                        Falls es über das Widget nicht geht, könnte man eventuell das Script so anpassen, dass es Ergebnisse aus dem Query mit nur einem Datenpunkt nochmals weiterverarbeitet?

                                        So in etwa...

                                        // folgender query erzeugt einen Datenpunkt
                                                    fluxQuery: 
                                                        'from(bucket: "'+buket_Name+'") \
                                                            |> range(start: -1d) \
                                                            |> filter(fn: (r) => r["_measurement"] == "'+measurement_Name+'") \
                                                            |> filter(fn: (r) => r["_field"] == "value") \
                                                            |> max()'
                                        					
                                        // Das ist das Ergebnis im JSON
                                        
                                              "data": [
                                                {
                                                  "t": 1720065360568,
                                                  "y": 16.6
                                                }
                                              ]
                                        	  
                                        // Leider Zeigt das Json Chart keine Linie an mit nur einem Datenpunkt :(
                                        // könnte dein Script das Ergbnis nochmal weiterverarbeiten wenn es nur einen Datenpunkt gibt?
                                        // Beispiel:
                                        
                                              "data": [
                                                {
                                                  "t": ts vom range start (-1d),
                                                  "y": 16.6
                                                },
                                                {
                                                  "t": ts (now),
                                                  "y": 16.6
                                                }		
                                              ]
                                        	  
                                        // das dürfte natürlich nur bei einem Datenpunkt passieren,
                                        // Ergebisse mit mehreren Datenpunkte sollen normal verarbeitet werden.
                                        

                                        Ich kenn mich leider null aus mit JS

                                        frank2604 1 Reply Last reply Reply Quote 0
                                        • frank2604
                                          frank2604 @stenmic last edited by

                                          @stenmic

                                          Hi, da kann ich leider nicht helfen. Ich kann auch kein JS und habe mir das auch nur aus Codeschnipseln zusammengesucht. Sorry!

                                          1 Reply Last reply Reply Quote 0
                                          • S
                                            stenmic last edited by

                                            Moin,
                                            kann ich irgendwie beinflussen wo die "Tage" unten in der X Achse platziert werden?
                                            Ich hätte sie gerne auf der Posittion 12Uhr.

                                            Setze ich xAxis_time_unit auf "day" stehen die Tage auf 0Uhr (wie in der Grafik).
                                            Lasse ich xAxis_time_unit weg, stehen die Tage auf irgendeiner Uhrzeit.

                                            2024-07-23 06 37 09.jpg

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            770
                                            Online

                                            31.7k
                                            Users

                                            79.7k
                                            Topics

                                            1.3m
                                            Posts

                                            vis
                                            36
                                            190
                                            27166
                                            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