/**************************************************************************** * This example was developed by the Hackerspace San Salvador to demonstrate * the simultaneous use of the NeoPixel library and the Bluetooth SoftDevice. * To compile this example you'll need to add support for the NRF52 based * following the instructions at: * https://github.com/sandeepmistry/arduino-nRF5 * Or adding the following URL to the board manager URLs on Arduino preferences: * https://sandeepmistry.github.io/arduino-nRF5/package_nRF5_boards_index.json * Then you can install the BLEPeripheral library avaiable at: * https://github.com/sandeepmistry/arduino-BLEPeripheral * To test it, compile this example and use the UART module from the nRF * Toolbox App for Android. Edit the interface and send the characters * 'a' to 'i' to switch the animation. * There is a delay because this example blocks the thread of execution but * the change will be shown after the current animation ends. (This might * take a couple of seconds) * For more info write us at: info _at- teubi.co */ #include #include #include "BLESerial.h" #include #define PIN 15 // Pin where NeoPixels are connected // Declare our NeoPixel strip object: Adafruit_NeoPixel strip(64, PIN, NEO_GRB + NEO_KHZ800); // Argument 1 = Number of pixels in NeoPixel strip // Argument 2 = Arduino pin number (most are valid) // Argument 3 = Pixel type flags, add together as needed: // NEO_KHZ800 800 KHz bitstream (most NeoPixel products w/WS2812 LEDs) // NEO_KHZ400 400 KHz (classic 'v1' (not v2) FLORA pixels, WS2811 drivers) // NEO_GRB Pixels are wired for GRB bitstream (most NeoPixel products) // NEO_RGB Pixels are wired for RGB bitstream (v1 FLORA pixels, not v2) // NEO_RGBW Pixels are wired for RGBW bitstream (NeoPixel RGBW products) // NEOPIXEL BEST PRACTICES for most reliable operation: // - Add 1000 uF CAPACITOR between NeoPixel strip's + and - connections. // - MINIMIZE WIRING LENGTH between microcontroller board and first pixel. // - NeoPixel strip's DATA-IN should pass through a 300-500 OHM RESISTOR. // - AVOID connecting NeoPixels on a LIVE CIRCUIT. If you must, ALWAYS // connect GROUND (-) first, then +, then data. // - When using a 3.3V microcontroller with a 5V-powered NeoPixel strip, // a LOGIC-LEVEL CONVERTER on the data line is STRONGLY RECOMMENDED. // (Skipping these may work OK on your workbench but can fail in the field) // define pins (varies per shield/board) #define BLE_REQ 10 #define BLE_RDY 2 #define BLE_RST 9 // create ble serial instance, see pinouts above BLESerial BLESerial(BLE_REQ, BLE_RDY, BLE_RST); uint8_t current_state = 0; uint8_t rgb_values[3]; void setup() { Serial.begin(115200); Serial.println("Hello World!"); // custom services and characteristics can be added as well BLESerial.setLocalName("UART_HS"); BLESerial.begin(); strip.begin(); // INITIALIZE NeoPixel strip object (REQUIRED) strip.show(); // Turn OFF all pixels ASAP //pinMode(PIN, OUTPUT); //digitalWrite(PIN, LOW); current_state = 'a'; } void loop() { while(BLESerial.available()) { uint8_t character = BLESerial.read(); switch(character) { case 'a': case 'b': case 'c': case 'd': case 'e': case 'f': case 'g': case 'h': current_state = character; break; }; } switch(current_state) { case 'a': colorWipe(strip.Color(255, 0, 0), 20); // Red break; case 'b': colorWipe(strip.Color( 0, 255, 0), 20); // Green break; case 'c': colorWipe(strip.Color( 0, 0, 255), 20); // Blue break; case 'd': theaterChase(strip.Color(255, 0, 0), 20); // Red break; case 'e': theaterChase(strip.Color( 0, 255, 0), 20); // Green break; case 'f': theaterChase(strip.Color(255, 0, 255), 20); // Cyan break; case 'g': rainbow(10); break; case 'h': theaterChaseRainbow(20); break; } } // Fill strip pixels one after another with a color. Strip is NOT cleared // first; anything there will be covered pixel by pixel. Pass in color // (as a single 'packed' 32-bit value, which you can get by calling // strip.Color(red, green, blue) as shown in the loop() function above), // and a delay time (in milliseconds) between pixels. void colorWipe(uint32_t color, int wait) { for(int i=0; i RGB strip.setPixelColor(c, color); // Set pixel 'c' to value 'color' } strip.show(); // Update strip with new contents delay(wait); // Pause for a moment firstPixelHue += 65536 / 90; // One cycle of color wheel over 90 frames } } }