Compare commits
No commits in common. "5d722f41e8721d3f95ac2df85a51a141ff54b07a" and "d24d0b6d03dc88cf14156fa30b2ff5d8a61bc2d8" have entirely different histories.
5d722f41e8
...
d24d0b6d03
|
@ -16,17 +16,20 @@
|
||||||
|
|
||||||
void is31fl3729_init(uint8_t i2c_addr, uint8_t config, uint8_t global_current)
|
void is31fl3729_init(uint8_t i2c_addr, uint8_t config, uint8_t global_current)
|
||||||
{
|
{
|
||||||
|
uint8_t buf;
|
||||||
|
|
||||||
// enable device
|
// enable device
|
||||||
#ifdef FL3729_SDB_PORT
|
#ifdef FL3729_SDB_PORT
|
||||||
FL3729_SDB_PORT->BSHR = FL3729_SDB_PIN;
|
FL3729_SDB_PORT->BSHR = FL3729_SDB_PIN;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// reset config registers
|
// reset config registers
|
||||||
i2c_write_reg_8b(i2c_addr, FL3729_REG_CONFIG, FL3729_RESET_VALUE);
|
buf = FL3729_RESET_VALUE;
|
||||||
|
i2c_write_addr1b(i2c_addr, FL3729_REG_RESET, &buf, 1);
|
||||||
|
|
||||||
// write initial config
|
// write initial config
|
||||||
i2c_write_reg_8b(i2c_addr, FL3729_REG_CONFIG, config);
|
i2c_write_addr1b(i2c_addr, FL3729_REG_CONFIG, &config, 1);
|
||||||
i2c_write_reg_8b(i2c_addr, FL3729_REG_G_CURRENT, global_current);
|
i2c_write_addr1b(i2c_addr, FL3729_REG_G_CURRENT, &global_current, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t is31fl3729_get_addr(uint8_t adpin)
|
uint8_t is31fl3729_get_addr(uint8_t adpin)
|
||||||
|
@ -37,21 +40,21 @@ uint8_t is31fl3729_get_addr(uint8_t adpin)
|
||||||
|
|
||||||
void is31fl3729_set_global_current(uint8_t i2c_addr, uint8_t current)
|
void is31fl3729_set_global_current(uint8_t i2c_addr, uint8_t current)
|
||||||
{
|
{
|
||||||
i2c_write_reg_8b(i2c_addr, FL3729_REG_G_CURRENT, current);
|
i2c_write_addr1b(i2c_addr, FL3729_REG_G_CURRENT, ¤t, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void is31fl3729_set_scaling_current(uint8_t i2c_addr, uint8_t cs, uint8_t current)
|
void is31fl3729_set_scaling_current(uint8_t i2c_addr, uint8_t cs, uint8_t current)
|
||||||
{
|
{
|
||||||
if (cs > 0xf) return;
|
if (cs > 0xf) return;
|
||||||
|
|
||||||
i2c_write_reg_8b(i2c_addr, FL3729_REG_SCALING + cs, current);
|
i2c_write_addr1b(i2c_addr, FL3729_REG_SCALING + cs, ¤t, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* sets current limit of multiple outputs simultaneously, starting from CS1.
|
* sets current limit of multiple outputs simultaneously, starting from CS1.
|
||||||
* useful for initial register configuration.
|
* useful for initial register configuration.
|
||||||
*/
|
*/
|
||||||
void is31fl3729_set_scaling_current_multi(uint8_t i2c_addr, const uint8_t *current, uint8_t count)
|
void is31fl3729_set_scaling_current_multi(uint8_t i2c_addr, uint8_t *current, uint8_t count)
|
||||||
{
|
{
|
||||||
if (!count) return;
|
if (!count) return;
|
||||||
count &= 0xf;
|
count &= 0xf;
|
||||||
|
@ -64,9 +67,9 @@ void is31fl3729_set_scaling_current_multi(uint8_t i2c_addr, const uint8_t *curre
|
||||||
* sw: first switch segment to update. usually set this to 1 for the first switch.
|
* sw: first switch segment to update. usually set this to 1 for the first switch.
|
||||||
* if set to 0, will default to 1.
|
* if set to 0, will default to 1.
|
||||||
* *out: output data buffer
|
* *out: output data buffer
|
||||||
* len: length of buffer. up to end user to not exceed writing beyond register 0x90.
|
* len: length of buffer
|
||||||
*/
|
*/
|
||||||
void is31fl3729_set_outputs(uint8_t i2c_addr, uint8_t sw, const uint8_t *out, uint8_t len)
|
void is31fl3729_set_outputs(uint8_t i2c_addr, uint8_t sw, uint8_t *out, uint8_t len)
|
||||||
{
|
{
|
||||||
if (!sw) sw = 1;
|
if (!sw) sw = 1;
|
||||||
|
|
||||||
|
|
|
@ -25,24 +25,24 @@
|
||||||
#define FL3729_REG_OUTPUT 0x01
|
#define FL3729_REG_OUTPUT 0x01
|
||||||
#define FL3729_REG_SCALING 0x90
|
#define FL3729_REG_SCALING 0x90
|
||||||
#define FL3729_REG_CONFIG 0xA0
|
#define FL3729_REG_CONFIG 0xA0
|
||||||
#define FL3729_REG_G_CURRENT 0xA1 // global current
|
#define FL3729_REG_G_CURRENT 0xA1 // global current
|
||||||
#define FL3729_REG_PUPD 0xB0 // pull up / pull down
|
#define FL3729_REG_PUPD 0xB0 // pull up / pull down
|
||||||
#define FL3729_REG_SS 0xB1 // spread spectrum
|
#define FL3729_REG_SS 0xB1 // spread spectrum
|
||||||
#define FL3729_REG_PWM 0xB2
|
#define FL3729_REG_PWM 0xB2
|
||||||
#define FL3729_REG_RESET 0xCF
|
#define FL3729_REG_RESET 0xCF
|
||||||
|
|
||||||
|
|
||||||
#define FL3729_GCC_MAX 64 // maximum global current level
|
#define FL3729_GCC_MAX 64 // maximum global current level
|
||||||
|
|
||||||
#define FL3729_CONF_SSD_SHDN (0 << 0) // software shutdown
|
#define FL3729_CONF_SHDN_ENA 0
|
||||||
#define FL3729_CONF_SSD_NRML (1 << 0) // normal operation
|
#define FL3729_CONF_SHDN_DIS ((1 << 0) << 0)
|
||||||
|
|
||||||
#define FL3729_CONF_OSDE_OFF (0 << 1)
|
#define FL3729_CONF_OSDE_OFF 0
|
||||||
#define FL3729_CONF_OSDE_OPEN (1 << 1)
|
#define FL3729_CONF_OSDE_OPEN ((1 << 0) << 1)
|
||||||
#define FL3729_CONF_OSDE_SHORT (2 << 1)
|
#define FL3729_CONF_OSDE_SHORT ((1 << 1) << 1)
|
||||||
|
|
||||||
#define FL3729_CONF_LOGIC_LOLEV (0 << 3)
|
#define FL3729_CONF_LOGIC_LOLEV 0
|
||||||
#define FL3729_CONF_LOGIC_HILEV (1 << 3)
|
#define FL3729_CONF_LOGIC_HILEV ((1 << 0) << 3)
|
||||||
|
|
||||||
#define FL3729_CONF_MATRIX_9x15 0x00
|
#define FL3729_CONF_MATRIX_9x15 0x00
|
||||||
#define FL3729_CONF_MATRIX_8x16 0x10
|
#define FL3729_CONF_MATRIX_8x16 0x10
|
||||||
|
@ -68,15 +68,25 @@
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
typedef struct IS31FL3729_Conf {
|
||||||
|
uint8_t ad_pin;
|
||||||
|
uint8_t config;
|
||||||
|
uint8_t global_brightness;
|
||||||
|
} IS31FL3729_Conf;
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
void is31fl3729_init(uint8_t i2c_addr, uint8_t config, uint8_t global_current);
|
void is31fl3729_init(uint8_t i2c_addr, uint8_t config, uint8_t global_current);
|
||||||
|
|
||||||
uint8_t is31fl3729_get_addr(uint8_t adpin);
|
uint8_t is31fl3729_get_addr(uint8_t adpin);
|
||||||
|
|
||||||
void is31fl3729_set_global_current(uint8_t i2c_addr, uint8_t current);
|
void is31fl3729_set_global_current(uint8_t i2c_addr, uint8_t current);
|
||||||
void is31fl3729_set_scaling_current(uint8_t i2c_addr, uint8_t cs, uint8_t current);
|
void is31fl3729_set_scaling_current(uint8_t i2c_addr, uint8_t cs, uint8_t current);
|
||||||
void is31fl3729_set_scaling_current_multi(uint8_t i2c_addr, const uint8_t *current, uint8_t count);
|
void is31fl3729_set_scaling_current_multi(uint8_t i2c_addr, uint8_t *current, uint8_t count);
|
||||||
|
|
||||||
void is31fl3729_set_outputs(uint8_t i2c_addr, uint8_t sw, const uint8_t *out, uint8_t len);
|
void is31fl3729_set_outputs(uint8_t i2c_addr, uint8_t sw, uint8_t *out, uint8_t len);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -45,15 +45,6 @@ void userconf_load()
|
||||||
userconf.ledprog_setting[0][0] = 2; // rainbow: angle top left to bottom right
|
userconf.ledprog_setting[0][0] = 2; // rainbow: angle top left to bottom right
|
||||||
userconf.ledprog_setting[0][1] = 25; // rainbow: spacing
|
userconf.ledprog_setting[0][1] = 25; // rainbow: spacing
|
||||||
|
|
||||||
userconf.ledprog_setting[1][0] = 8; // lite then fade: fade rate
|
|
||||||
userconf.ledprog_setting[1][1] = 192; // lite then fade: hue
|
|
||||||
|
|
||||||
userconf.ledprog_setting[2][0] = 255; // twinkle: saturation
|
|
||||||
userconf.ledprog_setting[2][1] = 4; // twinkle: intensity
|
|
||||||
|
|
||||||
userconf.ledprog_setting[3][0] = 5; // alternate: offset in 22.5deg increments
|
|
||||||
userconf.ledprog_setting[3][1] = 244; // alternate: hue
|
|
||||||
|
|
||||||
userconf.checksum = checksum();
|
userconf.checksum = checksum();
|
||||||
userconf.checkval = CHECKVAL;
|
userconf.checkval = CHECKVAL;
|
||||||
}
|
}
|
||||||
|
|
|
@ -100,7 +100,7 @@ uint8_t i2c_read_reg_8b(uint8_t addr, uint8_t reg)
|
||||||
return dat;
|
return dat;
|
||||||
}
|
}
|
||||||
|
|
||||||
int8_t i2c_write_addr1b(uint8_t addr, uint8_t reg, const uint8_t *data, uint8_t len)
|
int8_t i2c_write_addr1b(uint8_t addr, uint8_t reg, uint8_t *data, uint8_t len)
|
||||||
{
|
{
|
||||||
timeout = I2C_TIMEOUT;
|
timeout = I2C_TIMEOUT;
|
||||||
while((I2C_GetFlagStatus(I2C1, I2C_FLAG_BUSY) != RESET) && timeout--);
|
while((I2C_GetFlagStatus(I2C1, I2C_FLAG_BUSY) != RESET) && timeout--);
|
||||||
|
@ -136,7 +136,7 @@ int8_t i2c_write_addr1b(uint8_t addr, uint8_t reg, const uint8_t *data, uint8_t
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void i2c_write_reg_8b(uint8_t addr, uint8_t reg, const uint8_t dat)
|
void i2c_write_reg_8b(uint8_t addr, uint8_t reg, uint8_t dat)
|
||||||
{
|
{
|
||||||
i2c_write_addr1b(addr, reg, &dat, 1);
|
i2c_write_addr1b(addr, reg, &dat, 1);
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,10 +14,10 @@
|
||||||
void i2c_init();
|
void i2c_init();
|
||||||
|
|
||||||
int8_t i2c_read_addr1b(uint8_t addr, uint8_t reg, uint8_t *data, uint8_t len);
|
int8_t i2c_read_addr1b(uint8_t addr, uint8_t reg, uint8_t *data, uint8_t len);
|
||||||
int8_t i2c_write_addr1b(uint8_t addr, uint8_t reg, const uint8_t *data, uint8_t len);
|
int8_t i2c_write_addr1b(uint8_t addr, uint8_t reg, uint8_t *data, uint8_t len);
|
||||||
|
|
||||||
uint8_t i2c_read_reg_8b(uint8_t addr, uint8_t reg);
|
uint8_t i2c_read_reg_8b(uint8_t addr, uint8_t reg);
|
||||||
void i2c_write_reg_8b(uint8_t addr, uint8_t reg, const uint8_t dat);
|
void i2c_write_reg_8b(uint8_t addr, uint8_t reg, uint8_t dat);
|
||||||
|
|
||||||
int8_t i2c_ack_poll(uint8_t devaddr);
|
int8_t i2c_ack_poll(uint8_t devaddr);
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
|
|
||||||
|
|
||||||
static const uint8_t rgb_map[9] = {0x04, 0x14, 0x01, 0x11, 0x07, 0x0a, 0x1a, 0x0d, 0x1d};
|
static const uint8_t rgb_map[9] = {0x04, 0x14, 0x01, 0x11, 0x07, 0x0a, 0x1a, 0x0d, 0x1d};
|
||||||
static const uint8_t cursor_map[3] = {0x16, 0x17, 0x18};
|
static const uint8_t cursor_map[3] = {0x17, 0x18, 0x19};
|
||||||
|
|
||||||
static const uint8_t LED_CIE_PWM_256I_256O[] = {
|
static const uint8_t LED_CIE_PWM_256I_256O[] = {
|
||||||
0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2,
|
0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2,
|
||||||
|
@ -48,7 +48,7 @@ void led_init()
|
||||||
uint8_t buf[FL3729_CS_OUTPUTS] = {0xff};
|
uint8_t buf[FL3729_CS_OUTPUTS] = {0xff};
|
||||||
|
|
||||||
is31fl3729_init(FL3729_ADDR,
|
is31fl3729_init(FL3729_ADDR,
|
||||||
FL3729_CONF_SSD_NRML | FL3729_CONF_OSDE_OFF | FL3729_CONF_MATRIX_2x16,
|
FL3729_CONF_SHDN_DIS | FL3729_CONF_OSDE_OFF | FL3729_CONF_MATRIX_2x16,
|
||||||
LED_INIT_CURRENT);
|
LED_INIT_CURRENT);
|
||||||
|
|
||||||
for (i = 0; i < FL3729_CS_OUTPUTS; i++) buf[i] = LED_INIT_SCALING;
|
for (i = 0; i < FL3729_CS_OUTPUTS; i++) buf[i] = LED_INIT_SCALING;
|
||||||
|
@ -83,8 +83,6 @@ void led_send()
|
||||||
out[cursor_map[2]] = cursor[2];
|
out[cursor_map[2]] = cursor[2];
|
||||||
|
|
||||||
is31fl3729_set_outputs(FL3729_ADDR, 1, out, 16+15);
|
is31fl3729_set_outputs(FL3729_ADDR, 1, out, 16+15);
|
||||||
|
|
||||||
led_updated = 0;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -10,7 +10,6 @@
|
||||||
#include "hsv2rgb.h"
|
#include "hsv2rgb.h"
|
||||||
#include "led.h"
|
#include "led.h"
|
||||||
#include "rand.h"
|
#include "rand.h"
|
||||||
#include "ui.h"
|
|
||||||
|
|
||||||
|
|
||||||
// led programs
|
// led programs
|
||||||
|
@ -155,17 +154,17 @@ void led_rgb_1_lite_then_fade(uint8_t preview, uint8_t tick)
|
||||||
i = 0;
|
i = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
hsv2rgb_8b(hue * 6, i, 255, &prog_rgb[0], &prog_rgb[1], &prog_rgb[2]);
|
hue *= 6;
|
||||||
|
hsv2rgb_8b(hue, i, 255, &prog_rgb[0], &prog_rgb[1], &prog_rgb[2]);
|
||||||
|
|
||||||
// make the rate adjustment a bit more intuitive
|
// make the rate adjustment a bit more intuitive
|
||||||
if (rate >= 254) rate = 255;
|
if (rate >= 254) rate = 255;
|
||||||
else rate >>= 2;
|
else rate >>= 2;
|
||||||
rate++;
|
|
||||||
|
|
||||||
// fade out anything that's already lit at user's rate
|
// fade out anything that's already lit at user's rate
|
||||||
for (i = 0; i < 9; i++) {
|
for (i = 0; i < 9; i++) {
|
||||||
if (lite_persist[i]) lite_persist[i]--;
|
if (lite_persist[i]) lite_persist[i]--;
|
||||||
else for (j = 0; j < 3; j++) {
|
else for (j = 0; j < 2; j++) {
|
||||||
if (rgb[i][j] > rate) rgb[i][j] -= rate; else rgb[i][j] = 0;
|
if (rgb[i][j] > rate) rgb[i][j] -= rate; else rgb[i][j] = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -202,8 +201,6 @@ void led_rgb_1_lite_then_fade(uint8_t preview, uint8_t tick)
|
||||||
|
|
||||||
for (i = start; i < end; i++) {
|
for (i = start; i < end; i++) {
|
||||||
rgb[i][0] = prog_rgb[0];
|
rgb[i][0] = prog_rgb[0];
|
||||||
rgb[i][1] = prog_rgb[1];
|
|
||||||
rgb[i][2] = prog_rgb[2];
|
|
||||||
lite_persist[i] = LITE_PERSIST;
|
lite_persist[i] = LITE_PERSIST;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -227,8 +224,6 @@ void led_rgb_1_lite_then_fade(uint8_t preview, uint8_t tick)
|
||||||
if (lite_idx == end) {
|
if (lite_idx == end) {
|
||||||
lite_timeout = LITE_IDLE_DWELL;
|
lite_timeout = LITE_IDLE_DWELL;
|
||||||
}
|
}
|
||||||
|
|
||||||
led_is_updated();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
lite_timeout--;
|
lite_timeout--;
|
||||||
|
@ -243,7 +238,7 @@ void led_rgb_1_lite_then_fade(uint8_t preview, uint8_t tick)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define TWINKLE_PERSIST 3;
|
#define TWINKLE_PERSIST 3;
|
||||||
#define TWINKLE_RGB_VAL 255
|
#define TWINKLE_RGB_VAL 240
|
||||||
uint8_t twinkle_set[9] = {0};
|
uint8_t twinkle_set[9] = {0};
|
||||||
|
|
||||||
void led_rgb_2_twinkle(uint8_t preview, uint8_t tick)
|
void led_rgb_2_twinkle(uint8_t preview, uint8_t tick)
|
||||||
|
@ -253,28 +248,26 @@ void led_rgb_2_twinkle(uint8_t preview, uint8_t tick)
|
||||||
uint8_t sat;
|
uint8_t sat;
|
||||||
|
|
||||||
// set
|
// set
|
||||||
if ((tick & 3) == 0) {
|
rnd = prng_get8();
|
||||||
rnd = prng_get8();
|
if (rnd >= userconf.ledprog_setting[2][1]) {
|
||||||
if (rnd < userconf.ledprog_setting[2][1]) {
|
// yup, we're doing it
|
||||||
// yup, we're doing it
|
rnd = prng_get16();
|
||||||
rnd = prng_get16();
|
rnd *= 1536;
|
||||||
rnd *= 1536;
|
rnd <<= 16;
|
||||||
rnd >>= 16;
|
|
||||||
|
|
||||||
sat = userconf.ledprog_setting[2][0];
|
sat = userconf.ledprog_setting[2][0];
|
||||||
if (sat >= 128) sat = 128 - (sat - 128);
|
if (sat >= 128) sat = 128 - (sat - 128);
|
||||||
sat <<= 1;
|
sat <<= 1;
|
||||||
|
|
||||||
hsv2rgb_8b(rnd, sat, TWINKLE_RGB_VAL, &prog_rgb[0], &prog_rgb[1], &prog_rgb[2]);
|
hsv2rgb_8b(rnd, sat, TWINKLE_RGB_VAL, &prog_rgb[0], &prog_rgb[1], &prog_rgb[2]);
|
||||||
|
|
||||||
rnd = prng_get16() & 0xfff;
|
rnd = prng_get16() & 0xfff;
|
||||||
rnd /= 455;
|
rnd /= 455;
|
||||||
|
|
||||||
rgb[rnd][0] = prog_rgb[0];
|
rgb[rnd][0] = prog_rgb[0];
|
||||||
rgb[rnd][1] = prog_rgb[1];
|
rgb[rnd][1] = prog_rgb[1];
|
||||||
rgb[rnd][2] = prog_rgb[2];
|
rgb[rnd][2] = prog_rgb[2];
|
||||||
twinkle_set[rnd] = TWINKLE_PERSIST;
|
twinkle_set[rnd] = TWINKLE_PERSIST;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// decay
|
// decay
|
||||||
|
@ -285,8 +278,6 @@ void led_rgb_2_twinkle(uint8_t preview, uint8_t tick)
|
||||||
else rgb[i][j] >>= 1;
|
else rgb[i][j] >>= 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
led_is_updated();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -301,7 +292,7 @@ void led_rgb_3_alternate(uint8_t preview, uint8_t tick)
|
||||||
uint8_t i, j;
|
uint8_t i, j;
|
||||||
|
|
||||||
uint16_t hue = userconf.ledprog_setting[3][1] * 6;
|
uint16_t hue = userconf.ledprog_setting[3][1] * 6;
|
||||||
uint16_t offset = (userconf.ledprog_setting[3][0] & 0xf) * 16 * 6;
|
uint8_t offset = (userconf.ledprog_setting[3][0] & 0xf) * 16 * 6;
|
||||||
|
|
||||||
uint8_t is_flashing = 0;
|
uint8_t is_flashing = 0;
|
||||||
|
|
||||||
|
@ -316,8 +307,6 @@ void led_rgb_3_alternate(uint8_t preview, uint8_t tick)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// don't need to update flashing state. this is handled by the cursor
|
|
||||||
|
|
||||||
// set hues
|
// set hues
|
||||||
for (i = 0; i < 2; i++) {
|
for (i = 0; i < 2; i++) {
|
||||||
hsv2rgb_8b(hue, 255, 255, &prog_rgb[0], &prog_rgb[1], &prog_rgb[2]);
|
hsv2rgb_8b(hue, 255, 255, &prog_rgb[0], &prog_rgb[1], &prog_rgb[2]);
|
||||||
|
@ -359,22 +348,18 @@ void led_rgb_3_alternate(uint8_t preview, uint8_t tick)
|
||||||
#define TYPING_CHAR_DELAY_MIN 12 // about 1/10 of a second
|
#define TYPING_CHAR_DELAY_MIN 12 // about 1/10 of a second
|
||||||
#define TYPING_CHAR_DELAY_MAX 500 // just shy of 4 seconds
|
#define TYPING_CHAR_DELAY_MAX 500 // just shy of 4 seconds
|
||||||
|
|
||||||
// the idle thing looked like shit.
|
static const uint8_t idle_glow[3] = {12, 8, 8};
|
||||||
// it's also broken.
|
|
||||||
// instead of removing, just set to 0 for now,
|
|
||||||
// and maybe address it later.
|
|
||||||
static const uint8_t idle_glow[3] = {0, 0, 0}; // {12, 8, 8};
|
|
||||||
static const uint8_t typing[3][3] = {
|
static const uint8_t typing[3][3] = {
|
||||||
{255, 240, 240}, // white
|
{255, 240, 240}, // white
|
||||||
{ 0, 240, 0}, // green
|
{ 0, 240, 0}, // green
|
||||||
{255, 96, 12}, // orange
|
{255, 96, 12}, // orange
|
||||||
};
|
};
|
||||||
|
|
||||||
static uint8_t typing_idx = 255;
|
static uint8_t typing_idx;
|
||||||
static uint16_t typing_char_delay = 0;
|
static uint16_t typing_char_delay;
|
||||||
|
|
||||||
static uint8_t typing_flash_state = 0;
|
static uint8_t typing_flash_state;
|
||||||
static uint8_t typing_flash_delay = 0;
|
static uint8_t typing_flash_delay;
|
||||||
|
|
||||||
static uint8_t typing_fadeout;
|
static uint8_t typing_fadeout;
|
||||||
|
|
||||||
|
@ -385,7 +370,6 @@ void led_rgb_4_typing(uint8_t preview, uint8_t tick)
|
||||||
uint8_t w;
|
uint8_t w;
|
||||||
uint16_t s;
|
uint16_t s;
|
||||||
uint8_t color;
|
uint8_t color;
|
||||||
uint8_t update = 0;
|
|
||||||
|
|
||||||
// match cursor color (well, approximate, or go green)
|
// match cursor color (well, approximate, or go green)
|
||||||
color = userconf.cursor_color;
|
color = userconf.cursor_color;
|
||||||
|
@ -396,35 +380,39 @@ void led_rgb_4_typing(uint8_t preview, uint8_t tick)
|
||||||
typing_flash_state++;
|
typing_flash_state++;
|
||||||
typing_flash_state &= 1;
|
typing_flash_state &= 1;
|
||||||
|
|
||||||
typing_flash_delay = cursor_flash_rates[userconf.cursor_flash];
|
typing_flash_delay = userconf.cursor_flash;
|
||||||
update = 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
typing_flash_delay--;
|
typing_flash_delay--;
|
||||||
|
|
||||||
// set rgb colors as appropriate
|
// set rgb colors as appropriate
|
||||||
for (i = 0; i < 9; i++) {
|
for (i = 0; i < 9; i++) {
|
||||||
for (j = 0; j < 3; j++) {
|
if (i < typing_idx || ((i == typing_idx) && (typing_flash_state))) {
|
||||||
if ((i < typing_idx) || ((i == typing_idx) && typing_flash_state)) {
|
// these are on
|
||||||
// these are on
|
rgb[i][0] = typing[color][0];
|
||||||
rgb[i][j] = typing[color][j];
|
rgb[i][1] = typing[color][1];
|
||||||
}
|
rgb[i][2] = typing[color][2];
|
||||||
|
}
|
||||||
|
|
||||||
if (i > typing_idx) { // || ((i == typing_idx) && !typing_flash_state)) {
|
if (i > typing_idx || ((i == typing_idx) && (!typing_flash_state))) {
|
||||||
// these are idle
|
// these are idle
|
||||||
rgb[i][j] = idle_glow[j];
|
rgb[i][0] = idle_glow[0];
|
||||||
}
|
rgb[i][1] = idle_glow[1];
|
||||||
|
rgb[i][2] = idle_glow[2];
|
||||||
|
}
|
||||||
|
|
||||||
// flashing cursor fadeout
|
// flashing cursor fadeout
|
||||||
if ((i == typing_idx) && !typing_flash_state) {
|
if (i == typing_idx && typing_flash_state) {
|
||||||
if (rgb[i][j] > 32) rgb[i][j] -= 32; else rgb[i][j] = 0;
|
if (typing_flash_delay <= 8) {
|
||||||
update = 1;
|
w = 8 - typing_flash_delay;
|
||||||
|
rgb[i][0] >>= w; if (rgb[i][0] < idle_glow[0]) rgb[i][0] = idle_glow[0];
|
||||||
|
rgb[i][1] >>= w; if (rgb[i][1] < idle_glow[1]) rgb[i][1] = idle_glow[1];
|
||||||
|
rgb[i][2] >>= w; if (rgb[i][2] < idle_glow[2]) rgb[i][2] = idle_glow[2];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// set cursor as appropriate
|
// set cursor as appropriate
|
||||||
for (i = 0; i < 3; i++) {
|
for (i = 0; i < 2; i++) {
|
||||||
cursor[i] = 0;
|
cursor[i] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -444,7 +432,7 @@ void led_rgb_4_typing(uint8_t preview, uint8_t tick)
|
||||||
else typing_fadeout = 0;
|
else typing_fadeout = 0;
|
||||||
|
|
||||||
for (i = 0; i < 9; i++) {
|
for (i = 0; i < 9; i++) {
|
||||||
for (j = 0; j < 3; j++) {
|
for (j = 0; j < 2; j++) {
|
||||||
s = rgb[i][j];
|
s = rgb[i][j];
|
||||||
s *= typing_fadeout;
|
s *= typing_fadeout;
|
||||||
rgb[i][j] = s >> 8;
|
rgb[i][j] = s >> 8;
|
||||||
|
@ -457,7 +445,7 @@ void led_rgb_4_typing(uint8_t preview, uint8_t tick)
|
||||||
}
|
}
|
||||||
|
|
||||||
// are we on the next character?
|
// are we on the next character?
|
||||||
if (!typing_char_delay) {
|
if (!(--typing_char_delay)) {
|
||||||
// next character
|
// next character
|
||||||
typing_idx++;
|
typing_idx++;
|
||||||
|
|
||||||
|
@ -465,8 +453,8 @@ void led_rgb_4_typing(uint8_t preview, uint8_t tick)
|
||||||
// at the cursor, we wait two max periods
|
// at the cursor, we wait two max periods
|
||||||
typing_char_delay = TYPING_CHAR_DELAY_MAX << 1;
|
typing_char_delay = TYPING_CHAR_DELAY_MAX << 1;
|
||||||
} else if (typing_idx == 10) {
|
} else if (typing_idx == 10) {
|
||||||
// at the end, we wait one max period
|
// at the end, we wait half of one max period
|
||||||
typing_char_delay = TYPING_CHAR_DELAY_MAX;
|
typing_char_delay = TYPING_CHAR_DELAY_MAX >> 1;
|
||||||
} else {
|
} else {
|
||||||
typing_char_delay = prng_scale16(TYPING_CHAR_DELAY_MIN, TYPING_CHAR_DELAY_MAX);
|
typing_char_delay = prng_scale16(TYPING_CHAR_DELAY_MIN, TYPING_CHAR_DELAY_MAX);
|
||||||
}
|
}
|
||||||
|
@ -481,12 +469,6 @@ void led_rgb_4_typing(uint8_t preview, uint8_t tick)
|
||||||
typing_flash_state = 0;
|
typing_flash_state = 0;
|
||||||
typing_flash_delay = 0;
|
typing_flash_delay = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
typing_char_delay--;
|
|
||||||
|
|
||||||
if (update) {
|
|
||||||
led_is_updated();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -151,12 +151,12 @@ static uint32_t tinymt32_temper (tinymt32_t* s)
|
||||||
|
|
||||||
uint16_t prng_scale16(uint16_t min, uint16_t max)
|
uint16_t prng_scale16(uint16_t min, uint16_t max)
|
||||||
{
|
{
|
||||||
uint32_t rnd;
|
uint16_t rnd;
|
||||||
|
|
||||||
rnd = prng_get16();
|
rnd = prng_get16();
|
||||||
rnd *= (max - min);
|
rnd *= (max - min);
|
||||||
rnd >>= 16;
|
rnd >>= 16;
|
||||||
rnd += min;
|
rnd += min;
|
||||||
|
|
||||||
return (uint16_t)rnd;
|
return rnd;
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,7 +38,7 @@ static uint8_t target_gc = 0;
|
||||||
|
|
||||||
static uint8_t cursor_flash = 0;
|
static uint8_t cursor_flash = 0;
|
||||||
static uint8_t cursor_state = 0xff;
|
static uint8_t cursor_state = 0xff;
|
||||||
const uint16_t cursor_flash_rates[8] = { // off-to-on flash rates in 1/256 second increments
|
static const uint16_t cursor_flash_rates[] = { // off-to-on flash rates in 1/256 second increments
|
||||||
255, // (0.5 on-off/second)
|
255, // (0.5 on-off/second)
|
||||||
191, // (0.75 on-off/second)
|
191, // (0.75 on-off/second)
|
||||||
127, // (1.0 on-off/second)
|
127, // (1.0 on-off/second)
|
||||||
|
@ -485,13 +485,12 @@ void ui_render()
|
||||||
}
|
}
|
||||||
|
|
||||||
// actually run the program
|
// actually run the program
|
||||||
led_rgbprog[rgb_prog_idx](LED_RGBPROG_NORMAL, tick);
|
led_rgbprog[rgb_prog_idx - 1](LED_RGBPROG_NORMAL, tick);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// temp: remove me once buttons are tested and working
|
// temp: remove me once buttons are tested and working
|
||||||
rgb_prog_idx = 4;
|
led_rgbprog[0](LED_RGBPROG_NORMAL, tick);
|
||||||
led_rgbprog[rgb_prog_idx](LED_RGBPROG_NORMAL, tick);
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,10 +10,6 @@
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
extern const uint16_t cursor_flash_rates[8];
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void ui_init();
|
void ui_init();
|
||||||
void ui_render();
|
void ui_render();
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue