Skip to content
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
Logo
  1. ioBroker Community Home
  2. Deutsch
  3. Tester
  4. Test Adapter iQontrol 2.0.x Vis (Entwicklungs-Thread)

NEWS

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

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.8k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.0k

Test Adapter iQontrol 2.0.x Vis (Entwicklungs-Thread)

Scheduled Pinned Locked Moved Tester
appdark-modeiqontrolresponsivevisvisualisierungvisualizationwidget
7.6k Posts 296 Posters 7.0m Views 201 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • s.bormannS s.bormann

    @dslraser sagte in Test Adapter iQontrol 1.2.x:

    @s-bormann sagte in Test Adapter iQontrol 1.2.x:

    Sag mal, kann man mit den neuen ADDITIONAL_CONTROLS nicht so was basteln? Eine value-List, in der man den Sender auswählt, und darunter ein oder mehrere Strings mit den EPG-Infos. Dahinter steckt dann ein Blockly-Script, dass dann die String-Datenpunkte entsprechend der Auswahl der value-List befüllt.

    meinst Du so in etwa ?

    Bildschirmfoto 2020-10-07 um 22.18.34.png

    Ja, das sieht doch ganz gut aus, oder?

    EDIT: übrigens sind beim Start trotz anderer Einstellung alle Sektionen geöffnet

    Bildschirmfoto 2020-10-07 um 22.46.12.png

    Bei mir funktioniert das genau, wie es soll.

    Für die REMOTE-Sektionen wurde jetzt eine eigene Option eingebaut (aktuelle Github-Version).
    VG!

    dslraserD Offline
    dslraserD Offline
    dslraser
    Forum Testing Most Active
    wrote on last edited by
    #3361

    @s-bormann sagte in Test Adapter iQontrol 1.3.x:

    Für die REMOTE-Sektionen wurde jetzt eine eigene Option eingebaut (aktuelle Github-Version).

    Funktioniert auch bei mir, dann werde ich mal alle meine Sender einbauen 👍
    Kannst Du bitte die Beschriftung für "Channels:" auch "umbenennbar" machen.

    Bildschirmfoto 2020-10-09 um 23.03.35.png

    s.bormannS 1 Reply Last reply
    0
    • B Offline
      B Offline
      blackeagle998
      wrote on last edited by
      #3362

      @s-bormann
      Mensch völlig vergessen:
      Ich kann leider keine Wiki Seite anlegen, auch nicht wenn ich eingeloggt bin.
      Habe mir angeschaut welcher Button da sein sollte, der ist definitiv nicht da.

      s.bormannS 1 Reply Last reply
      0
      • I Online
        I Online
        io_laurent
        wrote on last edited by
        #3363

        @s-bormann
        Guten Morgen, ich habe hier eine RGB Lampe, bei der ich über iQontrol die Farbe ändern will. Eine Kachel dafür konnte ich anlegen, allerdings wird mir die Möglichkeit, die Farbe zu ändern, nur manchmal angezeigt. Farbtemperatur und dimmen wird immer angezeigt und ich kann die Werte ändern, Farbe aber nur manchmal. Kannst du mir nen Tipp geben, wie ich die Farbe immer einblenden und ändern kann?

        Und natürlich vielen Dank für deine Arbeit un die kontinuierliche Weiterentwicklung! Du baust so schnell neue Features ein, daß ich nicht nachkomme, alles auszuprobieren.

        Gruß, io_laurent

        M s.bormannS 2 Replies Last reply
        0
        • I io_laurent

          @s-bormann
          Guten Morgen, ich habe hier eine RGB Lampe, bei der ich über iQontrol die Farbe ändern will. Eine Kachel dafür konnte ich anlegen, allerdings wird mir die Möglichkeit, die Farbe zu ändern, nur manchmal angezeigt. Farbtemperatur und dimmen wird immer angezeigt und ich kann die Werte ändern, Farbe aber nur manchmal. Kannst du mir nen Tipp geben, wie ich die Farbe immer einblenden und ändern kann?

          Und natürlich vielen Dank für deine Arbeit un die kontinuierliche Weiterentwicklung! Du baust so schnell neue Features ein, daß ich nicht nachkomme, alles auszuprobieren.

          Gruß, io_laurent

          M Offline
          M Offline
          martinschm
          wrote on last edited by martinschm
          #3364

          @s-bormann : Mir ist mal aufgefallen, das wenn man den Namen einer Ansicht ändert, danach die Verknüpfungen mit der Ansicht nicht mehr funktioniert und man die neu anlegen oder anpassen muß.

          Vermutlich wird der Name als Referenz verwendet. Könnte man das so ändern, das der Name nur noch ein String ist und das Objekt "Ansicht" eine feste unique ID hat?

          Dann bricht nichts wenn man mal was umbenennt.

          s.bormannS 1 Reply Last reply
          0
          • dslraserD dslraser

            @s-bormann sagte in Test Adapter iQontrol 1.3.x:

            Für die REMOTE-Sektionen wurde jetzt eine eigene Option eingebaut (aktuelle Github-Version).

            Funktioniert auch bei mir, dann werde ich mal alle meine Sender einbauen 👍
            Kannst Du bitte die Beschriftung für "Channels:" auch "umbenennbar" machen.

            Bildschirmfoto 2020-10-09 um 23.03.35.png

            s.bormannS Offline
            s.bormannS Offline
            s.bormann
            Most Active
            wrote on last edited by
            #3365

            @dslraser sagte in Test Adapter iQontrol 1.3.x:

            @s-bormann sagte in Test Adapter iQontrol 1.3.x:

            Für die REMOTE-Sektionen wurde jetzt eine eigene Option eingebaut (aktuelle Github-Version).

            Funktioniert auch bei mir, dann werde ich mal alle meine Sender einbauen 👍
            Kannst Du bitte die Beschriftung für "Channels:" auch "umbenennbar" machen.

            Bildschirmfoto 2020-10-09 um 23.03.35.png

            Ist es schon. Guck noch mal in den Optionen. LG

            K 1 Reply Last reply
            0
            • B blackeagle998

              @s-bormann
              Mensch völlig vergessen:
              Ich kann leider keine Wiki Seite anlegen, auch nicht wenn ich eingeloggt bin.
              Habe mir angeschaut welcher Button da sein sollte, der ist definitiv nicht da.

              s.bormannS Offline
              s.bormannS Offline
              s.bormann
              Most Active
              wrote on last edited by
              #3366

              @blackeagle998 sagte in Test Adapter iQontrol 1.3.x:

              @s-bormann
              Mensch völlig vergessen:
              Ich kann leider keine Wiki Seite anlegen, auch nicht wenn ich eingeloggt bin.
              Habe mir angeschaut welcher Button da sein sollte, der ist definitiv nicht da.

              Hmm, komisch, eigentlich sollte es laut Github freigeschaltet sein.

              Also Workaround kannst Du vielleicht einfach ein Issue anlegen, dann kopiere ich das von Hand in das Wiki, sobald Du das "Go" gibst.

              1 Reply Last reply
              0
              • M martinschm

                @s-bormann : Mir ist mal aufgefallen, das wenn man den Namen einer Ansicht ändert, danach die Verknüpfungen mit der Ansicht nicht mehr funktioniert und man die neu anlegen oder anpassen muß.

                Vermutlich wird der Name als Referenz verwendet. Könnte man das so ändern, das der Name nur noch ein String ist und das Objekt "Ansicht" eine feste unique ID hat?

                Dann bricht nichts wenn man mal was umbenennt.

                s.bormannS Offline
                s.bormannS Offline
                s.bormann
                Most Active
                wrote on last edited by
                #3367

                @martinschm sagte in Test Adapter iQontrol 1.3.x:

                @s-bormann : Mir ist mal aufgefallen, das wenn man den Namen einer Ansicht ändert, danach die Verknüpfungen mit der Ansicht nicht mehr funktioniert und man die neu anlegen oder anpassen muß.

                Vermutlich wird der Name als Referenz verwendet. Könnte man das so ändern, das der Name nur noch ein String ist und das Objekt "Ansicht" eine feste unique ID hat?

                Dann bricht nichts wenn man mal was umbenennt.

                Eigentlich sollte er das automatisch anpassen. Habe das auch gerade noch mal getestet, bei mir macht er das auch korrekt. Wenn es bei Dir weiter nicht geht, dann mach doch mal die F12-Konsole auf während des Umbenennens und schau, ob es Fehlermeldungen gibt VG

                M 1 Reply Last reply
                0
                • I io_laurent

                  @s-bormann
                  Guten Morgen, ich habe hier eine RGB Lampe, bei der ich über iQontrol die Farbe ändern will. Eine Kachel dafür konnte ich anlegen, allerdings wird mir die Möglichkeit, die Farbe zu ändern, nur manchmal angezeigt. Farbtemperatur und dimmen wird immer angezeigt und ich kann die Werte ändern, Farbe aber nur manchmal. Kannst du mir nen Tipp geben, wie ich die Farbe immer einblenden und ändern kann?

                  Und natürlich vielen Dank für deine Arbeit un die kontinuierliche Weiterentwicklung! Du baust so schnell neue Features ein, daß ich nicht nachkomme, alles auszuprobieren.

                  Gruß, io_laurent

                  s.bormannS Offline
                  s.bormannS Offline
                  s.bormann
                  Most Active
                  wrote on last edited by
                  #3368

                  @io_laurent sagte in Test Adapter iQontrol 1.3.x:

                  @s-bormann
                  Guten Morgen, ich habe hier eine RGB Lampe, bei der ich über iQontrol die Farbe ändern will. Eine Kachel dafür konnte ich anlegen, allerdings wird mir die Möglichkeit, die Farbe zu ändern, nur manchmal angezeigt. Farbtemperatur und dimmen wird immer angezeigt und ich kann die Werte ändern, Farbe aber nur manchmal. Kannst du mir nen Tipp geben, wie ich die Farbe immer einblenden und ändern kann?

                  Und natürlich vielen Dank für deine Arbeit un die kontinuierliche Weiterentwicklung! Du baust so schnell neue Features ein, daß ich nicht nachkomme, alles auszuprobieren.

                  Gruß, io_laurent

                  Hi,
                  bitte Logs aus der Entwickerkonsole schicken, einmal wenn es geht und einmal wenn es nicht geht, damit man vergleichen kann. Bitte auch einen Screenshot von der Konfiguration und den RAW der verwendeten Datenpunkte.
                  VG!

                  1 Reply Last reply
                  0
                  • s.bormannS Offline
                    s.bormannS Offline
                    s.bormann
                    Most Active
                    wrote on last edited by
                    #3369

                    Für alle Widget-Entwickler, z.B. @blackeagle998 oder @dslraser und alle Interessierten: Es gibt

                    Neues zu Widgets:
                    Die Plattform zur Entwicklung von Widgets wächst so langsam. Was nun mit der aktuellen Github-Version geht, ist folgendes:

                    • Man kann im Unterordner /userwidgets HTML, CSS und JS-Dateien erstellen oder hochladen und (mit Click auf das Datei-Icon) auch direkt bearbeiten

                    • Wenn man im head-Teil der Widget-HTML-Seite einen Meta-Tag mit dem Schema
                      <meta name="widget-datapoint" content="postMessageTest.MyState" data-type="string" data-role="text" />
                      einfügt, erstellt iQontrol den Datenpunkt iqontrol.<instanz>.Widgets.postMessageTest.MyState

                      (der Datenpunkt wird aber nur erstellt, wenn man das Widget auch als URL oder BACKGROUND_URL bei einem seiner Gerätekacheln angegeben hat. Weitere Konfigurationen wie z.B. data-unit stehen in der Readme)

                    • Um das Widget mit diesem Datenpunkt kommunizieren zu lassen, kann man die postMessage-Kommunikation nutzen. Diese wurde um die Befehle setWidgetState, getWidgetState und getWidgetStateSubscribed ergänzt (siehe Readme, hier findet sich auch eine Beispiel-Datei)

                    Was ist der Plan?
                    Die Idee dahinter wäre, dass wir hier zusammen neue Widgets erstellen und die schon bestehenden tollen Widgets so umgestalten, dass sie komplett unabhängig von externen Datenpunkten und externen Scripten werden.

                    Sprich: Alle Logik (javascript etc.) sollte in die Widget-Webseite direkt eingebunden werden, so dass man keine externen Scripte mehr im Javascript-Adapter erstellen muss. Die noch benötigten Datenpunkte kann sich das Widget dann über den oben beschriebenen meta-Tag selbst erstellen.

                    Ich plane auch noch, ein paar weitere Meta-Tags hinzuzufügen, mit dem sich das Widget seine Gerätekachel selbst konfigurieren kann (z.B. die Größe der Kachel, Icon etc.). Damit könnte dann z.B. auch eine "Widget hier hinzufügen"-Funktion bespielt werden. So könnte auch ein Meta-Tag mit einem Info-Text, der beim Hinzufügen angezeigt wird ganz nützlich sein (z.B. für Hilfestellungen oder Credits / Copyright des Erstellers etc.).

                    Wenn dann damit gute und autark funktionierende Widgets entstanden sind, können diese fest in iQontrol integriert werden und damit allen auf einfache Weise zugänglich gemacht werden.

                    Viel Spaß beim Testen und Entwickeln 🙂
                    VG

                    B 1 Reply Last reply
                    6
                    • s.bormannS s.bormann

                      Für alle Widget-Entwickler, z.B. @blackeagle998 oder @dslraser und alle Interessierten: Es gibt

                      Neues zu Widgets:
                      Die Plattform zur Entwicklung von Widgets wächst so langsam. Was nun mit der aktuellen Github-Version geht, ist folgendes:

                      • Man kann im Unterordner /userwidgets HTML, CSS und JS-Dateien erstellen oder hochladen und (mit Click auf das Datei-Icon) auch direkt bearbeiten

                      • Wenn man im head-Teil der Widget-HTML-Seite einen Meta-Tag mit dem Schema
                        <meta name="widget-datapoint" content="postMessageTest.MyState" data-type="string" data-role="text" />
                        einfügt, erstellt iQontrol den Datenpunkt iqontrol.<instanz>.Widgets.postMessageTest.MyState

                        (der Datenpunkt wird aber nur erstellt, wenn man das Widget auch als URL oder BACKGROUND_URL bei einem seiner Gerätekacheln angegeben hat. Weitere Konfigurationen wie z.B. data-unit stehen in der Readme)

                      • Um das Widget mit diesem Datenpunkt kommunizieren zu lassen, kann man die postMessage-Kommunikation nutzen. Diese wurde um die Befehle setWidgetState, getWidgetState und getWidgetStateSubscribed ergänzt (siehe Readme, hier findet sich auch eine Beispiel-Datei)

                      Was ist der Plan?
                      Die Idee dahinter wäre, dass wir hier zusammen neue Widgets erstellen und die schon bestehenden tollen Widgets so umgestalten, dass sie komplett unabhängig von externen Datenpunkten und externen Scripten werden.

                      Sprich: Alle Logik (javascript etc.) sollte in die Widget-Webseite direkt eingebunden werden, so dass man keine externen Scripte mehr im Javascript-Adapter erstellen muss. Die noch benötigten Datenpunkte kann sich das Widget dann über den oben beschriebenen meta-Tag selbst erstellen.

                      Ich plane auch noch, ein paar weitere Meta-Tags hinzuzufügen, mit dem sich das Widget seine Gerätekachel selbst konfigurieren kann (z.B. die Größe der Kachel, Icon etc.). Damit könnte dann z.B. auch eine "Widget hier hinzufügen"-Funktion bespielt werden. So könnte auch ein Meta-Tag mit einem Info-Text, der beim Hinzufügen angezeigt wird ganz nützlich sein (z.B. für Hilfestellungen oder Credits / Copyright des Erstellers etc.).

                      Wenn dann damit gute und autark funktionierende Widgets entstanden sind, können diese fest in iQontrol integriert werden und damit allen auf einfache Weise zugänglich gemacht werden.

                      Viel Spaß beim Testen und Entwickeln 🙂
                      VG

                      B Offline
                      B Offline
                      blackeagle998
                      wrote on last edited by
                      #3370

                      @s-bormann
                      Hallo Sebastian, das hört sich super an und ich bin gespannt darauf, das auszuprobieren.
                      Mir drängen sich aber zwei Fragen auf, wo mir nicht klar ist, wie das zu realisieren ist:

                      1. Ich baue die HTML Inhalte in Abhängigkeit verschiedener Datenpunkte zusammen. Beispielsweise wird eine Staubsauger Fehlermeldung nur angezeigt, wenn der entsprechende Datenpunkt auch auf Fehler steht.
                        Ich kann doch keine HTML Datei mit if/then/else erstellen oder?

                      2. Ich aktualisiere die HTML Erstellung in Abhängigkeit verschiedener Datenpunkte. Ändert sich irgendein Datenpunkt, der für das HTML relevant ist, wird der gesamte HTML Inhalt neu geschrieben.
                        Wie stelle ich zukünftig diese Subscription her, wenn ich kein externes Skript nutzen soll?

                      s.bormannS 1 Reply Last reply
                      0
                      • B blackeagle998

                        @s-bormann
                        Hallo Sebastian, das hört sich super an und ich bin gespannt darauf, das auszuprobieren.
                        Mir drängen sich aber zwei Fragen auf, wo mir nicht klar ist, wie das zu realisieren ist:

                        1. Ich baue die HTML Inhalte in Abhängigkeit verschiedener Datenpunkte zusammen. Beispielsweise wird eine Staubsauger Fehlermeldung nur angezeigt, wenn der entsprechende Datenpunkt auch auf Fehler steht.
                          Ich kann doch keine HTML Datei mit if/then/else erstellen oder?

                        2. Ich aktualisiere die HTML Erstellung in Abhängigkeit verschiedener Datenpunkte. Ändert sich irgendein Datenpunkt, der für das HTML relevant ist, wird der gesamte HTML Inhalt neu geschrieben.
                          Wie stelle ich zukünftig diese Subscription her, wenn ich kein externes Skript nutzen soll?

                        s.bormannS Offline
                        s.bormannS Offline
                        s.bormann
                        Most Active
                        wrote on last edited by
                        #3371

                        @blackeagle998 sagte in Test Adapter iQontrol 1.3.x:

                        @s-bormann
                        Hallo Sebastian, das hört sich super an und ich bin gespannt darauf, das auszuprobieren.
                        Mir drängen sich aber zwei Fragen auf, wo mir nicht klar ist, wie das zu realisieren ist:

                        1. Ich baue die HTML Inhalte in Abhängigkeit verschiedener Datenpunkte zusammen. Beispielsweise wird eine Staubsauger Fehlermeldung nur angezeigt, wenn der entsprechende Datenpunkt auch auf Fehler steht.
                          Ich kann doch keine HTML Datei mit if/then/else erstellen oder?

                        2. Ich aktualisiere die HTML Erstellung in Abhängigkeit verschiedener Datenpunkte. Ändert sich irgendein Datenpunkt, der für das HTML relevant ist, wird der gesamte HTML Inhalt neu geschrieben.
                          Wie stelle ich zukünftig diese Subscription her, wenn ich kein externes Skript nutzen soll?

                        Man nutzt dynamische Bereiche auf der Seite. Z.b. mit <div id="Nachricht"></div> und/oder analog mit <span id="mySpan"></span>-Tags.

                        Im javascript-Teil bespielt man die dann mit Inhalten, z.B. mit document.getElementById('Nachricht').innerHTML = "<h1>Irgendwas</h1><br>Text"

                        Abhängig von den Widget-Datenpunkten geht das dann mit der postMessage-Kommunikation z.B. so:

                        <script type="text/javascript">    
                        	//send postMessages
                        	function sendPostMessage(command, stateId, value){
                        		message = { command: command, stateId: stateId, value: value };
                        		window.parent.postMessage(message, "*");
                        	}
                        
                        	//receive postMessages
                        	window.addEventListener("message", receivePostMessage, false);
                        	function receivePostMessage(event) { //event = {data: message data, origin: url of origin, source: id of sending element}
                        		if(event.data && event.data.command) switch(event.data.command){
                        			case "getState":
                        				if(event.data.stateId && event.data.value) switch(event.data.stateId){
                        					case "Testwidget.MESSAGE":
                        						document.getElementById('Nachricht').innerHTML = "<b>Nachricht erhalten:</b> " + JSON.stringify(event.data.value);
                        					break;
                        					
                        					case "Testwidget.ANOTHER_DATAPONT":
                        						if(event.data.value == "Hallo")
                        							document.getElementById('mySpan').innerHTML = "Es wurde Hallo gesagt <img src='smiley.png'>";
                        						} else {
                        							document.getElementById('mySpan').innerHTML = "Keiner grüßt mehr ordentlich <img src='sad.png'>";
                        						}
                        					break;
                        				}
                        			break;
                        		}
                        	}
                        	
                        	//Subscribe to WidgetDatapoints now
                        	sendPostMessage("getWidgetStateSubscribed", "Testwidget.MESSAGE");
                        	sendPostMessage("getWidgetStateSubscribed", "Testwidget.ANOTHER_DATAPONT");
                        </script>
                        

                        Auf Grund der Uhrzeit habe ich es nicht mehr testen können, aber zumindest so in der Art muss es gehen.
                        LG

                        1 Reply Last reply
                        1
                        • s.bormannS s.bormann

                          @martinschm sagte in Test Adapter iQontrol 1.3.x:

                          @s-bormann : Mir ist mal aufgefallen, das wenn man den Namen einer Ansicht ändert, danach die Verknüpfungen mit der Ansicht nicht mehr funktioniert und man die neu anlegen oder anpassen muß.

                          Vermutlich wird der Name als Referenz verwendet. Könnte man das so ändern, das der Name nur noch ein String ist und das Objekt "Ansicht" eine feste unique ID hat?

                          Dann bricht nichts wenn man mal was umbenennt.

                          Eigentlich sollte er das automatisch anpassen. Habe das auch gerade noch mal getestet, bei mir macht er das auch korrekt. Wenn es bei Dir weiter nicht geht, dann mach doch mal die F12-Konsole auf während des Umbenennens und schau, ob es Fehlermeldungen gibt VG

                          M Offline
                          M Offline
                          martinschm
                          wrote on last edited by martinschm
                          #3372

                          @s-bormann said in Test Adapter iQontrol 1.3.x:

                          @martinschm sagte in Test Adapter iQontrol 1.3.x:

                          @s-bormann : Mir ist mal aufgefallen, das wenn man den Namen einer Ansicht ändert, danach die Verknüpfungen mit der Ansicht nicht mehr funktioniert und man die neu anlegen oder anpassen muß.

                          Vermutlich wird der Name als Referenz verwendet. Könnte man das so ändern, das der Name nur noch ein String ist und das Objekt "Ansicht" eine feste unique ID hat?

                          Dann bricht nichts wenn man mal was umbenennt.

                          Eigentlich sollte er das automatisch anpassen. Habe das auch gerade noch mal getestet, bei mir macht er das auch korrekt. Wenn es bei Dir weiter nicht geht, dann mach doch mal die F12-Konsole auf während des Umbenennens und schau, ob es Fehlermeldungen gibt VG

                          Hi, hab es grade testet. Sobald ich den Namen der Ansicht ändere steht bei der Ansicht auf die ich verweise nichts mehr drin (hier Feuer Wasser Alarm)

                          ae474fb0-4149-4ce1-b0c9-6b7ab6089779-image.png

                          Wenn ich umbenenne und dann auf Speichern klicke sehe ich in der Entwicklerkonsole keine Fehlermeldungen.

                          Ich hab aber noch diesen Eintrag gefunden (removed dead link):
                          0fc378b5-94d5-4e68-973b-6931347c358d-image.png

                          Es wird also gelöscht und nicht umgehangen.

                          s.bormannS 1 Reply Last reply
                          0
                          • dslraserD dslraser

                            @s-bormann sagte in Test Adapter iQontrol 1.2.x:

                            @blackeagle998 Sag mal, mir kam gerade der Gedanke, dass man ja auch einige beliebte Widgets fest in iQontrol einbauen könnte. Da ich Dein Widget richtig gut finde, könnte man z.B. damit mal starten. @dslraser hat auch schon einiges in diese Richtung programmiert. Dazu müsste man zwar Dein Script noch mal ein wenig abwandeln, so dass es ohne den javascript-Adapter auskommt (ich denke, das müsste eigentlich gehen - iQontrol müsste dann die benötigten Konfigurations-Datenpunkte anlegen und alles, was Script ist, müsste in der Widget-Webseite selbst laufen) - aber das Grundgerüst, Design, Idee etc. könnte man komplett übernehmen. Hättest Du da grundsätzlich Interesse dran?

                            (Ist erst mal nur ein Gedankenspiel und erfordert noch etwas Zeit - aber man muss ja Pläne für die kalte Jahreszeit haben 🙂 )

                            Einen Wunsch hätte ich da direkt noch...😊
                            Du könntest ein Widget von/für openstreetmap einbauen. Ein schönes Beispiel hat hier der Adapter jarvis. Das hat mir schön länger gefehlt, aber das sollte jetzt mit den ganzen Kacheln möglich sein, oder ?
                            Hier gibt es sogar fertige Sachen. https://leafletjs.com/
                            Fertige Koordinaten bekommt man von anderen Adaptern. Es wäre schön, dort mehrere Benutzer "anspringen" zu können. Verschiedene Symbole dazu wären auch schön.

                            Beispiel :
                            Screenshot_20200928-171055_Chrome.jpg

                            Hier noch ein Basis html dazu (aber das geht viel besser)

                            <!DOCTYPE html>
                            <html lang="de">
                              <head>
                                 <meta charset="UTF-8">
                                 <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no" />
                                 <title>HowTo: Mini-Beispiel "Leaflet Karte mit Marker"</title>
                                 <!-- leaflet.css und leaflet.js von externer Quelle einbinden -->
                                 <link rel="stylesheet" href="https://unpkg.com/leaflet@1.4.0/dist/leaflet.css" />
                                 <script src="https://unpkg.com/leaflet@1.4.0/dist/leaflet.js"></script>
                              </head>
                              <body>
                                 <div id='meineKarte' style='height: 800px; width: 100%;'></div>
                                 <!-- OSM-Basiskarte einfügen und zentrieren -->
                                 <script type='text/javascript'>
                                    var Karte = L.map('meineKarte').setView([52.521918,13.413215], 11);
                                    L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
                                    'attribution':  'Kartendaten &copy; <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a> Mitwirkende',
                                    'useCache': true
                                    }).addTo(Karte);
                                 </script>
                                 <!-- Marker einfügen -->
                                 <script>
                                    var marker = L.marker([52.518620,13.376187]).addTo(Karte);
                                 </script>
                              </body>
                            </html>
                            

                            EDIT: wenn Du das html in eine leere Datei einfügst und speicherst und dann mit einem Browser öffnest, erscheint schon eine Karte. Die Koordinaten habe ich mal verändert, ich wollte nicht, das direkt meine Anschrift angezeigt wird...😲

                            EDIT:
                            für die Koordinaten nutze ich diesen Adapter
                            https://github.com/t4qjXH8N/ioBroker.google-sharedlocations/blob/master/README.md

                            s.bormannS Offline
                            s.bormannS Offline
                            s.bormann
                            Most Active
                            wrote on last edited by s.bormann
                            #3373

                            @dslraser sagte in Test Adapter iQontrol 1.3.x:

                            @s-bormann sagte in Test Adapter iQontrol 1.2.x:

                            @blackeagle998 Sag mal, mir kam gerade der Gedanke, dass man ja auch einige beliebte Widgets fest in iQontrol einbauen könnte. Da ich Dein Widget richtig gut finde, könnte man z.B. damit mal starten. @dslraser hat auch schon einiges in diese Richtung programmiert. Dazu müsste man zwar Dein Script noch mal ein wenig abwandeln, so dass es ohne den javascript-Adapter auskommt (ich denke, das müsste eigentlich gehen - iQontrol müsste dann die benötigten Konfigurations-Datenpunkte anlegen und alles, was Script ist, müsste in der Widget-Webseite selbst laufen) - aber das Grundgerüst, Design, Idee etc. könnte man komplett übernehmen. Hättest Du da grundsätzlich Interesse dran?

                            (Ist erst mal nur ein Gedankenspiel und erfordert noch etwas Zeit - aber man muss ja Pläne für die kalte Jahreszeit haben 🙂 )

                            Einen Wunsch hätte ich da direkt noch...😊
                            Du könntest ein Widget von/für openstreetmap einbauen. Ein schönes Beispiel hat hier der Adapter jarvis. Das hat mir schön länger gefehlt, aber das sollte jetzt mit den ganzen Kacheln möglich sein, oder ?
                            Hier gibt es sogar fertige Sachen. https://leafletjs.com/
                            Fertige Koordinaten bekommt man von anderen Adaptern. Es wäre schön, dort mehrere Benutzer "anspringen" zu können. Verschiedene Symbole dazu wären auch schön.

                            Beispiel :
                            Screenshot_20200928-171055_Chrome.jpg

                            Hier noch ein Basis html dazu (aber das geht viel besser)

                            <!DOCTYPE html>
                            <html lang="de">
                              <head>
                                 <meta charset="UTF-8">
                                 <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no" />
                                 <title>HowTo: Mini-Beispiel "Leaflet Karte mit Marker"</title>
                                 <!-- leaflet.css und leaflet.js von externer Quelle einbinden -->
                                 <link rel="stylesheet" href="https://unpkg.com/leaflet@1.4.0/dist/leaflet.css" />
                                 <script src="https://unpkg.com/leaflet@1.4.0/dist/leaflet.js"></script>
                              </head>
                              <body>
                                 <div id='meineKarte' style='height: 800px; width: 100%;'></div>
                                 <!-- OSM-Basiskarte einfügen und zentrieren -->
                                 <script type='text/javascript'>
                                    var Karte = L.map('meineKarte').setView([52.521918,13.413215], 11);
                                    L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
                                    'attribution':  'Kartendaten &copy; <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a> Mitwirkende',
                                    'useCache': true
                                    }).addTo(Karte);
                                 </script>
                                 <!-- Marker einfügen -->
                                 <script>
                                    var marker = L.marker([52.518620,13.376187]).addTo(Karte);
                                 </script>
                              </body>
                            </html>
                            

                            EDIT: wenn Du das html in eine leere Datei einfügst und speicherst und dann mit einem Browser öffnest, erscheint schon eine Karte. Die Koordinaten habe ich mal verändert, ich wollte nicht, das direkt meine Anschrift angezeigt wird...😲

                            EDIT:
                            für die Koordinaten nutze ich diesen Adapter
                            https://github.com/t4qjXH8N/ioBroker.google-sharedlocations/blob/master/README.md

                            Hi,

                            hier mal ein erster Entwurf (quasi eine Machbarkeits-Studie 🙂 ) zum Thema Widget und OpenStreetMap/Leaflet.

                            Die folgende Datei in das Verzeichnis /userwidgets/Map hochladen (geht nur mit der aktuellen Github-Version. Das Verzeichnis muss erst angelegt werden).

                            map.html (edit: korrigierte Version der Datei, Rundungsfehler behoben)

                            Dann ein Widget erstellen und die Datei als BACKGROUND_URL angeben.

                            In den Optionen unter URL/HTML die Option Erlaube postMessage-Kommunikation für BACKGROUND_URL/HTML einschalten.

                            iQontrol erzeugt dann die Datenpunkte iqontrol.0.Widgets.Map.Position.latitude, .altitude und .zoom, mit denen man die Position der Karte festlegen kann.

                            Mehr geht erst mal noch nicht, aber ich würde mich schon mal freuen, wenn ich Rückmeldung bekäme, dass das so weit bei Euch funktioniert. Dann kann man weitere Funktionen einbauen.

                            VG!

                            dslraserD 1 Reply Last reply
                            0
                            • M martinschm

                              @s-bormann said in Test Adapter iQontrol 1.3.x:

                              @martinschm sagte in Test Adapter iQontrol 1.3.x:

                              @s-bormann : Mir ist mal aufgefallen, das wenn man den Namen einer Ansicht ändert, danach die Verknüpfungen mit der Ansicht nicht mehr funktioniert und man die neu anlegen oder anpassen muß.

                              Vermutlich wird der Name als Referenz verwendet. Könnte man das so ändern, das der Name nur noch ein String ist und das Objekt "Ansicht" eine feste unique ID hat?

                              Dann bricht nichts wenn man mal was umbenennt.

                              Eigentlich sollte er das automatisch anpassen. Habe das auch gerade noch mal getestet, bei mir macht er das auch korrekt. Wenn es bei Dir weiter nicht geht, dann mach doch mal die F12-Konsole auf während des Umbenennens und schau, ob es Fehlermeldungen gibt VG

                              Hi, hab es grade testet. Sobald ich den Namen der Ansicht ändere steht bei der Ansicht auf die ich verweise nichts mehr drin (hier Feuer Wasser Alarm)

                              ae474fb0-4149-4ce1-b0c9-6b7ab6089779-image.png

                              Wenn ich umbenenne und dann auf Speichern klicke sehe ich in der Entwicklerkonsole keine Fehlermeldungen.

                              Ich hab aber noch diesen Eintrag gefunden (removed dead link):
                              0fc378b5-94d5-4e68-973b-6931347c358d-image.png

                              Es wird also gelöscht und nicht umgehangen.

                              s.bormannS Offline
                              s.bormannS Offline
                              s.bormann
                              Most Active
                              wrote on last edited by
                              #3374

                              @martinschm sagte in Test Adapter iQontrol 1.3.x:

                              @s-bormann said in Test Adapter iQontrol 1.3.x:

                              @martinschm sagte in Test Adapter iQontrol 1.3.x:

                              @s-bormann : Mir ist mal aufgefallen, das wenn man den Namen einer Ansicht ändert, danach die Verknüpfungen mit der Ansicht nicht mehr funktioniert und man die neu anlegen oder anpassen muß.

                              Vermutlich wird der Name als Referenz verwendet. Könnte man das so ändern, das der Name nur noch ein String ist und das Objekt "Ansicht" eine feste unique ID hat?

                              Dann bricht nichts wenn man mal was umbenennt.

                              Eigentlich sollte er das automatisch anpassen. Habe das auch gerade noch mal getestet, bei mir macht er das auch korrekt. Wenn es bei Dir weiter nicht geht, dann mach doch mal die F12-Konsole auf während des Umbenennens und schau, ob es Fehlermeldungen gibt VG

                              Hi, hab es grade testet. Sobald ich den Namen der Ansicht ändere steht bei der Ansicht auf die ich verweise nichts mehr drin (hier Feuer Wasser Alarm)

                              ae474fb0-4149-4ce1-b0c9-6b7ab6089779-image.png

                              Wenn ich umbenenne und dann auf Speichern klicke sehe ich in der Entwicklerkonsole keine Fehlermeldungen.

                              Ich hab aber noch diesen Eintrag gefunden (removed dead link):
                              0fc378b5-94d5-4e68-973b-6931347c358d-image.png

                              Es wird also gelöscht und nicht umgehangen.

                              Es tut mir wirklich leid, bei mir funktioniert es. Habe es auch gerade noch mal mit einem Leerzeichen im Namen versucht - klappt aber auch. Ich habe wirklich keine Ahnung, woran das liegen könnte, sorry.

                              M 1 Reply Last reply
                              0
                              • s.bormannS s.bormann

                                @dslraser sagte in Test Adapter iQontrol 1.3.x:

                                @s-bormann sagte in Test Adapter iQontrol 1.2.x:

                                @blackeagle998 Sag mal, mir kam gerade der Gedanke, dass man ja auch einige beliebte Widgets fest in iQontrol einbauen könnte. Da ich Dein Widget richtig gut finde, könnte man z.B. damit mal starten. @dslraser hat auch schon einiges in diese Richtung programmiert. Dazu müsste man zwar Dein Script noch mal ein wenig abwandeln, so dass es ohne den javascript-Adapter auskommt (ich denke, das müsste eigentlich gehen - iQontrol müsste dann die benötigten Konfigurations-Datenpunkte anlegen und alles, was Script ist, müsste in der Widget-Webseite selbst laufen) - aber das Grundgerüst, Design, Idee etc. könnte man komplett übernehmen. Hättest Du da grundsätzlich Interesse dran?

                                (Ist erst mal nur ein Gedankenspiel und erfordert noch etwas Zeit - aber man muss ja Pläne für die kalte Jahreszeit haben 🙂 )

                                Einen Wunsch hätte ich da direkt noch...😊
                                Du könntest ein Widget von/für openstreetmap einbauen. Ein schönes Beispiel hat hier der Adapter jarvis. Das hat mir schön länger gefehlt, aber das sollte jetzt mit den ganzen Kacheln möglich sein, oder ?
                                Hier gibt es sogar fertige Sachen. https://leafletjs.com/
                                Fertige Koordinaten bekommt man von anderen Adaptern. Es wäre schön, dort mehrere Benutzer "anspringen" zu können. Verschiedene Symbole dazu wären auch schön.

                                Beispiel :
                                Screenshot_20200928-171055_Chrome.jpg

                                Hier noch ein Basis html dazu (aber das geht viel besser)

                                <!DOCTYPE html>
                                <html lang="de">
                                  <head>
                                     <meta charset="UTF-8">
                                     <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no" />
                                     <title>HowTo: Mini-Beispiel "Leaflet Karte mit Marker"</title>
                                     <!-- leaflet.css und leaflet.js von externer Quelle einbinden -->
                                     <link rel="stylesheet" href="https://unpkg.com/leaflet@1.4.0/dist/leaflet.css" />
                                     <script src="https://unpkg.com/leaflet@1.4.0/dist/leaflet.js"></script>
                                  </head>
                                  <body>
                                     <div id='meineKarte' style='height: 800px; width: 100%;'></div>
                                     <!-- OSM-Basiskarte einfügen und zentrieren -->
                                     <script type='text/javascript'>
                                        var Karte = L.map('meineKarte').setView([52.521918,13.413215], 11);
                                        L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
                                        'attribution':  'Kartendaten &copy; <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a> Mitwirkende',
                                        'useCache': true
                                        }).addTo(Karte);
                                     </script>
                                     <!-- Marker einfügen -->
                                     <script>
                                        var marker = L.marker([52.518620,13.376187]).addTo(Karte);
                                     </script>
                                  </body>
                                </html>
                                

                                EDIT: wenn Du das html in eine leere Datei einfügst und speicherst und dann mit einem Browser öffnest, erscheint schon eine Karte. Die Koordinaten habe ich mal verändert, ich wollte nicht, das direkt meine Anschrift angezeigt wird...😲

                                EDIT:
                                für die Koordinaten nutze ich diesen Adapter
                                https://github.com/t4qjXH8N/ioBroker.google-sharedlocations/blob/master/README.md

                                Hi,

                                hier mal ein erster Entwurf (quasi eine Machbarkeits-Studie 🙂 ) zum Thema Widget und OpenStreetMap/Leaflet.

                                Die folgende Datei in das Verzeichnis /userwidgets/Map hochladen (geht nur mit der aktuellen Github-Version. Das Verzeichnis muss erst angelegt werden).

                                map.html (edit: korrigierte Version der Datei, Rundungsfehler behoben)

                                Dann ein Widget erstellen und die Datei als BACKGROUND_URL angeben.

                                In den Optionen unter URL/HTML die Option Erlaube postMessage-Kommunikation für BACKGROUND_URL/HTML einschalten.

                                iQontrol erzeugt dann die Datenpunkte iqontrol.0.Widgets.Map.Position.latitude, .altitude und .zoom, mit denen man die Position der Karte festlegen kann.

                                Mehr geht erst mal noch nicht, aber ich würde mich schon mal freuen, wenn ich Rückmeldung bekäme, dass das so weit bei Euch funktioniert. Dann kann man weitere Funktionen einbauen.

                                VG!

                                dslraserD Offline
                                dslraserD Offline
                                dslraser
                                Forum Testing Most Active
                                wrote on last edited by dslraser
                                #3375

                                @s-bormann sagte in Test Adapter iQontrol 1.3.x:

                                iQontrol erzeugt dann die Datenpunkte iqontrol.0.Widgets.Map.Position.latitude, .altitude und .zoom, mit denen man die Position der Karte festlegen kann.
                                Mehr geht erst mal noch nicht, aber ich würde mich schon mal freuen, wenn ich Rückmeldung bekäme, dass das so weit bei Euch funktioniert. Dann kann man weitere Funktionen einbauen.

                                Erstmal vielen Dank für das einfügen der Karte.👍
                                "Grundsätzlich" funktioniert die Karte. Zwei Dinge sind mir aufgefallen:

                                • klick auf das minus funktioniert

                                • klick auf das plus funktioniert nicht

                                (mit zwei Fingern zoomen funktioniert)

                                Wo setzt Du in der Karte den Focus für die Koordinaten ? (oben links/oben rechts/ unten links/ unten rechts / zentriert ?) Mit meinen Koordinaten startet die Ansicht bei größerem Zoom immer weit unten links, so das der Standort nicht auf dem Bild zu sehen ist.

                                20201011_183605 (1).gif

                                s.bormannS 1 Reply Last reply
                                0
                                • s.bormannS s.bormann

                                  @martinschm sagte in Test Adapter iQontrol 1.3.x:

                                  @s-bormann said in Test Adapter iQontrol 1.3.x:

                                  @martinschm sagte in Test Adapter iQontrol 1.3.x:

                                  @s-bormann : Mir ist mal aufgefallen, das wenn man den Namen einer Ansicht ändert, danach die Verknüpfungen mit der Ansicht nicht mehr funktioniert und man die neu anlegen oder anpassen muß.

                                  Vermutlich wird der Name als Referenz verwendet. Könnte man das so ändern, das der Name nur noch ein String ist und das Objekt "Ansicht" eine feste unique ID hat?

                                  Dann bricht nichts wenn man mal was umbenennt.

                                  Eigentlich sollte er das automatisch anpassen. Habe das auch gerade noch mal getestet, bei mir macht er das auch korrekt. Wenn es bei Dir weiter nicht geht, dann mach doch mal die F12-Konsole auf während des Umbenennens und schau, ob es Fehlermeldungen gibt VG

                                  Hi, hab es grade testet. Sobald ich den Namen der Ansicht ändere steht bei der Ansicht auf die ich verweise nichts mehr drin (hier Feuer Wasser Alarm)

                                  ae474fb0-4149-4ce1-b0c9-6b7ab6089779-image.png

                                  Wenn ich umbenenne und dann auf Speichern klicke sehe ich in der Entwicklerkonsole keine Fehlermeldungen.

                                  Ich hab aber noch diesen Eintrag gefunden (removed dead link):
                                  0fc378b5-94d5-4e68-973b-6931347c358d-image.png

                                  Es wird also gelöscht und nicht umgehangen.

                                  Es tut mir wirklich leid, bei mir funktioniert es. Habe es auch gerade noch mal mit einem Leerzeichen im Namen versucht - klappt aber auch. Ich habe wirklich keine Ahnung, woran das liegen könnte, sorry.

                                  M Offline
                                  M Offline
                                  martinschm
                                  wrote on last edited by
                                  #3376

                                  @s-bormann said in Test Adapter iQontrol 1.3.x:

                                  @martinschm sagte in Test Adapter iQontrol 1.3.x:

                                  @s-bormann said in Test Adapter iQontrol 1.3.x:

                                  @martinschm sagte in Test Adapter iQontrol 1.3.x:

                                  @s-bormann : Mir ist mal aufgefallen, das wenn man den Namen einer Ansicht ändert, danach die Verknüpfungen mit der Ansicht nicht mehr funktioniert und man die neu anlegen oder anpassen muß.

                                  Vermutlich wird der Name als Referenz verwendet. Könnte man das so ändern, das der Name nur noch ein String ist und das Objekt "Ansicht" eine feste unique ID hat?

                                  Dann bricht nichts wenn man mal was umbenennt.

                                  Eigentlich sollte er das automatisch anpassen. Habe das auch gerade noch mal getestet, bei mir macht er das auch korrekt. Wenn es bei Dir weiter nicht geht, dann mach doch mal die F12-Konsole auf während des Umbenennens und schau, ob es Fehlermeldungen gibt VG

                                  Hi, hab es grade testet. Sobald ich den Namen der Ansicht ändere steht bei der Ansicht auf die ich verweise nichts mehr drin (hier Feuer Wasser Alarm)

                                  ae474fb0-4149-4ce1-b0c9-6b7ab6089779-image.png

                                  Wenn ich umbenenne und dann auf Speichern klicke sehe ich in der Entwicklerkonsole keine Fehlermeldungen.

                                  Ich hab aber noch diesen Eintrag gefunden (removed dead link):
                                  0fc378b5-94d5-4e68-973b-6931347c358d-image.png

                                  Es wird also gelöscht und nicht umgehangen.

                                  Es tut mir wirklich leid, bei mir funktioniert es. Habe es auch gerade noch mal mit einem Leerzeichen im Namen versucht - klappt aber auch. Ich habe wirklich keine Ahnung, woran das liegen könnte, sorry.

                                  Ja kein Ding, ist ja zum Glück relativ einfach zu fixen. Am Browser kann es nicht liegen, oder?

                                  s.bormannS 1 Reply Last reply
                                  0
                                  • M martinschm

                                    @s-bormann said in Test Adapter iQontrol 1.3.x:

                                    @martinschm sagte in Test Adapter iQontrol 1.3.x:

                                    @s-bormann said in Test Adapter iQontrol 1.3.x:

                                    @martinschm sagte in Test Adapter iQontrol 1.3.x:

                                    @s-bormann : Mir ist mal aufgefallen, das wenn man den Namen einer Ansicht ändert, danach die Verknüpfungen mit der Ansicht nicht mehr funktioniert und man die neu anlegen oder anpassen muß.

                                    Vermutlich wird der Name als Referenz verwendet. Könnte man das so ändern, das der Name nur noch ein String ist und das Objekt "Ansicht" eine feste unique ID hat?

                                    Dann bricht nichts wenn man mal was umbenennt.

                                    Eigentlich sollte er das automatisch anpassen. Habe das auch gerade noch mal getestet, bei mir macht er das auch korrekt. Wenn es bei Dir weiter nicht geht, dann mach doch mal die F12-Konsole auf während des Umbenennens und schau, ob es Fehlermeldungen gibt VG

                                    Hi, hab es grade testet. Sobald ich den Namen der Ansicht ändere steht bei der Ansicht auf die ich verweise nichts mehr drin (hier Feuer Wasser Alarm)

                                    ae474fb0-4149-4ce1-b0c9-6b7ab6089779-image.png

                                    Wenn ich umbenenne und dann auf Speichern klicke sehe ich in der Entwicklerkonsole keine Fehlermeldungen.

                                    Ich hab aber noch diesen Eintrag gefunden (removed dead link):
                                    0fc378b5-94d5-4e68-973b-6931347c358d-image.png

                                    Es wird also gelöscht und nicht umgehangen.

                                    Es tut mir wirklich leid, bei mir funktioniert es. Habe es auch gerade noch mal mit einem Leerzeichen im Namen versucht - klappt aber auch. Ich habe wirklich keine Ahnung, woran das liegen könnte, sorry.

                                    Ja kein Ding, ist ja zum Glück relativ einfach zu fixen. Am Browser kann es nicht liegen, oder?

                                    s.bormannS Offline
                                    s.bormannS Offline
                                    s.bormann
                                    Most Active
                                    wrote on last edited by
                                    #3377

                                    @martinschm Ich denke eher nicht, die javascript-funktion, die das checkt, ist eigentlich so simpel, dass ich mir kaum vorstellen kann, dass das ein Browser nicht hinbekommt. Aber, es gibt ja nichts, was es nicht gibt. Ggf. kannst Du es ja mal mit einem anderen Browser probieren?

                                    1 Reply Last reply
                                    0
                                    • dslraserD dslraser

                                      @s-bormann sagte in Test Adapter iQontrol 1.3.x:

                                      iQontrol erzeugt dann die Datenpunkte iqontrol.0.Widgets.Map.Position.latitude, .altitude und .zoom, mit denen man die Position der Karte festlegen kann.
                                      Mehr geht erst mal noch nicht, aber ich würde mich schon mal freuen, wenn ich Rückmeldung bekäme, dass das so weit bei Euch funktioniert. Dann kann man weitere Funktionen einbauen.

                                      Erstmal vielen Dank für das einfügen der Karte.👍
                                      "Grundsätzlich" funktioniert die Karte. Zwei Dinge sind mir aufgefallen:

                                      • klick auf das minus funktioniert

                                      • klick auf das plus funktioniert nicht

                                      (mit zwei Fingern zoomen funktioniert)

                                      Wo setzt Du in der Karte den Focus für die Koordinaten ? (oben links/oben rechts/ unten links/ unten rechts / zentriert ?) Mit meinen Koordinaten startet die Ansicht bei größerem Zoom immer weit unten links, so das der Standort nicht auf dem Bild zu sehen ist.

                                      20201011_183605 (1).gif

                                      s.bormannS Offline
                                      s.bormannS Offline
                                      s.bormann
                                      Most Active
                                      wrote on last edited by
                                      #3378

                                      @dslraser sagte in Test Adapter iQontrol 1.3.x:

                                      @s-bormann sagte in Test Adapter iQontrol 1.3.x:

                                      iQontrol erzeugt dann die Datenpunkte iqontrol.0.Widgets.Map.Position.latitude, .altitude und .zoom, mit denen man die Position der Karte festlegen kann.
                                      Mehr geht erst mal noch nicht, aber ich würde mich schon mal freuen, wenn ich Rückmeldung bekäme, dass das so weit bei Euch funktioniert. Dann kann man weitere Funktionen einbauen.

                                      Erstmal vielen Dank für das einfügen der Karte.👍
                                      "Grundsätzlich" funktioniert die Karte. Zwei Dinge sind mir aufgefallen:

                                      • klick auf das minus funktioniert

                                      • klick auf das plus funktioniert nicht

                                      (mit zwei Fingern zoomen funktioniert)

                                      Wo setzt Du in der Karte den Focus für die Koordinaten ? (oben links/oben rechts/ unten links/ unten rechts / zentriert ?) Mit meinen Koordinaten startet die Ansicht bei größerem Zoom immer weite unten links, so das der Standort nicht auf dem Bild zu sehen ist.

                                      20201011_183605 (1).gif

                                      Zum Plus/Minus: Schalte mal die Option "Mauszeiger-Events für das Icon ignorieren" für aktiv, inaktiv und vergrößert ein, ich denke das unsichtbare Geräte-Icon hängt Dir vorm plus-Knopf 🙂

                                      Zum Focus: Habe da gerade den Bug gefunden. In der Datei kommt 3 x parseInt vor, das muss parseFloat heißen (sonst wird auf ganzzahlige Koordinaten abgerundet...)...

                                      Versuche die Datei im ursprünglichen Beitrag zu ändern.

                                      dslraserD 1 Reply Last reply
                                      1
                                      • s.bormannS s.bormann

                                        @dslraser sagte in Test Adapter iQontrol 1.3.x:

                                        @s-bormann sagte in Test Adapter iQontrol 1.3.x:

                                        iQontrol erzeugt dann die Datenpunkte iqontrol.0.Widgets.Map.Position.latitude, .altitude und .zoom, mit denen man die Position der Karte festlegen kann.
                                        Mehr geht erst mal noch nicht, aber ich würde mich schon mal freuen, wenn ich Rückmeldung bekäme, dass das so weit bei Euch funktioniert. Dann kann man weitere Funktionen einbauen.

                                        Erstmal vielen Dank für das einfügen der Karte.👍
                                        "Grundsätzlich" funktioniert die Karte. Zwei Dinge sind mir aufgefallen:

                                        • klick auf das minus funktioniert

                                        • klick auf das plus funktioniert nicht

                                        (mit zwei Fingern zoomen funktioniert)

                                        Wo setzt Du in der Karte den Focus für die Koordinaten ? (oben links/oben rechts/ unten links/ unten rechts / zentriert ?) Mit meinen Koordinaten startet die Ansicht bei größerem Zoom immer weite unten links, so das der Standort nicht auf dem Bild zu sehen ist.

                                        20201011_183605 (1).gif

                                        Zum Plus/Minus: Schalte mal die Option "Mauszeiger-Events für das Icon ignorieren" für aktiv, inaktiv und vergrößert ein, ich denke das unsichtbare Geräte-Icon hängt Dir vorm plus-Knopf 🙂

                                        Zum Focus: Habe da gerade den Bug gefunden. In der Datei kommt 3 x parseInt vor, das muss parseFloat heißen (sonst wird auf ganzzahlige Koordinaten abgerundet...)...

                                        Versuche die Datei im ursprünglichen Beitrag zu ändern.

                                        dslraserD Offline
                                        dslraserD Offline
                                        dslraser
                                        Forum Testing Most Active
                                        wrote on last edited by dslraser
                                        #3379

                                        @s-bormann sagte in Test Adapter iQontrol 1.3.x:

                                        Zum Plus/Minus: Schalte mal die Option "Mauszeiger-Events für das Icon ignorieren" für aktiv, inaktiv und vergrößert ein, ich denke das unsichtbare Geräte-Icon hängt Dir vorm plus-Knopf
                                        Zum Focus: Habe da gerade den Bug gefunden. In der Datei kommt 3 x parseInt vor, das muss parseFloat heißen (sonst wird auf ganzzahlige Koordinaten abgerundet...)...

                                        hat beides funktioniert 👍

                                        Jetzt bräuchte es noch die Möglichkeit mehrere User mit eigenen Koordinaten und ein zugehöriges Symbol auf der Karte, dann wäre es schon perfekt für mich.😊

                                        EDIT: @blackeagle998
                                        auch die Datei map.html hilft vielleicht etwas das ganze Prinzip zu verstehen.

                                        <!doctype html>
                                        <html style="width: 100%; height: 100%; margin: 0px;">
                                        <head>
                                           <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
                                           <meta name="widget-datapoint" content="Map.Position.latitude" data-type="number" data-role="value.gps.latitude" />
                                           <meta name="widget-datapoint" content="Map.Position.longitude" data-type="number" data-role="value.gps.longitude" />
                                           <meta name="widget-datapoint" content="Map.Position.zoom" data-type="number" data-role="value.zoom" />
                                           <link rel="stylesheet" href="https://unpkg.com/leaflet@1.7.1/dist/leaflet.css" integrity="sha512-xodZBNTC5n17Xt2atTPuE1HxjVMSvLVW9ocqUKLsCC5CXdbqCmblAshOMAS6/keqq/sMZMZ19scR4PsZChSR7A==" crossorigin=""/>
                                           <script src="https://unpkg.com/leaflet@1.7.1/dist/leaflet.js" integrity="sha512-XQoYMqMTK8LvdxXYG3nZ448hOEQiglfqkJs1NOQV44cWnUrBc8PkAOcXy20w0vlaXaVUearIOBhiXZ5V3ynxwA==" crossorigin=""></script>
                                           <title>iQontrol Map Widget</title>
                                        </head>
                                        <body style="width: 100%; height: 100%; margin: 0px;">
                                           <div id="mapid" style="width: 100%; height: 100%; margin: 0px;"></div>
                                           <script type="text/javascript">
                                             //Declarations
                                             var mapPositionLatitude = 20;
                                             var mapPositionLongitude = 30;
                                             var mapPositionZoom = 10;
                                             var mymap = false;
                                        
                                             //Subscribe to WidgetDatapoints now
                                             sendPostMessage("getWidgetStateSubscribed", "Map.Position.latitude");
                                             sendPostMessage("getWidgetStateSubscribed", "Map.Position.longitude");
                                             sendPostMessage("getWidgetStateSubscribed", "Map.Position.zoom");
                                        
                                             //Initialize map (with timeout to give script the time go get the initial position values)
                                             setTimeout(function(){
                                                console.log("Init map: " + mapPositionLatitude + "|" + mapPositionLongitude + "|" + mapPositionZoom);
                                                 mymap = L.map('mapid').setView([mapPositionLatitude, mapPositionLongitude], mapPositionZoom);        
                                                 L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
                                                     'attribution':  'Kartendaten &copy; <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a> Mitwirkende',
                                                     'useCache': true
                                                 }).addTo(mymap);
                                             }, 250);
                                             
                                             //Reposition map
                                             function repositionMap(){
                                               console.log("Reposition map: " + mapPositionLatitude + "|" + mapPositionLongitude + "|" + mapPositionZoom);
                                               if(mymap) mymap.setView([mapPositionLatitude, mapPositionLongitude], mapPositionZoom); else console.log("   Abort, map not initialized yet");
                                             }
                                             
                                             //send postMessages
                                             function sendPostMessage(command, stateId, value){
                                                 message = { command: command, stateId: stateId, value: value };
                                                 window.parent.postMessage(message, "*");
                                             }
                                        
                                             //receive postMessages
                                             window.addEventListener("message", receivePostMessage, false);
                                             function receivePostMessage(event) { //event = {data: message data, origin: url of origin, source: id of sending element}
                                                 if(event.data && event.data.command) switch(event.data.command){
                                                     case "getState":
                                                         if(event.data.stateId && event.data.value) switch(event.data.stateId){
                                                           case "Map.Position.latitude":
                                                             	console.log("Set latitude to " + event.data.value.val);
                                                           	mapPositionLatitude = parseFloat(event.data.value.val) || 0;
                                                             	if(mymap) repositionMap();
                                                           break;
                                        
                                                           case "Map.Position.longitude":
                                                             	console.log("Set longitude to " + event.data.value.val);
                                                           	mapPositionLongitude = parseFloat(event.data.value.val) || 0;
                                                             	if(mymap) repositionMap();
                                                           break;
                                                             
                                                           case "Map.Position.zoom":
                                                             	console.log("Set zoom to " + event.data.value.val);
                                                           	mapPositionZoom = parseFloat(event.data.value.val) || 0;
                                                             	if(mymap) repositionMap();
                                                           break;
                                                         }
                                                     break;
                                                 }
                                             }
                                           </script>
                                        </body>
                                        </html>
                                        


                                        20201011_202151.gif

                                        B dslraserD 2 Replies Last reply
                                        0
                                        • dslraserD dslraser

                                          @s-bormann sagte in Test Adapter iQontrol 1.3.x:

                                          Zum Plus/Minus: Schalte mal die Option "Mauszeiger-Events für das Icon ignorieren" für aktiv, inaktiv und vergrößert ein, ich denke das unsichtbare Geräte-Icon hängt Dir vorm plus-Knopf
                                          Zum Focus: Habe da gerade den Bug gefunden. In der Datei kommt 3 x parseInt vor, das muss parseFloat heißen (sonst wird auf ganzzahlige Koordinaten abgerundet...)...

                                          hat beides funktioniert 👍

                                          Jetzt bräuchte es noch die Möglichkeit mehrere User mit eigenen Koordinaten und ein zugehöriges Symbol auf der Karte, dann wäre es schon perfekt für mich.😊

                                          EDIT: @blackeagle998
                                          auch die Datei map.html hilft vielleicht etwas das ganze Prinzip zu verstehen.

                                          <!doctype html>
                                          <html style="width: 100%; height: 100%; margin: 0px;">
                                          <head>
                                             <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
                                             <meta name="widget-datapoint" content="Map.Position.latitude" data-type="number" data-role="value.gps.latitude" />
                                             <meta name="widget-datapoint" content="Map.Position.longitude" data-type="number" data-role="value.gps.longitude" />
                                             <meta name="widget-datapoint" content="Map.Position.zoom" data-type="number" data-role="value.zoom" />
                                             <link rel="stylesheet" href="https://unpkg.com/leaflet@1.7.1/dist/leaflet.css" integrity="sha512-xodZBNTC5n17Xt2atTPuE1HxjVMSvLVW9ocqUKLsCC5CXdbqCmblAshOMAS6/keqq/sMZMZ19scR4PsZChSR7A==" crossorigin=""/>
                                             <script src="https://unpkg.com/leaflet@1.7.1/dist/leaflet.js" integrity="sha512-XQoYMqMTK8LvdxXYG3nZ448hOEQiglfqkJs1NOQV44cWnUrBc8PkAOcXy20w0vlaXaVUearIOBhiXZ5V3ynxwA==" crossorigin=""></script>
                                             <title>iQontrol Map Widget</title>
                                          </head>
                                          <body style="width: 100%; height: 100%; margin: 0px;">
                                             <div id="mapid" style="width: 100%; height: 100%; margin: 0px;"></div>
                                             <script type="text/javascript">
                                               //Declarations
                                               var mapPositionLatitude = 20;
                                               var mapPositionLongitude = 30;
                                               var mapPositionZoom = 10;
                                               var mymap = false;
                                          
                                               //Subscribe to WidgetDatapoints now
                                               sendPostMessage("getWidgetStateSubscribed", "Map.Position.latitude");
                                               sendPostMessage("getWidgetStateSubscribed", "Map.Position.longitude");
                                               sendPostMessage("getWidgetStateSubscribed", "Map.Position.zoom");
                                          
                                               //Initialize map (with timeout to give script the time go get the initial position values)
                                               setTimeout(function(){
                                                  console.log("Init map: " + mapPositionLatitude + "|" + mapPositionLongitude + "|" + mapPositionZoom);
                                                   mymap = L.map('mapid').setView([mapPositionLatitude, mapPositionLongitude], mapPositionZoom);        
                                                   L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
                                                       'attribution':  'Kartendaten &copy; <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a> Mitwirkende',
                                                       'useCache': true
                                                   }).addTo(mymap);
                                               }, 250);
                                               
                                               //Reposition map
                                               function repositionMap(){
                                                 console.log("Reposition map: " + mapPositionLatitude + "|" + mapPositionLongitude + "|" + mapPositionZoom);
                                                 if(mymap) mymap.setView([mapPositionLatitude, mapPositionLongitude], mapPositionZoom); else console.log("   Abort, map not initialized yet");
                                               }
                                               
                                               //send postMessages
                                               function sendPostMessage(command, stateId, value){
                                                   message = { command: command, stateId: stateId, value: value };
                                                   window.parent.postMessage(message, "*");
                                               }
                                          
                                               //receive postMessages
                                               window.addEventListener("message", receivePostMessage, false);
                                               function receivePostMessage(event) { //event = {data: message data, origin: url of origin, source: id of sending element}
                                                   if(event.data && event.data.command) switch(event.data.command){
                                                       case "getState":
                                                           if(event.data.stateId && event.data.value) switch(event.data.stateId){
                                                             case "Map.Position.latitude":
                                                               	console.log("Set latitude to " + event.data.value.val);
                                                             	mapPositionLatitude = parseFloat(event.data.value.val) || 0;
                                                               	if(mymap) repositionMap();
                                                             break;
                                          
                                                             case "Map.Position.longitude":
                                                               	console.log("Set longitude to " + event.data.value.val);
                                                             	mapPositionLongitude = parseFloat(event.data.value.val) || 0;
                                                               	if(mymap) repositionMap();
                                                             break;
                                                               
                                                             case "Map.Position.zoom":
                                                               	console.log("Set zoom to " + event.data.value.val);
                                                             	mapPositionZoom = parseFloat(event.data.value.val) || 0;
                                                               	if(mymap) repositionMap();
                                                             break;
                                                           }
                                                       break;
                                                   }
                                               }
                                             </script>
                                          </body>
                                          </html>
                                          


                                          20201011_202151.gif

                                          B Offline
                                          B Offline
                                          blackeagle998
                                          wrote on last edited by
                                          #3380

                                          @dslraser @s-bormann
                                          Dankeschön, das ist sehr hilfreich.
                                          Bitte nicht wundern, wenn ich die nächsten zwei / drei Wochen nur eingeschränkt entwickeln / kommunizieren werde.

                                          1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          614

                                          Online

                                          32.4k

                                          Users

                                          81.4k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe