Created
January 15, 2024 19:09
-
-
Save chemdoc77/2e37248bd4aa25901bc2c16ac928402f to your computer and use it in GitHub Desktop.
Kreigsman's SmartMatrixSwirl modified for WS2812B Matrix
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// Kreigsman's SmartMatrixSwirl from https://gist.github.com/kriegsman/5adca44e14ad025e6d3b | |
// Modified for WS2812B Matrix by Chemdoc77 | |
//#include <SmartMatrix.h> | |
#include <FastLED.h> | |
const uint8_t kMatrixWidth = 16; | |
const uint8_t kMatrixHeight = 16; | |
const uint8_t kBorderWidth = 2; | |
#define NUM_LEDS (kMatrixWidth*kMatrixHeight) | |
CRGB leds[NUM_LEDS]; | |
#define DATA_PIN 6 | |
#define LED_TYPE NEOPIXEL | |
int brightness = 50; | |
// Color correction for the SmartMatrix | |
//#define COLOR_CORRECTION CRGB(255,110,178) | |
void setup() | |
{ | |
delay(1000); | |
FastLED.addLeds<LED_TYPE, DATA_PIN>(leds, NUM_LEDS); | |
FastLED.setDither(false); | |
FastLED.setCorrection(TypicalLEDStrip); | |
FastLED.setBrightness(brightness); | |
FastLED.setMaxPowerInVoltsAndMilliamps(5, 5000); | |
set_max_power_indicator_LED(13); | |
fill_solid(leds, NUM_LEDS, CRGB::Black); | |
FastLED.show(); | |
// FastLED.addLeds<SMART_MATRIX>(leds, NUM_LEDS).setCorrection(COLOR_CORRECTION); | |
} | |
void loop() | |
{ | |
// Apply some blurring to whatever's already on the matrix | |
// Note that we never actually clear the matrix, we just constantly | |
// blur it repeatedly. Since the blurring is 'lossy', there's | |
// an automatic trend toward black -- by design. | |
uint8_t blurAmount = beatsin8(2,10,255); | |
blur2d( leds, kMatrixWidth, kMatrixHeight, blurAmount); | |
// Use two out-of-sync sine waves | |
uint8_t i = beatsin8( 27, kBorderWidth, kMatrixHeight-kBorderWidth); | |
uint8_t j = beatsin8( 41, kBorderWidth, kMatrixWidth-kBorderWidth); | |
// Also calculate some reflections | |
uint8_t ni = (kMatrixWidth-1)-i; | |
uint8_t nj = (kMatrixWidth-1)-j; | |
// The color of each point shifts over time, each at a different speed. | |
uint16_t ms = millis(); | |
leds[XY( i, j)] += CHSV( ms / 11, 200, 255); | |
leds[XY( j, i)] += CHSV( ms / 13, 200, 255); | |
leds[XY(ni,nj)] += CHSV( ms / 17, 200, 255); | |
leds[XY(nj,ni)] += CHSV( ms / 29, 200, 255); | |
leds[XY( i,nj)] += CHSV( ms / 37, 200, 255); | |
leds[XY(ni, j)] += CHSV( ms / 41, 200, 255); | |
FastLED.show(); | |
} | |
// Trivial XY function for the SmartMatrix; use a different XY | |
// function for different matrix grids. See XYMatrix example for code. | |
uint16_t XY( uint8_t x, uint8_t y) { return (y * kMatrixWidth) + x; } |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment