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

Aus FHEMWiki
(Artikel erstellt mit Infos aus Artikel panStamp)
 
(→‎IR-Belegung Panstamp RGB-Board TBC: Nutzung von Link2Forum-Vorlage)
 
(15 dazwischenliegende Versionen von 6 Benutzern werden nicht angezeigt)
Zeile 1: Zeile 1:
{{Baustelle}}
{{Baustelle}}
{{SEITENTITEL:panStamp RGBWW Board mit DMX und IR}}
{{Infobox Hardware
|Bild=panStampRGBv1.0.jpg
|Bildbeschreibung=RGBWW Board
|HWProtocol=SWAP
|HWType=Sender, Empfänger, Sensor, [[Interface]]
|HWCategory=
|HWComm=868MHz
|HWChannels=
|HWVoltage=12V
|HWPowerConsumption=
|HWPoweredBy=Netzteil
|HWSize=
|HWDeviceFHEM=[http://fhem.de/commandref.html#SWAP_0000002200000003 35_SWAP_0000002200000003.pm] [http://fhem.de/commandref.html#SWAP 34_SWAP.pm]
|ModOwner=justme1968 <br />({{Link2FU|430|Forum}} / [[Benutzer:Justme|Wiki]])
|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.
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 {{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 ==
Die Projektseite zur Hardware findet sich [http://itse.homeip.net/projekte/12/6/ 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. {{Link2Forum|Topic=13890 |Message=247069}}


''' Upate 2014-01-11'''
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.
Zur Zeit ist Version 2 des Boards in Vorbereiteung. Die Projektseite zur Hardware findet sich [http://itse.homeip.net/projekte/12/6/ hier].  


=== 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. {{Link2Forum|Topic=13890|Message=106644}}


== Software ==
== Software ==
 
Eine Übersicht über die derzeit vorhandene Funktionalität des [[SWAP_0000002200000003|FHEM Moduls]] und panStamp Sketches (Stand 01.05.2015):
''' Upate 2014-01-11'''
{{Link2Forum|Topic=13890 |Message=1205404}}
Demnächst wird eine aktualisiert Version des [[SWAP_0000002200000003|Fhem Moduls]] und panStamp Sketches eingecheckt. Eine Übersicht über die dann vorhandene Funktionalität:
 
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 <code>config.h</code> mit Compilerschalter konfiguriert werden.
 
=== Arduino IDE 1.5 / 1.6 einrichten ===
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).


wie gehabt muss alles über config.h konfiguriert werden.
=== Arduino IDE 1.0 einrichten ===
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:


=== Arduino IDE einrichten ===
* 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>.
Zum Flashen der panStamps wird die Arduino IDE benötigt. Eine Installationsanleitung ist unter folgendem Link zu finden:
: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 '''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>.


* IR lib - https://github.com/shirriff/Arduino-IRremote
* 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.
* DMX lib- http://www.mathertel.de/Arduino/DMXSerial.aspx


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.
* 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.


Die aktuelle Version des RGB-Driver Sketches findet sich auf [http://sourceforge.net/p/fhem/code/HEAD/tree/trunk/fhem/contrib/arduino/ sourceforge].
Für das kompilieren mit INO siehe [[panStamp_Programmierung#INO|hier]].


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.
=== Link zum Sketch ===
Die aktuelle Version des RGBWW-Driver Sketches findet sich im [https://svn.fhem.de/trac/browser/trunk/fhem/contrib/arduino/ FHEM-SVN]. {{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.


==== Kompillierte hex version ====
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}}
==== HEX-File ohne IR und DMX ====
Eine kompiliertes HEX-File ohne IR-Empfang und DMX ist hier im Forum zu finden: {{Link2Forum|Topic=13890 |Message=201955}}


=== Compilerschalter ===
=== Compilerschalter ===
Welche Features der sketch bietet lässt sich im config.h file durch ein- oder auskommentieren der #define ENABLE_... Zeilen festlegen.
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 63: Zeile 102:
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 ====
   #define HAS_SENSOR
   #define HAS_SENSOR
Ermöglicht die Nutzung eines DHT22 Sensors zur Auswerung von Temperatur und Luftfeuchtigkeit
Ermöglicht die Nutzung eines DHT22 Sensors zur Auswertung von Temperatur und Luftfeuchtigkeit
 
Dafür sollten diese Konfigurationszeilen auskommentiert sein:
 
   USE_SOFT_PWM;
   USE_SOFT_PWM;
   ENABLE_IR_SEND;
   ENABLE_IR_SEND;
   ENABLE_REPEATER;
   ENABLE_REPEATER;


sollte hierfür auskommentiert sein.
In der <code>IRremote.cpp</code> Datei in der Irremote Library muss die Zeile
 
In der IRremote.cpp Datei in der Irremote Library muss die Zeile
 
<pre>
<pre>
void IRrecv::disableIRIn()  
void IRrecv::disableIRIn()  
Zeile 93: Zeile 124:
</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();
erweitert 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: {{Link2Forum|Topic=12487 |Message=76489}}
 
=== Zusammenhänge der Konfiguration ===
Die Zusammenhänge der Konfiguration sind hier beschrieben {{Link2Forum|Topic=13890 |Message=175181}}
 
=== 4. und 5. LED Kanal TBC ===
{{Link2Forum|Topic=13890|Message=169741}}<br>
{{Link2Forum|Topic=13890|Message=192132}}<br>
{{Link2Forum|Topic=13890|Message=201922}}<br>
{{Link2Forum|Topic=13890|Message=201936}}
 
=== Alternativer Fade per Patch ===
Als Alternative zum im Sketch und im Modul eingebauten Fade-Befehl ist hier ein Patch vorgestellt:
{{Link2Forum|Topic=12487 |Message=133096}}
{{Link2Forum|Topic=12487|Message=133096}}


void disableIRIn();
Der Patch ist '''nicht eingecheckt'''.
 
 
== IR Schnittstelle TBC ==
=== IR TBC ===
{{Link2Forum|Topic=13890|Message=107061}}<br>
{{Link2Forum|Topic=13890|Message=107197}}<br>
{{Link2Forum|Topic=13890|Message=107415}}<br>
{{Link2Forum|Topic=13890|Message=122021}}<br>
{{Link2Forum|Topic=13890|Message=122077}}<br>
{{Link2Forum|Topic=13890|Message=167351}}<br>
{{Link2Forum|Topic=13890|Message=175269}}<br>
{{Link2Forum|Topic=13890|Message=175285}}<br>
{{Link2Forum|Topic=13890|Message=182582}}<br>
{{Link2Forum|Topic=13890|Message=245597}}<br>
{{Link2Forum|Topic=13890|Message=259267}}<br>
 
=== IR-Belegung Panstamp RGB-Board TBC ===
{{Link2Forum|Topic=13890|Message=163008}}<br>
{{Link2Forum|Topic=13890|Message=163153}}<br>
 
Es gibt Unterschiede in der Pinbelegung zwischen dem Panstamp rgbdriver Board und dem rgbdriver Board aus dem fhem Forum.
 
Original Panstamp rgbdriver Board:
Der IR Empfänger läuft auf Pin D0 des PanstampAVR auf.


erweitert werden.
Panstamp rgbdriver Board aus dem Forum:
Der IR Empfänger läuft auf Pin A0 des PanstampAVR auf.


Der Daten-Pin des DHT22 Sensors muss hierfür an A2 des panStamps angeschlossen werden.
Im Sketch sollte die folgende Zeile demnach angepasst werden:
# define IR_RECV_PIN  0 //Orginal Board 0; fhem Board A0


=== 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 ==
== Weblinks ==
* [http://www.panstamp.com/home panStamp] panStamp Hersteller
* [http://www.panstamp.com/home panStamp] panStamp Hersteller
* [http://itse.homeip.net/projekte/12/6/ Projektseite] für das RGB-Multi-Board.
* [http://itse.homeip.net/projekte/12/6/ Projektseite] für das RGB-Multi-Board.
* [http://sourceforge.net/p/fhem/code/HEAD/tree/trunk/fhem/contrib/arduino/ rgbdriver sketch] auf sourceforge
* [https://svn.fhem.de/trac/browser/trunk/fhem/contrib/arduino/ rgbdriver Sketch] im FHEM-SVN
 
[[Kategorie:panStamp]]

Aktuelle Version vom 21. September 2017, 08:16 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 justme1968
(Forum / Wiki)
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 im FHEM-SVN. 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

Beitrag
Beitrag
Beitrag
Beitrag

Alternativer Fade per Patch

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

Der Patch ist nicht eingecheckt.


IR Schnittstelle TBC

IR TBC

Beitrag
Beitrag
Beitrag
Beitrag
Beitrag
Beitrag
Beitrag
Beitrag
Beitrag
Beitrag
Beitrag

IR-Belegung Panstamp RGB-Board TBC

Beitrag
Beitrag

Es gibt Unterschiede in der Pinbelegung zwischen dem Panstamp rgbdriver Board und dem rgbdriver Board aus dem fhem Forum.

Original Panstamp rgbdriver Board: Der IR Empfänger läuft auf Pin D0 des PanstampAVR auf.

Panstamp rgbdriver Board aus dem Forum: Der IR Empfänger läuft auf Pin A0 des PanstampAVR auf.

Im Sketch sollte die folgende Zeile demnach angepasst werden:

  1. define IR_RECV_PIN 0 //Orginal Board 0; fhem Board A0

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