67 lines
1.6 KiB
C
67 lines
1.6 KiB
C
/**
|
|
* \defgroup squares Square patterns for the Borg.
|
|
* @{
|
|
*/
|
|
|
|
|
|
/**
|
|
* @file squares.c
|
|
* @brief Moves layers of translucent checker boards over each other.
|
|
* @author Christian Kroll
|
|
*/
|
|
|
|
|
|
#include <assert.h>
|
|
#include <stdint.h>
|
|
#include "../config.h"
|
|
#include "../util.h"
|
|
#include "../pixel.h"
|
|
#include "../random/prng.h"
|
|
#include "squares.h"
|
|
|
|
#define STEP ((uint8_t)(NUMPLANE * 2u))
|
|
#define TICK 100
|
|
#define CYCLES 200u
|
|
|
|
/**
|
|
* Moves layers of translucent checker boards over each other.
|
|
*/
|
|
void squares(void) {
|
|
// add a rotating color map for smooth transitions
|
|
uint8_t nColorMap[NUMPLANE * 2];
|
|
for (uint8_t i = 0; i < (NUMPLANE * 2); ++i) {
|
|
if (i < (NUMPLANE + 1)) {
|
|
nColorMap[i] = i;
|
|
} else {
|
|
nColorMap[i] = (NUMPLANE * 2) - i;
|
|
}
|
|
}
|
|
|
|
uint8_t nOffsets[NUMPLANE] = {0};
|
|
uint8_t nColOffset = 0;
|
|
for (uint8_t nCount = CYCLES; nCount--;) {
|
|
for (uint8_t x = 0; x < NUM_COLS ; ++x) {
|
|
for (uint8_t y = 0; y < NUM_ROWS; ++y) {
|
|
uint8_t nColor = 0;
|
|
for (uint8_t nLayer = 0; nLayer < NUMPLANE; ++nLayer) {
|
|
nColor += (uint8_t)(((x + nOffsets[nLayer]) / STEP) +
|
|
((y + nOffsets[nLayer] + STEP) / STEP)) % 2u;
|
|
}
|
|
setpixel((pixel){x, y},
|
|
nColorMap[(nColOffset + nColor) % (2* NUMPLANE)]);
|
|
}
|
|
}
|
|
|
|
// add randomly calculated offsets to each layer starting points
|
|
for (uint8_t i = 0; i < NUMPLANE; ++i) {
|
|
nOffsets[i] = (uint8_t)(nOffsets[i] + random8()) % STEP;
|
|
}
|
|
// rotate color map
|
|
nColOffset = (nColOffset + 1) % (NUMPLANE * 2);
|
|
|
|
// pause for a moment to ensure that frame transitions are visible
|
|
wait(TICK);
|
|
}
|
|
}
|
|
|
|
/*@}*/
|