PanStamp RGBWW Board mit DMX und IR: Unterschied zwischen den Versionen

Aus FHEMWiki
K (Kategorie zugefügt)
K (.)
Zeile 17: Zeile 17:
|HWManufacturer=panStamp
|HWManufacturer=panStamp
}}
}}
[[PanStamp RGBWW Board mit DMX und IR]] unterstützt RGBW LEDs und lässt sich per Infrarot Fernbedienung, DMX Controller (z. B. als Unterputz Touchpanel) und FHEM bedienen.
[[PanStamp RGBWW Board mit DMX und IR]] unterstützt RGBW LEDs und lässt sich per Infrarot Fernbedienung, DMX Controller (z.B. als Unterputz Touchpanel) und FHEM bedienen.
Es ist eine Hard- und Softwareentwicklung auf Basis von panStamp Modulen und verwendet zusätzlich das FHEM Modul [[SWAP 0000002200000003]] als 3. Ebene
Es ist eine Hard- und Softwareentwicklung auf Basis von panStamp Modulen und verwendet zusätzlich das FHEM Modul [[SWAP 0000002200000003]] als 3. Ebene


Der Funktionsumfang wird in diesem [http://forum.fhem.de/index.php/topic,12487.msg81923.html#msg81923 Forenthread] vorgestellt. Die Hardware für das Board wird [http://forum.fhem.de/index.php/topic,13890.0.html  hier] im FHEM Forum vorgestellt und ein Prototyp ist [http://forum.fhem.de/index.php/topic,12487.msg85777.html#msg85777 hier] zu sehen.
Der Funktionsumfang wird in diesem {{Link2Forum|Topic=12487|Message=81923|LinkText=Forenthread}} vorgestellt. Die Hardware für das Board wird {{Link2Forum|Topic=13890|LinkText=hier}} im FHEM Forum vorgestellt und ein Prototyp ist {{Link2Forum|Topic=12487|Message=85777|LinkText=hier}} zu sehen.


== Hardware ==
== Hardware ==
Zeile 26: Zeile 26:


=== Kompatibilität RBG-Board mit NRG-panStamps ===
=== Kompatibilität RBG-Board mit NRG-panStamps ===
Mit dem hier beschriebenen Sketch ist das Board nur mit den AVRs kompatibel.
Mit dem hier beschriebenen Sketch ist das Board nur mit den panStamp AVRs kompatibel. Die Pinbelegung zwischen AVR und NRG ist im Prinzip gleich bis auf Pin 23. Das ist bei dem NRG ein IO Pin und nicht GND wie beim AVR. Das wäre kein Problem wenn man entweder hardwareseitig den Kontakt unterbricht oder aber programmiertechnisch diesen Pin '''NIE''' als Ausgang definiert. Ansonsten gibt’s einen „kurzen“. Oder wenn er als Ausgang definiert ist darf er nur das GND Potential haben, also Low, 0. {{Link2Forum|Topic=13890 |Message=247069}}
Die Pinbelegung zwischen AVR und NRG ist im Prinzip gleich bis auf Pin 23. Das ist bei dem NRG ein IO Pin und nicht Ground wie beim AVR.  
Das wäre kein Problem wenn man entweder hardwareseitig den Kontakt unterbricht oder aber programmiertechnisch diesen Pin '''NIE''' als Ausgang definiert. Ansonsten gibt’s ein „kurzen“. Oder wenn er als Ausgang definiert ist darf er nur das GND Potential haben, also Low, 0.
 
{{Link2Forum|Topic=13890 |Message=247069}}
[http://forum.fhem.de/index.php?topic=13890.msg247069#msg247069]


Da es derzeit (Stand 01.05.2015) aber keinen Sketch gibt, der auf den NRG lauffähig ist, wäre vorher noch diese Herausforderung zu lösen.
Da es derzeit (Stand 01.05.2015) aber keinen Sketch gibt, der auf den NRG lauffähig ist, wäre vorher noch diese Herausforderung zu lösen.


=== Eigenschaften des fade TBC ===
=== Eigenschaften des fade TBC ===
{{Randnotiz|RNText=In Artikel [[PanStamp_RGBWW_Board_mit_DMX_und_IR]]}}
Der wichtige Punkt ist das das RGBWW-Board Farbübergänge autonom macht und FHEM nur den Trigger zum starten und Rückmeldung über den Status gibt. d.h. wie ruckelfrei das faden ist hängt nicht von äußeren Bedingungen wie Funklast, FHEM timing oder FHEM Auslastung ab. Im Board gibt es 15 '''Register''' die jeweils eine Farbe und eine Anzeigedauer enthalten. Diese werden (ein mal) von FHEM aus programmiert. Zum starten wird dann nur noch das Anfangs- und das Endregister gesendet und das Board überblendet zwischen allen Farben der Register zwischen Anfang und Ende in der eingestellten Zeit.
http://forum.fhem.de/index.php?topic=13890.msg106644#msg106644
Die eigentliche Einschränkung ist das die aktuelle AVR Version der panstamps ''nur'' 8bit pwm kann (jedenfalls wenn es 3 oder mehr Kanäle sein sollen und die Hardware PWM genutzt wird). Wenn dir diese 256 Stufen pro Grundfarbe reichen ist es absolut Ruckelfrei. d.h. es gibt keinen zeitlichen Jitter. Ob dir die Anzahl der Helligkeitsstufen reicht hängt ein wenig von den LEDs selber ab und davon zwischen welchen Farben du konkret wechselst. Im dunklen Bereich wirst du vermutlich stufen sehen (also beim aufblenden von dunkel zu hell). wenn du zwischen zwei hellen Farben (z.b. von rot nach grün) blendest wirst du keine stufen sehen. {{Link2Forum|Topic=13890|Message=106644}}
 


== Software ==
== Software ==
Zeile 44: Zeile 38:
{{Link2Forum|Topic=13890 |Message=1205404}}
{{Link2Forum|Topic=13890 |Message=1205404}}
was geht:
was geht:
* bis zu vier led kanäle (je nach kombination von ir und soft pwm)
* Bis zu vier LED Kanäle (je nach Kombination von ir und soft PWM)
* ir senden
* Ir senden
* ir empfangen
* Ir empfangen
* messen ob die led versorgung an ist
* Messen ob die LED Versorgungsspannung an ist
* helligkeit eines an A2 angeschlossenen helligkeits sensors
* Helligkeit eines an Pin <code>A2</code> angeschlossenen Helligkeitssensors (LDR)
* konfiguration der dmx basis adresse über das swap register 0x12
* Konfiguration der DMX Basisadresse über das SWAP Register <code>0x12</code>
* optional soft on auf letzten wert
* Optional soft on auf letzten RGBW Wert
* alles was auch vorher schon ging: dimmen, faden, ir fernbedienungen anlernen, ...
* Alles was auch vorher schon ging: dimmen, faden, ir fernbedienungen anlernen, ...


wichtig zu wissen:
wichtig zu wissen:
* wenn ir aktiv ist und kein soft pwm lässt sich der 4. kanal nur ein und aus schalten
* Wenn ir aktiv ist und kein soft PWM lässt sich der 4. Kanal nur ein und aus schalten
* wenn ir aktiv ist muss soft pwm aktiv sein um den 4. kanäle auch zu dimmen
* Wenn ir aktiv ist muss soft PWM aktiv sein um den 4. Kanal auch zu dimmen
* es wird nur ein zusätzlicher kanal tatsächlich schon unterstützt. der fünfte kommt noch
* Es wird nur ein zusätzlicher LED Kanal tatsächlich schon unterstützt. Der fünfte kommt noch
* bei ir senden sind nur die aufrufe für sony und nec tatsächlich eingebaut. die anderen sind aber einfach zu ergänzen
* Bei ir senden sind nur die Aufrufe für Sony und NEC tatsächlich eingebaut. Die Anderen sind aber einfach zu ergänzen
* beim ir senden sind noch keine Wiederholungen eingebaut. die müssen laut protokoll aber eigentlich sein
* Beim ir senden sind noch keine Wiederholungen eingebaut. Die müssen laut Protokoll aber eigentlich sein


was noch kommt:
was noch kommt:
* besseres soft pwm
* besseres soft PWM
* mehr konfiguration bezüglich default verhalten. ramp zeiten, delays, ...
* mehr Konfiguration bezüglich default verhalten. ramp zeiten, delays, ...
* hsv farb modell um besser zu faden und vor allem um den weiss anteil automatisch auf die weiss leds zu legen
* hsv Farbmodell um besser zu faden und vor allem um den Weißanteil automatisch auf die weißen LEDs zu legen
* die virtuellen channel  
* die virtuellen channel  
* fhem kompatibles ir senden
* fhem kompatibles ir senden
* sofortiges senden von helligkeit und led spannung bei änderung
* sofortiges senden von Helligkeit und LED Spannung bei Änderung
* andere ir lib mit sehr viel besserer geräte unterstützung
* andere ir lib mit sehr viel besserer Geräte Unterstützung


wie gehabt muss alles über config.h mit Compilerschalter konfiguriert werden.
wie gehabt muss alles über <code>config.h</code> mit Compilerschalter konfiguriert werden.


=== Arduino IDE 1.5 / 1.6 einrichten ===
=== Arduino IDE 1.5 / 1.6 einrichten ===
Mit der Arduino IDE 1.5.x gab es zusätzlich eine grundlegende Umstellungen der Arduino SWAP Library, für die der derzeitige Sketch [r4716] angepasst werden muss. Der Sketch ist nur kompatibel zur alten SWAP Library, die unter Arduino IDE 1.0 installiert werden muss (Stand 01.05.2015).
Mit der Arduino IDE 1.5.x gab es zusätzlich eine [http://www.panstamp.com/news/panstamp-is-now-fully-arduino-1-5-enabled/ grundlegende Umstellungen der Arduino SWAP Library], für die der derzeitige Sketch [r4716] angepasst werden muss. Der Sketch ist nur kompatibel zur alten SWAP Library, die unter [[PanStamp_Programmierung#Arduino_IDE_1.0.x_vorbereiten|Arduino IDE 1.0 installiert]] werden muss (Stand 01.05.2015).


=== Arduino IDE 1.0 einrichten ===
=== Arduino IDE 1.0 einrichten ===
Zum Flashen der panStamps wird die Arduino IDE benötigt. Eine Installationsanleitung ist unter folgendem Link zu finden:
Zum Flashen der panStamps wird die [[PanStamp_Programmierung#Arduino_IDE_1.0.x_vorbereiten|Arduino IDE 1.0.x benötigt]]. Für den RGBWW-Sketch sind je nach gewünschtem Funktionsumfang noch folgende libs zu installieren:
:https://code.google.com/p/panstamp/wiki/firststeps
 
Für den RGB-Driver sketch sind je nach gewünschtem Funktionsumfang noch folgende libs zu installieren:


* Die Dateien der '''Panstamp Lib''' läd man von hier [[http://old.panstamp.com/downloads]] (panstamp_library.zip, 129k v.25, May 31, 2013). Mit der neueren Lib v.4 läuft die Kompillierung des derzeitigen Sketches nicht durch. Die Dateien der Lib speichert man in einem entsprechend neuen  Unterordner, z.B. hierin C:\Users\<username>\Documents\Arduino\libraries. Am Ende der ganzen Aktion im Folgenden sollten sich in diesem Unterordner 3 neue Unterordner befinden: IRremote, DMXSerial und panstamp
* Die Dateien der '''Panstamp Lib''' läd man von hier [[http://old.panstamp.com/downloads]] (panstamp_library.zip, 129k v.25, May 31, 2013). Mit der neueren Lib v.4 läuft die Kompillierung des derzeitigen Sketches nicht durch. Die Dateien der Lib speichert man in einem entsprechend neuen  Unterordner, z.B. hierin <code>C:\Users\<username>\Documents\Arduino\libraries</code>. Am Ende der ganzen Aktion sollten sich in diesem Unterordner 3 neue Unterordner befinden: <code>IRremote, DMXSerial und panstamp</code>.


* Die Dateien der '''IR Remote Lib''' kopiert man von hier [[https://github.com/shirriff/Arduino-IRremote]] und speichert sie ebenfalls in einem passenden Unterordner von libraries.
* Die Dateien der '''IR Remote Lib''' kopiert man von hier [[https://github.com/shirriff/Arduino-IRremote]] und speichert sie ebenfalls in einem passenden Unterordner von <code>libraries</code>.


* Die Dateien der '''DMX Lib''' kopiert man von hier [[http://www.mathertel.de/Arduino/DMXSerial.aspx]] und speichert sie ein weiteres Mal in einem weiteren Unterordner von libraries. Weitere Informationen zur Verwendung von Arduino Libraties finden sich hier [[http://arduino.cc/en/Hacking/Libraries]]. Dass die Libraries richtig erkannt worden sind, lässt sich dadurch erkennen, dass unter Sketch/Library importieren die 3 weiteren Punkte unten unter "beigetragen" auftauchen.
* Die Dateien der '''DMX Lib''' kopiert man von hier [[http://www.mathertel.de/Arduino/DMXSerial.aspx]] und speichert sie ein weiteres Mal in einem weiteren Unterordner von <code>libraries</code>. Weitere Informationen zur Verwendung von Arduino Librarys finden sich hier [[http://arduino.cc/en/Hacking/Libraries]]. Dass die Librarys richtig erkannt worden sind, lässt sich dadurch erkennen, dass unter dem Menüpunkt <code>Sketch/Library importieren</code> die 3 weiteren Punkte unten unter <code>beigetragen</code> auftauchen.


Die Librarys sollten entweder mit dem entsprechenden Menüpunkt in die IDE integriert werden oder jeweils nach auspacken des zip files als als kompletten Ordner im Arduino libraries verzeichnis abgelegt werden (siehe [http://www.arduino.cc/en/Hacking/Libraries)]).
Die Librarys sollten entweder mit dem entsprechenden Menüpunkt in die IDE integriert werden oder jeweils nach auspacken des zip files als als kompletten Ordner im Arduino <code>libraries</code> Verzeichnis abgelegt werden (siehe [http://www.arduino.cc/en/Hacking/Libraries)]).
* Windows IDE only: Falls alles so bleibt, wie es heruntergeladen wurde, wechselt man wieder auf den Reiter sketch und importiert über ->Sketch Library importieren die entsprechenden Libs für IRremote und DMX. Dadurch werden 3 neue Zeilen hinzugefügt.
* Windows IDE only: Falls alles so bleibt, wie es heruntergeladen wurde, wechselt man wieder auf den Reiter Sketch und importiert über ->Sketch Library importieren die entsprechenden Libs für IRremote und DMX. Dadurch werden 3 neue Zeilen hinzugefügt.
* Nun sollte über Sketch/Überprüften/Kompillieren die Erstellung des Sketches möglich sein.
* Nun sollte über Sketch/Überprüften/Kompillieren die Erstellung des Sketches möglich sein.
* Falls erfolgreich unter Datei/Hochladen (ohne Programmer) den Sketch auf den Panstamp laden.
* Falls erfolgreich unter Datei/Hochladen (ohne Programmer) den Sketch auf den Panstamp laden.


Für das kompilieren mit INO siehe [[panstamp#ino|hier]].
Für das kompilieren mit INO siehe [[PanStamp_Programmierung#INO|hier]].


=== Link zum Sketch ===
=== Link zum Sketch ===
Die aktuelle Version des RGB-Driver Sketches findet sich auf [http://sourceforge.net/p/fhem/code/HEAD/tree/trunk/fhem/contrib/arduino/ sourceforge].
Die aktuelle Version des RGBWW-Driver Sketches findet sich auf [http://sourceforge.net/p/fhem/code/HEAD/tree/trunk/fhem/contrib/arduino/ sourceforge]. {{Link2Forum|Topic=13890 |Message=201391}}
{{Link2Forum|Topic=13890 |Message=201391}}
Dieser muss in <code>Arduino\libraries\panstamp\examples\sketches</code> entpackt und die <code>rbgdriver.ino</code> gestartet werden. In der Arduino IDE sollte unter Tools->Board "Arduino Pro or Pro Mini (3.3V, 8MHz) w/ Atmega328" eingestellt sein. Wenn man das boards.txt file von [http://code.google.com/p/panstamp/downloads/detail?name=boards.txt&can=2&q= hier] installiert kann man in der IDE auch direkt panStamp als Plattform auswählen.
[http://forum.fhem.de/index.php?topic=13890.msg201391#msg201391]
Dieser muss in Arduino\libraries\panstamp\examples\sketches entpackt und die rbgdriver.ino gestartet werden. In der Arduino IDE sollte unter Tools->Board "Arduino Pro or Pro Mini (3.3V, 8MHz) w/ Atmega328" eingestellt sein. Wenn man das boards.txt file von [http://code.google.com/p/panstamp/downloads/detail?name=boards.txt&can=2&q= hier] installiert kann man in der IDE auch direkt panStamp als Plattform auswählen.


==== Kompillierte hex version ====
==== Kompillierte hex version ====
Eine kompiliertes HEX-File für drei (vier) Kanäle plus IR-Empfang und DMX ist hier im Forum zu finden:
Eine kompiliertes HEX-File für drei (vier) Kanäle plus IR-Empfang und DMX ist hier im Forum zu finden: {{Link2Forum|Topic=13890 |Message=121619}}
{{Link2Forum|Topic=13890 |Message=121619}}
[http://forum.fhem.de/index.php?topic=13890.msg121619#msg121619]


==== HEX-File ohne IR und DMX ====
==== HEX-File ohne IR und DMX ====
Eine kompiliertes HEX-File ohne IR-Empfang und DMX ist hier im Forum zu finden:
Eine kompiliertes HEX-File ohne IR-Empfang und DMX ist hier im Forum zu finden: {{Link2Forum|Topic=13890 |Message=201955}}
{{Link2Forum|Topic=13890 |Message=201955}}
[http://forum.fhem.de/index.php?topic=13890.msg201955#msg201955]
 


=== Compilerschalter ===
=== Compilerschalter ===
Welche Features der sketch bietet lässt sich im config.h file durch ein- oder auskommentieren der <pre>#define ENABLE_...</pre> Zeilen festlegen. {{Link2Forum|Topic=13890 |Message=173431}}
Welche Features der sketch bietet lässt sich im <code>config.h</code> file durch ein- oder auskommentieren der <code>#define ENABLE_...</code> Zeilen festlegen. {{Link2Forum|Topic=13890 |Message=173431}}


==== #define ENABLE_DMX ====
==== #define ENABLE_DMX ====
Zeile 117: Zeile 101:
Ermöglicht die Nutzung eines DMX RGB Einstellers zur Steuerung der RGB LEDs
Ermöglicht die Nutzung eines DMX RGB Einstellers zur Steuerung der RGB LEDs


 
Hierbei ist darauf zu achten, dass in der DMX-Lib in der Datei <code>DMXSerial.h</code> die Zeile
Hierbei ist darauf zu achten, dass in der DMX-Lib in der Datei DMXSerial.h die Zeile
  #define DmxModePin 2    // Arduino pin 2 for controlling the data direction
  #define DmxModePin 2    // Arduino pin 2 for controlling the data direction
in  
in  
  #define DmxModePin 7    // Arduino pin 7 for controlling the data direction
  #define DmxModePin 7    // Arduino pin 7 for controlling the data direction
abgeändert werden muss.
abgeändert werden muss.


==== #define HAS_SENSOR ====
==== #define HAS_SENSOR ====
Zeile 135: Zeile 115:
   ENABLE_REPEATER;
   ENABLE_REPEATER;


In der IRremote.cpp Datei in der Irremote Library muss die Zeile
In der <code>IRremote.cpp</code> Datei in der Irremote Library muss die Zeile
<pre>
<pre>
void IRrecv::disableIRIn()  
void IRrecv::disableIRIn()  
Zeile 143: Zeile 123:
</pre>
</pre>


sowie die Irremote.h Datei unter Public: um die Zeile  
sowie die <code>Irremote.h</code> Datei unter <code>Public:</code> um die Zeile  
  void disableIRIn();
  void disableIRIn();
erweitert werden.
erweitert werden.


Der Daten-Pin des DHT22 Sensors muss hierfür an A2 des panStamps angeschlossen werden.
Der Daten-Pin des DHT22 Sensors muss hierfür an Pin <code>A2</code> des panStamps angeschlossen werden.
Ein Beispiel für die Umrechnung der userReading für Spannung Temp etc. ist hier beschrieben.
Ein Beispiel für die Umrechnung der userReading für Spannung Temp etc. ist hier beschrieben: {{Link2Forum|Topic=12487 |Message=76489}}
{{Link2Forum|Topic=12487 |Message=76489}}


=== Zusammenhänge der Konfiguration ===
=== Zusammenhänge der Konfiguration ===
Die Zusammenhänge der Konfiguration sind hier beschrieben
Die Zusammenhänge der Konfiguration sind hier beschrieben {{Link2Forum|Topic=13890 |Message=175181}}
{{Link2Forum|Topic=13890 |Message=175181}}


=== 4. und 5. LED Kanal TBC ===
=== 4. und 5. LED Kanal TBC ===

Version vom 29. Juli 2015, 07:10 Uhr


Clock - Under Construction.svg An dieser Seite wird momentan noch gearbeitet.



PanStamp RGBWW Board mit DMX und IR
RGBWW Board
Allgemein
Protokoll SWAP
Typ Sender, Empfänger, Sensor, Interface
Kategorie
Technische Details
Kommunikation 868MHz
Kanäle
Betriebsspannung 12V
Leistungsaufnahme
Versorgung Netzteil
Abmessungen
Sonstiges
Modulname 35_SWAP_0000002200000003.pm 34_SWAP.pm
Ersteller Andre / justme1968
Hersteller panStamp

PanStamp RGBWW Board mit DMX und IR unterstützt RGBW LEDs und lässt sich per Infrarot Fernbedienung, DMX Controller (z.B. als Unterputz Touchpanel) und FHEM bedienen. Es ist eine Hard- und Softwareentwicklung auf Basis von panStamp Modulen und verwendet zusätzlich das FHEM Modul SWAP 0000002200000003 als 3. Ebene

Der Funktionsumfang wird in diesem Forenthread vorgestellt. Die Hardware für das Board wird hier im FHEM Forum vorgestellt und ein Prototyp ist hier zu sehen.

Hardware

Die Projektseite zur Hardware findet sich hier. Eine Version 2 des Boards in geplant.

Kompatibilität RBG-Board mit NRG-panStamps

Mit dem hier beschriebenen Sketch ist das Board nur mit den panStamp AVRs kompatibel. Die Pinbelegung zwischen AVR und NRG ist im Prinzip gleich bis auf Pin 23. Das ist bei dem NRG ein IO Pin und nicht GND wie beim AVR. Das wäre kein Problem wenn man entweder hardwareseitig den Kontakt unterbricht oder aber programmiertechnisch diesen Pin NIE als Ausgang definiert. Ansonsten gibt’s einen „kurzen“. Oder wenn er als Ausgang definiert ist darf er nur das GND Potential haben, also Low, 0. Beitrag

Da es derzeit (Stand 01.05.2015) aber keinen Sketch gibt, der auf den NRG lauffähig ist, wäre vorher noch diese Herausforderung zu lösen.

Eigenschaften des fade TBC

Der wichtige Punkt ist das das RGBWW-Board Farbübergänge autonom macht und FHEM nur den Trigger zum starten und Rückmeldung über den Status gibt. d.h. wie ruckelfrei das faden ist hängt nicht von äußeren Bedingungen wie Funklast, FHEM timing oder FHEM Auslastung ab. Im Board gibt es 15 Register die jeweils eine Farbe und eine Anzeigedauer enthalten. Diese werden (ein mal) von FHEM aus programmiert. Zum starten wird dann nur noch das Anfangs- und das Endregister gesendet und das Board überblendet zwischen allen Farben der Register zwischen Anfang und Ende in der eingestellten Zeit. Die eigentliche Einschränkung ist das die aktuelle AVR Version der panstamps nur 8bit pwm kann (jedenfalls wenn es 3 oder mehr Kanäle sein sollen und die Hardware PWM genutzt wird). Wenn dir diese 256 Stufen pro Grundfarbe reichen ist es absolut Ruckelfrei. d.h. es gibt keinen zeitlichen Jitter. Ob dir die Anzahl der Helligkeitsstufen reicht hängt ein wenig von den LEDs selber ab und davon zwischen welchen Farben du konkret wechselst. Im dunklen Bereich wirst du vermutlich stufen sehen (also beim aufblenden von dunkel zu hell). wenn du zwischen zwei hellen Farben (z.b. von rot nach grün) blendest wirst du keine stufen sehen. Beitrag

Software

Eine Übersicht über die derzeit vorhandene Funktionalität des Fhem Moduls und panStamp Sketches (Stand 01.05.2015): Beitrag was geht:

  • Bis zu vier LED Kanäle (je nach Kombination von ir und soft PWM)
  • Ir senden
  • Ir empfangen
  • Messen ob die LED Versorgungsspannung an ist
  • Helligkeit eines an Pin A2 angeschlossenen Helligkeitssensors (LDR)
  • Konfiguration der DMX Basisadresse über das SWAP Register 0x12
  • Optional soft on auf letzten RGBW Wert
  • Alles was auch vorher schon ging: dimmen, faden, ir fernbedienungen anlernen, ...

wichtig zu wissen:

  • Wenn ir aktiv ist und kein soft PWM lässt sich der 4. Kanal nur ein und aus schalten
  • Wenn ir aktiv ist muss soft PWM aktiv sein um den 4. Kanal auch zu dimmen
  • Es wird nur ein zusätzlicher LED Kanal tatsächlich schon unterstützt. Der fünfte kommt noch
  • Bei ir senden sind nur die Aufrufe für Sony und NEC tatsächlich eingebaut. Die Anderen sind aber einfach zu ergänzen
  • Beim ir senden sind noch keine Wiederholungen eingebaut. Die müssen laut Protokoll aber eigentlich sein

was noch kommt:

  • besseres soft PWM
  • mehr Konfiguration bezüglich default verhalten. ramp zeiten, delays, ...
  • hsv Farbmodell um besser zu faden und vor allem um den Weißanteil automatisch auf die weißen LEDs zu legen
  • die virtuellen channel
  • fhem kompatibles ir senden
  • sofortiges senden von Helligkeit und LED Spannung bei Änderung
  • andere ir lib mit sehr viel besserer Geräte Unterstützung

wie gehabt muss alles über config.h mit Compilerschalter konfiguriert werden.

Arduino IDE 1.5 / 1.6 einrichten

Mit der Arduino IDE 1.5.x gab es zusätzlich eine grundlegende Umstellungen der Arduino SWAP Library, für die der derzeitige Sketch [r4716] angepasst werden muss. Der Sketch ist nur kompatibel zur alten SWAP Library, die unter Arduino IDE 1.0 installiert werden muss (Stand 01.05.2015).

Arduino IDE 1.0 einrichten

Zum Flashen der panStamps wird die Arduino IDE 1.0.x benötigt. Für den RGBWW-Sketch sind je nach gewünschtem Funktionsumfang noch folgende libs zu installieren:

  • Die Dateien der Panstamp Lib läd man von hier [[1]] (panstamp_library.zip, 129k v.25, May 31, 2013). Mit der neueren Lib v.4 läuft die Kompillierung des derzeitigen Sketches nicht durch. Die Dateien der Lib speichert man in einem entsprechend neuen Unterordner, z.B. hierin C:\Users\<username>\Documents\Arduino\libraries. Am Ende der ganzen Aktion sollten sich in diesem Unterordner 3 neue Unterordner befinden: IRremote, DMXSerial und panstamp.
  • Die Dateien der IR Remote Lib kopiert man von hier [[2]] und speichert sie ebenfalls in einem passenden Unterordner von libraries.
  • Die Dateien der DMX Lib kopiert man von hier [[3]] und speichert sie ein weiteres Mal in einem weiteren Unterordner von libraries. Weitere Informationen zur Verwendung von Arduino Librarys finden sich hier [[4]]. Dass die Librarys richtig erkannt worden sind, lässt sich dadurch erkennen, dass unter dem Menüpunkt Sketch/Library importieren die 3 weiteren Punkte unten unter beigetragen auftauchen.

Die Librarys sollten entweder mit dem entsprechenden Menüpunkt in die IDE integriert werden oder jeweils nach auspacken des zip files als als kompletten Ordner im Arduino libraries Verzeichnis abgelegt werden (siehe [5]).

  • Windows IDE only: Falls alles so bleibt, wie es heruntergeladen wurde, wechselt man wieder auf den Reiter Sketch und importiert über ->Sketch Library importieren die entsprechenden Libs für IRremote und DMX. Dadurch werden 3 neue Zeilen hinzugefügt.
  • Nun sollte über Sketch/Überprüften/Kompillieren die Erstellung des Sketches möglich sein.
  • Falls erfolgreich unter Datei/Hochladen (ohne Programmer) den Sketch auf den Panstamp laden.

Für das kompilieren mit INO siehe hier.

Link zum Sketch

Die aktuelle Version des RGBWW-Driver Sketches findet sich auf sourceforge. Beitrag Dieser muss in Arduino\libraries\panstamp\examples\sketches entpackt und die rbgdriver.ino gestartet werden. In der Arduino IDE sollte unter Tools->Board "Arduino Pro or Pro Mini (3.3V, 8MHz) w/ Atmega328" eingestellt sein. Wenn man das boards.txt file von hier installiert kann man in der IDE auch direkt panStamp als Plattform auswählen.

Kompillierte hex version

Eine kompiliertes HEX-File für drei (vier) Kanäle plus IR-Empfang und DMX ist hier im Forum zu finden: Beitrag

HEX-File ohne IR und DMX

Eine kompiliertes HEX-File ohne IR-Empfang und DMX ist hier im Forum zu finden: Beitrag

Compilerschalter

Welche Features der sketch bietet lässt sich im config.h file durch ein- oder auskommentieren der #define ENABLE_... Zeilen festlegen. Beitrag

#define ENABLE_DMX

#define ENABLE_DMX

Ermöglicht die Nutzung eines DMX RGB Einstellers zur Steuerung der RGB LEDs

Hierbei ist darauf zu achten, dass in der DMX-Lib in der Datei DMXSerial.h die Zeile

#define DmxModePin 2     // Arduino pin 2 for controlling the data direction

in

#define DmxModePin 7     // Arduino pin 7 for controlling the data direction

abgeändert werden muss.

#define HAS_SENSOR

 #define HAS_SENSOR

Ermöglicht die Nutzung eines DHT22 Sensors zur Auswertung von Temperatur und Luftfeuchtigkeit Dafür sollten diese Konfigurationszeilen auskommentiert sein:

 USE_SOFT_PWM;
 ENABLE_IR_SEND;
 ENABLE_REPEATER;

In der IRremote.cpp Datei in der Irremote Library muss die Zeile

void IRrecv::disableIRIn() 
{
TIMER_DISABLE_INTR;
}

sowie die Irremote.h Datei unter Public: um die Zeile

void disableIRIn();

erweitert werden.

Der Daten-Pin des DHT22 Sensors muss hierfür an Pin A2 des panStamps angeschlossen werden. Ein Beispiel für die Umrechnung der userReading für Spannung Temp etc. ist hier beschrieben: Beitrag

Zusammenhänge der Konfiguration

Die Zusammenhänge der Konfiguration sind hier beschrieben Beitrag

4. und 5. LED Kanal TBC

http://forum.fhem.de/index.php?topic=13890.msg169741#msg169741 http://forum.fhem.de/index.php?topic=13890.msg192132#msg192132 http://forum.fhem.de/index.php?topic=13890.msg201922#msg201922 http://forum.fhem.de/index.php?topic=13890.msg201936#msg201936

Alternativer Fade per Patch

Als Alternative zum im Sketch und im Modul eingebauten Fade-Befehl ist hier ein Patch vorgestellt: Beitrag [6]

Der Patch ist nicht eingecheckt.


IR Schnittstelle TBC

IR TBC

http://forum.fhem.de/index.php?topic=13890.msg107061#msg107061 http://forum.fhem.de/index.php?topic=13890.msg107197#msg107197 http://forum.fhem.de/index.php?topic=13890.msg107415#msg107415 http://forum.fhem.de/index.php/topic,13890.msg122021.html#msg122021 http://forum.fhem.de/index.php/topic,13890.msg122077.html#msg122077 http://forum.fhem.de/index.php?topic=13890.msg167351#msg167351 http://forum.fhem.de/index.php?topic=13890.msg175269#msg175269 http://forum.fhem.de/index.php?topic=13890.msg175285#msg175285 http://forum.fhem.de/index.php?topic=13890.msg182582#msg182582 http://forum.fhem.de/index.php?topic=13890.msg245597#msg245597 http://forum.fhem.de/index.php?topic=13890.msg259267#msg259267

IR-Belegung Panstamp RGB-Board TBC

http://forum.fhem.de/index.php/topic,13890.msg163008.html#msg163008 http://forum.fhem.de/index.php/topic,13890.msg163153.html#msg163153

Ircluster TBC

http://forum.fhem.de/index.php?topic=13890.msg175331#msg175331

Irgate TBC

http://forum.fhem.de/index.php?topic=13890.msg175278#msg175278

DMX Schnittstelle

Da die DMX-Schrittstelle kein direktes Interface zu FHEM hat, sondern nur die direkte Kommunikation zwischen DMX-Kontroller und RGB-Board betrifft, ist die Schnittstelle nur bei der Konfiguration des Sketches und über die Dokumentation des Boards beschrieben.

Weblinks