Digispark_Test.ino 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. #include <Adafruit_NeoPixel.h>
  2. void HSVtoRGB(float H, float S,float V,int &R, int &G, int &B){
  3. while(H>360) H-=360;
  4. if(H>360 || H<0 || S>100 || S<0 || V>100 || V<0){
  5. return;
  6. }
  7. float s = S/100;
  8. float v = V/100;
  9. float C = s*v;
  10. float X = C*(1-abs(fmod(H/60.0, 2)-1));
  11. float m = v-C;
  12. float r,g,b;
  13. if(H >= 0 && H < 60){
  14. r = C,g = X,b = 0;
  15. }
  16. else if(H >= 60 && H < 120){
  17. r = X,g = C,b = 0;
  18. }
  19. else if(H >= 120 && H < 180){
  20. r = 0,g = C,b = X;
  21. }
  22. else if(H >= 180 && H < 240){
  23. r = 0,g = X,b = C;
  24. }
  25. else if(H >= 240 && H < 300){
  26. r = X,g = 0,b = C;
  27. }
  28. else{
  29. r = C,g = 0,b = X;
  30. }
  31. R = (r+m)*255;
  32. G = (g+m)*255;
  33. B = (b+m)*255;
  34. }
  35. #define PIN1 2
  36. #define NUMPIXELS 25 // 24
  37. #define CENTER 12.5
  38. int mode;
  39. Adafruit_NeoPixel pixels[] = {
  40. Adafruit_NeoPixel(NUMPIXELS, PIN1, NEO_GRB + NEO_KHZ800),
  41. };
  42. int PIN_COUNT = 1;
  43. double hue = 0.0;
  44. void setup() {
  45. pinMode(13, OUTPUT); //LED on Model A
  46. pinMode(10, INPUT); //LED on Model A
  47. digitalWrite(13, LOW); //LED on Model A
  48. pinMode(PIN1, OUTPUT);
  49. pixels[0].begin();
  50. randomSeed(analogRead(10));
  51. mode = random(1,4);
  52. for(int i=0;i<=mode;i++) {
  53. digitalWrite(13, LOW); //LED on Model A
  54. delay(100);
  55. digitalWrite(13, HIGH); //LED on Model A
  56. delay(100);
  57. }
  58. }
  59. // the loop routine runs over and over again forever:
  60. void loop() {
  61. static double power = 1.5;
  62. static double fac = 0.5/pow(0.5,power);
  63. for(int i=0;i<NUMPIXELS;i++){
  64. int r,g,b;
  65. int hueOffset = (abs(CENTER-i)/(float)CENTER) * 50 * ( pow(mode,4) );
  66. double h = (hue + hueOffset)/360.,y;
  67. while(h>1) h-=1;
  68. if(h<=0.5)
  69. y = pow(h,power)*fac;
  70. else
  71. y = 1-pow(1-h,power)*fac;
  72. HSVtoRGB(y*360, 100, 20,r,g,b);
  73. pixels[0].setPixelColor(i, pixels[0].Color(r,g,b)); // Moderately bright green color.
  74. }
  75. pixels[0].show(); // This sends the updated pixel color to the hardware.
  76. hue -= 0.4;
  77. if(hue>=360) {
  78. hue -= 360;
  79. }
  80. if(hue<=0) {
  81. hue = 360 + hue;
  82. }
  83. // digitalWrite(1, LOW); //LED on Model A
  84. delay(5); // Delay for a period of time (in milliseconds).
  85. }