ws2812.h 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. /*
  2. * light weight WS2812 lib include
  3. *
  4. * Version 2.3 - Nev 29th 2015
  5. * Author: Tim (cpldcpu@gmail.com)
  6. *
  7. * Please do not change this file! All configuration is handled in "ws2812_config.h"
  8. *
  9. * This program is free software: you can redistribute it and/or modify
  10. * it under the terms of the GNU General Public License as published by
  11. * the Free Software Foundation, either version 2 of the License, or
  12. * (at your option) any later version.
  13. *
  14. * This program is distributed in the hope that it will be useful,
  15. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  17. * GNU General Public License for more details.
  18. *
  19. * You should have received a copy of the GNU General Public License
  20. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  21. */
  22. #ifndef LIGHT_WS2812_H_
  23. #define LIGHT_WS2812_H_
  24. #include <avr/io.h>
  25. #include <avr/interrupt.h>
  26. //#include "ws2812_config.h"
  27. //#include "i2cmaster.h"
  28. #include "rgblight_types.h"
  29. void WS2812_init(void);
  30. void WS2812_set_color( uint8_t index, uint8_t red, uint8_t green, uint8_t blue );
  31. void WS2812_set_color_all( uint8_t red, uint8_t green, uint8_t blue );
  32. void WS2812_send_colors(void);
  33. /* User Interface
  34. *
  35. * Input:
  36. * ledarray: An array of GRB data describing the LED colors
  37. * number_of_leds: The number of LEDs to write
  38. * pinmask (optional): Bitmask describing the output bin. e.g. _BV(PB0)
  39. *
  40. * The functions will perform the following actions:
  41. * - Set the data-out pin as output
  42. * - Send out the LED data
  43. * - Wait 50�s to reset the LEDs
  44. */
  45. void ws2812_setleds (LED_TYPE *ledarray, uint16_t number_of_leds);
  46. void ws2812_setleds_pin (LED_TYPE *ledarray, uint16_t number_of_leds,uint8_t pinmask);
  47. void ws2812_setleds_rgbw(LED_TYPE *ledarray, uint16_t number_of_leds);
  48. /*
  49. * Old interface / Internal functions
  50. *
  51. * The functions take a byte-array and send to the data output as WS2812 bitstream.
  52. * The length is the number of bytes to send - three per LED.
  53. */
  54. void ws2812_sendarray (uint8_t *array,uint16_t length);
  55. void ws2812_sendarray_mask(uint8_t *array,uint16_t length, uint8_t pinmask);
  56. /*
  57. * Internal defines
  58. */
  59. #ifndef CONCAT
  60. #define CONCAT(a, b) a ## b
  61. #endif
  62. #ifndef CONCAT_EXP
  63. #define CONCAT_EXP(a, b) CONCAT(a, b)
  64. #endif
  65. // #define ws2812_PORTREG CONCAT_EXP(PORT,ws2812_port)
  66. // #define ws2812_DDRREG CONCAT_EXP(DDR,ws2812_port)
  67. #endif /* LIGHT_WS2812_H_ */