Advertisement
NapsterMP3

Artnet NeopPixel SD.

Jul 1st, 2016
94
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 4.59 KB | None | 0 0
  1. /*
  2. Same as ArtnetNeoPixel.ino but with controls to record and playback sequences from an SD card.
  3. To record, send 255 to the first channel of universe 14. To stop, send 0 and to playback send 127.
  4. The limit of leds seems to be around 450 to get 44 fps. The playback routine is not optimzed yet.
  5. This example may be copied under the terms of the MIT license, see the LICENSE file for details
  6. */
  7.  
  8. #include <Artnet.h>
  9. #include <Ethernet.h>
  10. #include <EthernetUdp.h>
  11. #include <SPI.h>
  12. #include <Adafruit_NeoPixel.h>
  13. #include <SD.h>
  14.  
  15. // Neopixel settings
  16. const int numLeds = 200; // change for your setup
  17. const byte dataPin = 2;
  18. Adafruit_NeoPixel leds = Adafruit_NeoPixel(numLeds, dataPin, NEO_GRB + NEO_KHZ800);
  19.  
  20. // Artnet settings
  21. Artnet artnet;
  22. const int startUniverse = 0; // CHANGE FOR YOUR SETUP most software this is 1, some software send out artnet first universe as zero.
  23. const int numberOfChannels = numLeds * 3; // Total number of channels you want to receive (1 led = 3 channels)
  24. byte channelBuffer[numberOfChannels]; // Combined universes into a single array
  25.  
  26. // SD card
  27. File datafile;
  28. char fileName[] = "data.txt";
  29. const int chipSelect = 4;
  30. bool record = 0;
  31. bool playback = 0;
  32.  
  33. // Check if we got all universes
  34. const int maxUniverses = numberOfChannels / 512 + ((numberOfChannels % 512) ? 1 : 0);
  35. bool universesReceived[maxUniverses];
  36. bool sendFrame = 1;
  37.  
  38. // Change ip and mac address for your setup
  39. byte ip[] = {192, 168, 2, 2};
  40. byte mac[] = {0x04, 0xE9, 0xE5, 0x00, 0x69, 0xEC};
  41.  
  42. void setup()
  43. {
  44. Serial.begin(115200);
  45. artnet.begin(mac, ip);
  46. leds.begin();
  47. initTest();
  48.  
  49. if (!SD.begin(chipSelect)) {
  50. Serial.println("initialization failed!");
  51. }
  52. else
  53. Serial.println("initialization done.");
  54.  
  55. // this will be called for each packet received
  56. artnet.setArtDmxCallback(onDmxFrame);
  57. }
  58.  
  59. void loop()
  60. {
  61. // we call the read function inside the loop
  62. artnet.read();
  63. if (playback)
  64. {
  65. while(datafile.available() && playback)
  66. {
  67. artnet.read();
  68. datafile.read(channelBuffer, numberOfChannels);
  69. for (int i = 0; i < numLeds; i++)
  70. leds.setPixelColor(i, channelBuffer[(i) * 3], channelBuffer[(i * 3) + 1], channelBuffer[(i * 3) + 2]);
  71.  
  72. leds.show();
  73. delay(20);
  74. }
  75. playback = 0;
  76. datafile.close();
  77. }
  78. }
  79.  
  80. void onDmxFrame(uint16_t universe, uint16_t length, uint8_t sequence, uint8_t* data)
  81. {
  82. sendFrame = 1;
  83. // set brightness of the whole strip
  84. if (universe == 15)
  85. {
  86. leds.setBrightness(data[0]);
  87. leds.show();
  88. }
  89.  
  90. if (universe == 14)
  91. {
  92. // record
  93. if (data[0] == 255)
  94. {
  95. if (SD.exists(fileName))
  96. {
  97. SD.remove(fileName);
  98. }
  99. datafile = SD.open(fileName, FILE_WRITE);
  100. record = 1;
  101. playback = 0;
  102. }
  103. // play
  104. if (data[0] == 127)
  105. {
  106. record = 0;
  107. playback = 1;
  108. datafile = SD.open(fileName, FILE_READ);
  109. }
  110. // stop
  111. if (data[0] == 0)
  112. {
  113. record = 0;
  114. playback = 0;
  115. datafile.close();
  116. }
  117. }
  118.  
  119. // Store which universe has got in
  120. if (universe < maxUniverses)
  121. universesReceived[universe] = 1;
  122.  
  123. for (int i = 0 ; i < maxUniverses ; i++)
  124. {
  125. if (universesReceived[i] == 0)
  126. {
  127. //Serial.println("Broke");
  128. sendFrame = 0;
  129. break;
  130. }
  131. }
  132.  
  133. if (!playback)
  134. {
  135. // read universe and put into the right part of the display buffer
  136. for (int i = 0 ; i < length ; i++)
  137. {
  138. int bufferIndex = i + ((universe - startUniverse) * length);
  139. if (bufferIndex < numberOfChannels) // to verify
  140. channelBuffer[bufferIndex] = byte(data[i]);
  141. }
  142. }
  143.  
  144. if (record && sendFrame)
  145. {
  146. datafile.write(channelBuffer, numberOfChannels);
  147. memset(universesReceived, 0, maxUniverses);
  148. }
  149.  
  150. if (!playback && !record)
  151. {
  152. // send to leds
  153. for (int i = 0; i < numLeds; i++)
  154. {
  155. leds.setPixelColor(i, channelBuffer[(i) * 3], channelBuffer[(i * 3) + 1], channelBuffer[(i * 3) + 2]);
  156. }
  157.  
  158. if (sendFrame)
  159. {
  160. leds.show();
  161. // Reset universeReceived to 0
  162. memset(universesReceived, 0, maxUniverses);
  163. }
  164. }
  165. }
  166.  
  167. void initTest()
  168. {
  169. for (int i = 0 ; i < numLeds ; i++)
  170. leds.setPixelColor(i, 127, 0, 0);
  171. leds.show();
  172. delay(500);
  173. for (int i = 0 ; i < numLeds ; i++)
  174. leds.setPixelColor(i, 0, 127, 0);
  175. leds.show();
  176. delay(500);
  177. for (int i = 0 ; i < numLeds ; i++)
  178. leds.setPixelColor(i, 0, 0, 127);
  179. leds.show();
  180. delay(500);
  181. for (int i = 0 ; i < numLeds ; i++)
  182. leds.setPixelColor(i, 0, 0, 0);
  183. leds.show();
  184. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement