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

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

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Visualisierung
  4. 3D Wohnungsgrundriss mit Sweet Home 3D - das beste?

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    16
    1
    1.0k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    698

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.0k

3D Wohnungsgrundriss mit Sweet Home 3D - das beste?

Geplant Angeheftet Gesperrt Verschoben Visualisierung
34 Beiträge 13 Kommentatoren 8.0k Aufrufe 10 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • KusselinK Kusselin

    @mickym ich meine im VIS nicht im Zeichenproggi...

    Wie importierst du deinen 3D view in vis?
    Gruss

    mickymM Online
    mickymM Online
    mickym
    Most Active
    schrieb am zuletzt editiert von mickym
    #25

    @kusselin Über den VIS Dateimanger lädst Du die Dateien hoch. Der Pfad welches Bild zu laden ist, ist in einem Datenpunkt gespeichert, wie ich das unten beschrieben habe.

    Ich hab Dir unten (im Vorposting) ja markiert, welches Widget ich zur Anzeige nutze und unten den Zusammenhang dargestellt.

    Es ist unter den Basic Widgets das

    9b4db3a0-2c7b-4b8e-a8cc-89f5d2229fdf-image.png

    Screenshot vom vis Dateimanager siehst ja auch unten.

    Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

    KusselinK 1 Antwort Letzte Antwort
    0
    • mickymM mickym

      @kusselin Über den VIS Dateimanger lädst Du die Dateien hoch. Der Pfad welches Bild zu laden ist, ist in einem Datenpunkt gespeichert, wie ich das unten beschrieben habe.

      Ich hab Dir unten (im Vorposting) ja markiert, welches Widget ich zur Anzeige nutze und unten den Zusammenhang dargestellt.

      Es ist unter den Basic Widgets das

      9b4db3a0-2c7b-4b8e-a8cc-89f5d2229fdf-image.png

      Screenshot vom vis Dateimanager siehst ja auch unten.

      KusselinK Offline
      KusselinK Offline
      Kusselin
      schrieb am zuletzt editiert von Kusselin
      #26

      @mickym sorry wenn ich so blöd frage...wo unten?

      Ich dachte, ich lade über den dateimanager hoch mit Upload und dann wenn das Bild geladen ist einfach doppelklick drauf....aber so gehts nicht!!

      Achso, ich muss dann für das 3D Bild erst eine leere View erstellen udn dann darein das Widget von dir ziehen und dann da das 3d Bild rein...? Richtig?

      Ich habe es im Vorpsot gesehen...danke....bissl schwer für den Anfang....

      Wieso muss ich da noch einen datenpunkt anlegen im userdata ordner?

      Ich dachte immer bild hochladen und in die erstellte View ziehen udn gut is.....

      mickymM 1 Antwort Letzte Antwort
      0
      • KusselinK Kusselin

        @mickym sorry wenn ich so blöd frage...wo unten?

        Ich dachte, ich lade über den dateimanager hoch mit Upload und dann wenn das Bild geladen ist einfach doppelklick drauf....aber so gehts nicht!!

        Achso, ich muss dann für das 3D Bild erst eine leere View erstellen udn dann darein das Widget von dir ziehen und dann da das 3d Bild rein...? Richtig?

        Ich habe es im Vorpsot gesehen...danke....bissl schwer für den Anfang....

        Wieso muss ich da noch einen datenpunkt anlegen im userdata ordner?

        Ich dachte immer bild hochladen und in die erstellte View ziehen udn gut is.....

        mickymM Online
        mickymM Online
        mickym
        Most Active
        schrieb am zuletzt editiert von mickym
        #27

        @kusselin Nein - das macht ja auch keinen Sinn - Du willst doch nicht statisch ein Bild in einem Widget haben. Wenn Du das wirklich nachbilden willst, nimmst Du dieses Widget und gibst unter der Objekt ID den Datenpunkt an, der den Pfad zu dem Bild enthält, was Du laden willst.

        Du willst ja dynamisch immer andere Bilder angezeigt haben. Deshalb änderst Du das Bild in dem Datenpunkt. Du kannst dich alles anhand der Screenshots nachvollziehen.

        Das Widget, den DP der in der Objekt ID angegeben wurde, den Pfad in dem Datenpunkt, der zum Bild führt. Du siehst außerdem, dass der Pfad bei /vis.0 beginnt.

        Nichts ziehen und doppelklicken. ;)

        Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

        KusselinK 1 Antwort Letzte Antwort
        0
        • mickymM mickym

          @kusselin Nein - das macht ja auch keinen Sinn - Du willst doch nicht statisch ein Bild in einem Widget haben. Wenn Du das wirklich nachbilden willst, nimmst Du dieses Widget und gibst unter der Objekt ID den Datenpunkt an, der den Pfad zu dem Bild enthält, was Du laden willst.

          Du willst ja dynamisch immer andere Bilder angezeigt haben. Deshalb änderst Du das Bild in dem Datenpunkt. Du kannst dich alles anhand der Screenshots nachvollziehen.

          Das Widget, den DP der in der Objekt ID angegeben wurde, den Pfad in dem Datenpunkt, der zum Bild führt. Du siehst außerdem, dass der Pfad bei /vis.0 beginnt.

          Nichts ziehen und doppelklicken. ;)

          KusselinK Offline
          KusselinK Offline
          Kusselin
          schrieb am zuletzt editiert von
          #28

          @mickym Haaaalt micky...ich möchte nicht so wie du es gemacht hast mit 350 Einzelbildern für Nacht udn Tag verfahren.....

          Ich möchte mein 3D Bild laden und dort dann buttons setzen für lichter usw....verstehst was ich meine?

          mickymM 1 Antwort Letzte Antwort
          0
          • KusselinK Kusselin

            @mickym Haaaalt micky...ich möchte nicht so wie du es gemacht hast mit 350 Einzelbildern für Nacht udn Tag verfahren.....

            Ich möchte mein 3D Bild laden und dort dann buttons setzen für lichter usw....verstehst was ich meine?

            mickymM Online
            mickymM Online
            mickym
            Most Active
            schrieb am zuletzt editiert von
            #29

            @kusselin Dann nimmst halt das normale IMG - Widget

            86f125d5-ddfb-487f-9ef0-0cac69eacf34-image.png

            sobald Du hier auf Quelle drückst, öffnet sich der Dateimanager und Du kannst das Bild direkt auswählen

            Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

            KusselinK 1 Antwort Letzte Antwort
            0
            • mickymM mickym

              @kusselin Dann nimmst halt das normale IMG - Widget

              86f125d5-ddfb-487f-9ef0-0cac69eacf34-image.png

              sobald Du hier auf Quelle drückst, öffnet sich der Dateimanager und Du kannst das Bild direkt auswählen

              KusselinK Offline
              KusselinK Offline
              Kusselin
              schrieb am zuletzt editiert von
              #30

              @mickym cool :-) danke Dir...
              Image 1.png

              is ja nur mal ein test....und so kann ich das bild jetzt in jede view setzen udn halt noch schalter usw. dann hinzufügen....

              Gruss

              1 Antwort Letzte Antwort
              0
              • mickymM mickym

                Das Umzurechnen von der entsprechenden Lampe habe ich im NodeRed mit einer Function Node gemacht, ist also ein Javascript - dass Du natürlich mit leichter Anpassung auch direkt mit dem Javascript Adapter verwenden kannst.

                Hier mal der Code:

                var x;
                var obj = msg.payload;
                var code = 0;
                
                for (x in obj) {
                
                var val=0;
                
                    switch(x) {
                        case "wohnzimmer/tischlampe":
                            val = obj[x] ? 1 : 0;
                            break;
                        case "wohnzimmer/vitrine":
                            val = obj[x] ? 2 : 0;
                            break;
                        case "tv":
                            val = obj[x] ? 4 : 0;
                            break;
                        case "wohnzimmer/deckenleuchten":
                            val = obj[x] ? 8 : 0;
                            break;
                        case "wohnzimmer/esstisch":
                            val = obj[x] ? 16 : 0;
                            break;
                        case "küche/deckenleuchten":
                            val = obj[x] ? 32 : 0;
                            break;
                        case "flur/deckenleuchten":
                            val = obj[x] ? 64 : 0;
                            break;
                        case "diele/deckenleuchten":
                            val = obj[x] ? 128 : 0;
                            break;
                        case "bad/deckenleuchten":
                            val = obj[x] ? 256 : 0;
                            break;
                        case "bad/spiegel":
                            val = obj[x] ? 512 : 0;
                            break;
                        case "monitor":
                            val = obj[x] ? 1024 : 0;
                            break;
                        case "buero/computer":
                            val = obj[x] ? 2048 : 0;
                            break;
                        case "buero/schreibtisch":
                            val = obj[x] ? 4096 : 0;
                            break;
                        case "buero/deckenleuchten":
                            val = obj[x] ? 8192 : 0;
                            break;
                        case "schlafzimmer/bettlampen":
                            val = obj[x] ? 16384 : 0;
                            break;
                        case "schlafzimmer/schrankbeleuchtung":
                            val = obj[x] ? 32768 : 0;
                            break;
                    } 
                 code += val;
                }
                
                msg.payload=code.toString(); 
                
                return msg;
                
                

                Oder mit anderen Worten - jede Lampe wird auf true oder false im Datenpunkt gespeichert, das Ganze in ein Objekt verfrachtet und dann quasi codiert.

                J Offline
                J Offline
                jwerlsdf
                schrieb am zuletzt editiert von
                #31

                @mickym
                Hallo mickym,
                ich bin gerade dabei meine VIS komplett neu zu machen, da ich nun eh auf VIS 2 umsteige. Ich würde jetzt gerne das ganze so aufbauen, wie du es hier erstellt hast. Mir ist alles bisher klar, das einzige was ich nicht genau verstehe, ist die Exeltabelle. Wo muss ich das im iobroker ablegen, etc. Außerdem hast du das ganze mit NodeRed gemacht. Da ich das aber leider nicht benutze, könntest du mir dabei helfen, das ganze in Javaskript zu importieren oder noch besser mit Blockly, da ich damit am meisten arbeite? Ich weiß, dass dieser thread schon ein bisschen alt ist, aber ich hoffe, du könntest mir noch einmal dabei helfen. Vielen Dank.

                mickymM 1 Antwort Letzte Antwort
                0
                • J jwerlsdf

                  @mickym
                  Hallo mickym,
                  ich bin gerade dabei meine VIS komplett neu zu machen, da ich nun eh auf VIS 2 umsteige. Ich würde jetzt gerne das ganze so aufbauen, wie du es hier erstellt hast. Mir ist alles bisher klar, das einzige was ich nicht genau verstehe, ist die Exeltabelle. Wo muss ich das im iobroker ablegen, etc. Außerdem hast du das ganze mit NodeRed gemacht. Da ich das aber leider nicht benutze, könntest du mir dabei helfen, das ganze in Javaskript zu importieren oder noch besser mit Blockly, da ich damit am meisten arbeite? Ich weiß, dass dieser thread schon ein bisschen alt ist, aber ich hoffe, du könntest mir noch einmal dabei helfen. Vielen Dank.

                  mickymM Online
                  mickymM Online
                  mickym
                  Most Active
                  schrieb am zuletzt editiert von mickym
                  #32

                  @jwerlsdf Hallo, ich nutze das selbst nicht mehr. Die Kombinationen der Grundrisse sind für die ganze Wohnung zuviele. Deswegen würde ich Dir heute empfehlen gerade mit VIS vielleicht mit Ebenen zu arbeiten und die Grundrisse mit den eingeschalteten Lampen jeweils für einen Raum zu machen. Wie gesagt - ich kann Dir das Prinzip nochmals genau verdeutlichen. Hier ist er mal das Excelsheet.

                  Beleuchtung codierung Bild.xlsx

                  Ausserdem siehst Du dass ich hier mit Bits und insgesamt 16 Lampen gearbeitet habe. Ich will Dir nur mal das Prinzip erklären:

                  Wichtig sind nur die vorderen Spalten

                  598a2d0f-e899-4508-a78c-4cf7bb4e253f-image.png

                  Links sind nun alle Lampen und das Bit was mit der Lampe verknüpft ist. In der gelben Spalte machst Du statt 0 eine 1 wenn die Lampe an ist - wie gesagt Du wirst kaum alle 65.536 Dateien für alle Kombinationen erstellen. Also deswegen auf ein Zimmer oder halt nur die häufigsten Kombis erstellen.

                  Wenn also die Lampe im Wohnzimmer (TV-Lampe, Vitrine) und TV und das Licht im Flur eingeschaltet ist, wird das als Datei mit 71 codiert:

                  8bdbcb70-b27c-4ad8-ad39-2e288bf1019e-image.png

                  Diese ganzen Grundrisse speicherst Du in einem Verzeichnis, auf das VIS zugriff hat:
                  3c961edd-8b79-43e6-81ea-d70b40ef1cf2-image.png
                  Ich hab das für das Gerät (iPad) in einem Verzeichnis unter vis.0 gespeichert:

                  GR-1366-1004-NA-71.png

                  In Deiner VIS nimmst Du nun ein Widget, bei dem Du das anzuzeigende Bild nicht direkt, sondern den Pfad zu der Datei die anzuzeigen ist enthält:

                  ed078668-8ae4-4408-91c8-33ba9c454187-image.png

                  In diesen Datenpunkt schreibst Du dann welche Datei angezeigt werden soll:

                  112da0e0-4c70-410e-85b8-2676c919ecc5-image.png

                  Ich bin bekanntlich kein Blockly-Fan und will das nun auch nicht in Blockly codieren, aber ich kann Dir mal den Flow soweit erklären. Du musst halt das was NodeRed automatisch kann halt im JS nachbauen oder in Blockly.

                  9a6d210a-1a52-49cc-ba11-cd06b47c24e5-image.png

                  Der linke Teil bis zu der JOIN Node sind alles Lampen die im iobroker oder mqtt triggern und Du erstellst daraus ein Objekt, wo Du alle Lampen mit dem Zustand (true=eingeschaltet) oder (false=ausgeschaltet) hast:

                  {
                    "wohnzimmer/esstisch": false,
                    "bad/deckenleuchten": false,
                    "flur/deckenleuchten": false,
                    "diele/deckenleuchten": false,
                    "buero/computer": false,
                    "küche/deckenleuchten": false,
                    "buero/deckenleuchten": false,
                    "wohnzimmer/deckenleuchten": false,
                    "wohnzimmer/vitrine": true
                  }
                  

                  Nun erstelle ich daraus den Code - der die gleiche Nummer enthält wie die XLS Tabelle. Die payload ist in diesem Fall so ein Objekt wie gerade gepostet, also quasi der Zustand aller Lampen in einem Objekt (halt in einem Zimmer, Wohnung etc.)

                  Das heißt dieses Objekt wird abgeprüft via JS:

                  var x;
                  var obj = msg.payload;
                  var code = 0;
                  
                  for (x in obj) {
                  
                  var val=0;
                  
                      switch(x) {
                          case "wohnzimmer/tischlampe":
                              val = obj[x] ? 1 : 0;
                              break;
                          case "wohnzimmer/vitrine":
                              val = obj[x] ? 2 : 0;
                              break;
                          case "tv":
                              val = obj[x] ? 4 : 0;
                              break;
                          case "wohnzimmer/deckenleuchten":
                              val = obj[x] ? 8 : 0;
                              break;
                          case "wohnzimmer/esstisch":
                              val = obj[x] ? 16 : 0;
                              break;
                          case "küche/deckenleuchten":
                              val = obj[x] ? 32 : 0;
                              break;
                          case "flur/deckenleuchten":
                              val = obj[x] ? 64 : 0;
                              break;
                          case "diele/deckenleuchten":
                              val = obj[x] ? 128 : 0;
                              break;
                          case "bad/deckenleuchten":
                              val = obj[x] ? 256 : 0;
                              break;
                          case "bad/spiegel":
                              val = obj[x] ? 512 : 0;
                              break;
                          case "monitor":
                              val = obj[x] ? 1024 : 0;
                              break;
                          case "buero/computer":
                              val = obj[x] ? 2048 : 0;
                              break;
                          case "buero/schreibtisch":
                              val = obj[x] ? 4096 : 0;
                              break;
                          case "buero/deckenleuchten":
                              val = obj[x] ? 8192 : 0;
                              break;
                          case "schlafzimmer/bettlampen":
                              val = obj[x] ? 16384 : 0;
                              break;
                          case "schlafzimmer/schrankbeleuchtung":
                              val = obj[x] ? 32768 : 0;
                              break;
                      } 
                   code += val;
                  }
                  
                  msg.payload=code.toString(); 
                  
                  return msg;
                  
                  

                  Wie Du siehst,

                          case "wohnzimmer/vitrine":
                              val = obj[x] ? 2 : 0;
                              break;
                  

                  wird jedes topic als Bit gesetzt und das ganze Objekt durchanalysiert und dann aufsummiert. In dem Beispiel die Vitrine mit Bit 2.

                  Daraus errechnet sich dann das Bild das angezeigt werden soll und das wird in den Datenpunkt geschrieben, auf das das Widget verweist.

                  So habe ich dir das Funktionsprinzip beschrieben.

                  Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                  1 Antwort Letzte Antwort
                  1
                  • mickymM mickym

                    So schaut das Ganze dann übrigens nachts animiert aus - je nachdem welche Lichter an sind. Hier kann man aber nur die gängigsten Szenarien abbilden - da es ja x Tausend Kombinationen = Bilder gibt.

                    screen.png

                    Als nächstes müssen dann Dialog eingebaut werden und noch Filter um die Anzahl der Icons ggf. manuell oder automatisch zu filtern. Aber wie gesagt momentan habe andere Dinge Prio.

                    D Offline
                    D Offline
                    denjo
                    schrieb am zuletzt editiert von denjo
                    #33

                    @mickym hast du jedes bild einzeln runter geladen?

                    mickymM 1 Antwort Letzte Antwort
                    0
                    • D denjo

                      @mickym hast du jedes bild einzeln runter geladen?

                      mickymM Online
                      mickymM Online
                      mickym
                      Most Active
                      schrieb am zuletzt editiert von
                      #34

                      @denjo ja. heute würde ich die bilder pro zimmer machen und dann das Ganze zusammensetzen.

                      Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

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


                      Support us

                      ioBroker
                      Community Adapters
                      Donate

                      381

                      Online

                      32.6k

                      Benutzer

                      82.0k

                      Themen

                      1.3m

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

                      • Du hast noch kein Konto? Registrieren

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