Finished LED Rainbow
This commit is contained in:
parent
e5e833dfa6
commit
6533eb9cf1
@ -1,9 +1,10 @@
|
|||||||
CFLAGS = -O3 -Wall --std=c11
|
CFLAGS = -Os -Wall --std=c11 -g
|
||||||
CHIP = atmega328p
|
CHIP = atmega328p
|
||||||
SOURCE_FILES = $(wildcard *.c)
|
SOURCE_FILES = $(wildcard *.c)
|
||||||
OBJ_FILES = $(SOURCE_FILES:%.c=%.o)
|
OBJ_FILES = $(SOURCE_FILES:%.c=%.o)
|
||||||
BIN = led-driver.bin
|
BIN = led-driver.bin
|
||||||
HEX = led-driver.hex
|
HEX = led-driver.hex
|
||||||
|
ASM = led-driver.asm
|
||||||
|
|
||||||
default: $(HEX)
|
default: $(HEX)
|
||||||
|
|
||||||
@ -13,11 +14,18 @@ default: $(HEX)
|
|||||||
$(BIN): $(OBJ_FILES)
|
$(BIN): $(OBJ_FILES)
|
||||||
avr-gcc $(CFLAGS) -o $@ $^
|
avr-gcc $(CFLAGS) -o $@ $^
|
||||||
|
|
||||||
|
$(ASM): $(BIN)
|
||||||
|
avr-objdump -d -g -l -S $^ > $@
|
||||||
|
|
||||||
$(HEX): $(BIN)
|
$(HEX): $(BIN)
|
||||||
avr-objcopy -O ihex -j .text -j .data $^ $@
|
avr-objcopy -O ihex -j .text -j .data $^ $@
|
||||||
|
|
||||||
|
asm: $(ASM)
|
||||||
|
|
||||||
flash: $(HEX)
|
flash: $(HEX)
|
||||||
avrdude -p $(CHIP) -c arduino -B 115200 -P /dev/ttyACM1 -v -v -e -Uflash:w:$(HEX):a
|
avrdude -p $(CHIP) -c arduino -B 115200 -P /dev/ttyACM0 -v -v -e -Uflash:w:$(HEX):a
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
$(RM) $(OBJ_FILES) $(BIN) $(HEX)
|
$(RM) $(OBJ_FILES) $(BIN) $(HEX) $(ASM)
|
||||||
|
|
||||||
|
|
||||||
|
Binary file not shown.
26
sketches/led-driver/colors.h
Normal file
26
sketches/led-driver/colors.h
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
#ifndef _COLORS_H_
|
||||||
|
#define _COLORS_H_
|
||||||
|
|
||||||
|
#include <stddef.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
#define RGB_MAX 128
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
uint8_t r;
|
||||||
|
uint8_t g;
|
||||||
|
uint8_t b;
|
||||||
|
} rgb_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
uint16_t hue;
|
||||||
|
uint8_t sat;
|
||||||
|
uint8_t val;
|
||||||
|
} hsv_t;
|
||||||
|
|
||||||
|
hsv_t makeHSV(uint16_t hue, uint8_t sat, uint8_t val);
|
||||||
|
rgb_t hsv2rgb(hsv_t* hsv);
|
||||||
|
void hsv2rgbList(hsv_t* hsv, rgb_t* rgb, size_t count);
|
||||||
|
void interpolateLinearly(hsv_t start, hsv_t end, size_t steps, hsv_t *colors);
|
||||||
|
|
||||||
|
#endif
|
62
sketches/led-driver/colors.notc
Normal file
62
sketches/led-driver/colors.notc
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
#include "colors.h"
|
||||||
|
|
||||||
|
void interpolateLinearly(hsv_t start, hsv_t end, size_t steps, hsv_t *colors) {
|
||||||
|
if( steps == 1 ) {
|
||||||
|
colors[0] = start;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
for( size_t i = 0; i < steps; i++ ) {
|
||||||
|
hsv_t tmp;
|
||||||
|
tmp.hue = (uint16_t)((int16_t)start.hue + ((int16_t)end.hue - (int16_t)start.hue) * (int16_t)i / ((int16_t)steps-1));
|
||||||
|
tmp.sat = (uint8_t)((int16_t)start.sat + ((int16_t)end.sat - (int16_t)start.sat) * (int16_t)i / ((int16_t)steps-1));
|
||||||
|
tmp.val = (uint8_t)((int16_t)start.val + ((int16_t)end.val - (int16_t)start.val) * (int16_t)i / ((int16_t)steps-1));
|
||||||
|
colors[i] = tmp;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void hsv2rgbList(hsv_t* hsv, rgb_t* rgb, size_t count) {
|
||||||
|
for(size_t i = 0; i < count; ++i) {
|
||||||
|
rgb[i] = hsv2rgb(&hsv[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
rgb_t hsv2rgb(hsv_t* hsv) {
|
||||||
|
rgb_t res;
|
||||||
|
|
||||||
|
if(hsv->sat == 0) {
|
||||||
|
res.r = res.g = res.b = hsv->val;
|
||||||
|
} else {
|
||||||
|
float hue = (float) (hsv->hue<360?hsv->hue:hsv->hue-360);
|
||||||
|
float val = ((float) hsv->val ) / 100.0;
|
||||||
|
float sat = ((float) hsv->sat ) / 100.0;
|
||||||
|
|
||||||
|
uint8_t h = hue / 60;
|
||||||
|
float f = ( hue / 60 ) - h;
|
||||||
|
|
||||||
|
uint8_t p = RGB_MAX * ( val * ( 1 - sat ));
|
||||||
|
uint8_t q = RGB_MAX * ( val * ( 1 - sat * f ));
|
||||||
|
uint8_t t = RGB_MAX * ( val * ( 1 - sat * ( 1 - f )));
|
||||||
|
|
||||||
|
switch(h) {
|
||||||
|
case 0:
|
||||||
|
case 6: res.r = hsv->val; res.g = t; res.b = p; break;
|
||||||
|
case 1: res.r = q; res.g = hsv->val; res.b = p; break;
|
||||||
|
case 2: res.r = p; res.g = hsv->val; res.b = t; break;
|
||||||
|
case 3: res.r = p; res.g = q; res.b = hsv->val; break;
|
||||||
|
case 4: res.r = t; res.g = p; res.b = hsv->val; break;
|
||||||
|
case 5: res.r = hsv->hue; res.g = p; res.b = q; break;
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
hsv_t makeHSV(uint16_t hue, uint8_t sat, uint8_t val) {
|
||||||
|
hsv_t tmp;
|
||||||
|
tmp.hue = hue;
|
||||||
|
tmp.sat = sat;
|
||||||
|
tmp.val = val;
|
||||||
|
|
||||||
|
return tmp;
|
||||||
|
}
|
@ -1,17 +1,200 @@
|
|||||||
#define F_CPU 20000000UL
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
#include <stddef.h>
|
||||||
#include <avr/io.h>
|
#include <avr/io.h>
|
||||||
|
#define F_CPU 20000000UL
|
||||||
#include <util/delay.h>
|
#include <util/delay.h>
|
||||||
|
#include <stdbool.h>
|
||||||
#define BAUD 9600
|
#define BAUD 9600
|
||||||
#include <util/setbaud.h>
|
#include <util/setbaud.h>
|
||||||
|
|
||||||
|
#include "colors.notc"
|
||||||
|
|
||||||
|
/*
|
||||||
|
255 0 0
|
||||||
|
255 255 0
|
||||||
|
0 0 255
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
// f=20MHz -> T=0,05 µs
|
||||||
|
uint8_t T0H = 6; // == 0.3 µs ~ 0.4 µs (+- 150ns) == [0.25, 0.55] µs
|
||||||
|
uint8_t T1H = 14; // == 0.7 µs ~ 0.8 µs (+- 150ns) == [0.65, 0.95] µs
|
||||||
|
uint8_t T0L = 15; // == 0.75 µs ~ 0.85µs (+- 150ns) == [0.70, 1.00] µs
|
||||||
|
uint8_t T1L = 8; // == 0.35 µs ~ 0.45µs (+- 150ns) == [0.30, 0.60] µs
|
||||||
|
uint8_t RES = 51; // > 50 µs
|
||||||
|
*/
|
||||||
|
|
||||||
|
// #define VAR1
|
||||||
|
|
||||||
|
#ifdef VAR1
|
||||||
|
#define nop __asm__ ("nop")
|
||||||
|
|
||||||
|
#define wait6 __asm__ ("nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop")
|
||||||
|
#define wait8 __asm__ ("nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop")
|
||||||
|
#define wait14 __asm__ ("nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop")
|
||||||
|
#define wait15 __asm__ ("nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop")
|
||||||
|
#else
|
||||||
|
// https://github.com/cpldcpu/light_ws2812/blob/master/light_ws2812_AVR/Light_WS2812/light_ws2812.c
|
||||||
|
#define w_nop1 __asm__("nop \n\t")
|
||||||
|
#define w_nop2 __asm__("rjmp .+0 \n\t")
|
||||||
|
#define w_nop4 w_nop2; w_nop2
|
||||||
|
#define w_nop8 w_nop4; w_nop4
|
||||||
|
#define w_nop16 w_nop8; w_nop8
|
||||||
|
|
||||||
|
#define wait6 w_nop2; w_nop4
|
||||||
|
#define wait8 w_nop4; w_nop4
|
||||||
|
#define wait14 wait8; wait6
|
||||||
|
#define wait15 wait14; w_nop1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define HUE_DEGREE 120
|
||||||
|
#define HUE_MAX 610
|
||||||
|
#define HUE_MIN 350
|
||||||
|
#define LEDS 30
|
||||||
|
#define DELAYS 536
|
||||||
|
|
||||||
|
void uart_init();
|
||||||
|
void writeZero();
|
||||||
|
void writeOne();
|
||||||
|
void writeRGB(uint8_t red, uint8_t green, uint8_t blue);
|
||||||
|
void writeNothing(uint8_t c);
|
||||||
|
|
||||||
|
void mydelay(uint16_t ms) {
|
||||||
|
while(ms--) {
|
||||||
|
_delay_loop_2(5000); // 1ms
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int mainz()
|
||||||
|
{
|
||||||
|
DDRC = 1;
|
||||||
|
uint8_t d = 14;
|
||||||
|
|
||||||
|
while(1)
|
||||||
|
{
|
||||||
|
for(int i = 0; i < LEDS; i += 1)
|
||||||
|
writeRGB(85,0,0);
|
||||||
|
|
||||||
|
mydelay(DELAYS);
|
||||||
|
|
||||||
|
for(int i = 0; i < LEDS; i += 1)
|
||||||
|
writeRGB(0,0,85);
|
||||||
|
|
||||||
|
mydelay(DELAYS);
|
||||||
|
|
||||||
|
//~ for(int i = 0; i < LEDS; i += 1)
|
||||||
|
//~ writeRGB(0,128,0);
|
||||||
|
|
||||||
|
//~ mydelay(DELAYS);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main() {
|
||||||
|
DDRC = 1; // PORT C0 output
|
||||||
|
// uart_init();
|
||||||
|
|
||||||
|
uint16_t min = HUE_MIN, max = HUE_MAX;
|
||||||
|
uint8_t vl = 40;
|
||||||
|
uint16_t steps = 1;
|
||||||
|
bool falling = true;
|
||||||
|
hsv_t colorsHSV[LEDS];
|
||||||
|
rgb_t colorsRGB[LEDS];
|
||||||
|
|
||||||
|
do{
|
||||||
|
//~ if(left == 360){
|
||||||
|
//~ left = 180;
|
||||||
|
//~ right = 360;
|
||||||
|
//~ }else{
|
||||||
|
//~ left = 360;
|
||||||
|
//~ right = 180;
|
||||||
|
//~ }
|
||||||
|
|
||||||
|
interpolateLinearly(makeHSV(min, 100, 30), makeHSV(max, 100, 30), LEDS, colorsHSV);
|
||||||
|
|
||||||
|
hsv2rgbList(colorsHSV, colorsRGB, LEDS);
|
||||||
|
|
||||||
|
for( int i = 0; i < LEDS; i++){
|
||||||
|
writeRGB( colorsRGB[i].r, colorsRGB[i].g, colorsRGB[i].b);
|
||||||
|
}
|
||||||
|
|
||||||
|
// switch
|
||||||
|
if(falling){
|
||||||
|
min = min + steps;
|
||||||
|
max = max - steps;
|
||||||
|
} else {
|
||||||
|
min = min - steps;
|
||||||
|
max = max + steps;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(min == HUE_MAX || max == HUE_MAX) {
|
||||||
|
falling = !falling;
|
||||||
|
}
|
||||||
|
|
||||||
|
// pulse
|
||||||
|
//~ if(falling){
|
||||||
|
//~ vl -= steps;
|
||||||
|
//~ // right = right - steps;
|
||||||
|
//~ } else {
|
||||||
|
//~ vl += steps;
|
||||||
|
//~ right = right + steps;
|
||||||
|
//~ }
|
||||||
|
|
||||||
|
//~ if(vl == 5 || vl == 40){
|
||||||
|
//~ falling = !falling;
|
||||||
|
//~ }
|
||||||
|
|
||||||
|
//_delay_us(100);
|
||||||
|
}while(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void writeZero() {
|
||||||
|
PORTC = 1;
|
||||||
|
wait6;
|
||||||
|
PORTC = 0;
|
||||||
|
wait15;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void writeOne() {
|
||||||
|
PORTC = 1;
|
||||||
|
wait14;
|
||||||
|
PORTC = 0;
|
||||||
|
wait8;
|
||||||
|
}
|
||||||
|
|
||||||
|
void writeRGB(uint8_t red, uint8_t green, uint8_t blue) {
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for( i = 128; i > 0; i >>= 1 ) {
|
||||||
|
if( green & i ){
|
||||||
|
writeOne();
|
||||||
|
} else {
|
||||||
|
writeZero();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for( i = 128; i > 0; i >>= 1 ) {
|
||||||
|
if( red & i ){
|
||||||
|
writeOne();
|
||||||
|
} else {
|
||||||
|
writeZero();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for( i = 128; i > 0; i >>= 1 ) {
|
||||||
|
if( blue & i ){
|
||||||
|
writeOne();
|
||||||
|
} else {
|
||||||
|
writeZero();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void uart_init(void) {
|
void uart_init(void) {
|
||||||
#define BAUDRATE ((F_CPU)/(BAUD*8UL)-1) // set baud rate value for UBRR
|
#define BAUDRATE ((F_CPU)/(BAUD*8UL)-1) // set baud rate value for UBRR
|
||||||
UBRR0H = (BAUDRATE>>8); // shift the register right by 8 bits to get the upper 8 bits
|
UBRR0H = (BAUDRATE>>8); // shift the register right by 8 bits to get the upper 8 bits
|
||||||
UBRR0L = BAUDRATE; // set baud rate
|
UBRR0L = BAUDRATE & 0xff; // set baud rate
|
||||||
|
|
||||||
// UCSR0A |= (1 << U2X0); // double transmission speed
|
// UCSR0A |= (1 << U2X0); // double transmission speed
|
||||||
// UCSR0B = (1 << TXEN0) | (1 << RXEN0);
|
// UCSR0B = (1 << TXEN0) | (1 << RXEN0);
|
||||||
@ -28,73 +211,12 @@ void uart_init(void) {
|
|||||||
// UCSR0C = _BV(UCSZ01) | _BV(UCSZ00); /* 8-bit data */
|
// UCSR0C = _BV(UCSZ01) | _BV(UCSZ00); /* 8-bit data */
|
||||||
UCSR0C = 0x06; /* 8-bit data */
|
UCSR0C = 0x06; /* 8-bit data */
|
||||||
UCSR0B = _BV(RXEN0) | _BV(TXEN0) | _BV(RXCIE0); /* Enable RX and TX */
|
UCSR0B = _BV(RXEN0) | _BV(TXEN0) | _BV(RXCIE0); /* Enable RX and TX */
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
// f=20MHz -> T=0,05 µs
|
|
||||||
uint8_t T0H = 6; // == 0.3 µs ~ 0.4 µs (+- 150ns) == [0.25, 0.55] µs
|
|
||||||
uint8_t T1H = 14; // == 0.7 µs ~ 0.8 µs (+- 150ns) == [0.65, 0.95] µs
|
|
||||||
uint8_t T0L = 15; // == 0.75 µs ~ 0.85µs (+- 150ns) == [0.70, 1.00] µs
|
|
||||||
uint8_t T1L = 8; // == 0.35 µs ~ 0.45µs (+- 150ns) == [0.30, 0.60] µs
|
|
||||||
uint8_t RES = 51; // > 50 µs
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define wait6 __asm__("nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t")
|
void writeNothing(uint8_t c){
|
||||||
#define wait8 __asm__("nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t")
|
for(uint8_t i = 0; i < c; i++){
|
||||||
#define wait14 __asm__("nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t")
|
writeRGB(0,0,0);
|
||||||
#define wait15 __asm__("nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t")
|
|
||||||
|
|
||||||
uint8_t const CMAX = 32;
|
|
||||||
|
|
||||||
inline void writeZero() {
|
|
||||||
PORTC = 1;
|
|
||||||
wait6;
|
|
||||||
PORTC = 0;
|
|
||||||
wait15;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void writeOne() {
|
|
||||||
PORTC = 1;
|
|
||||||
wait14;
|
|
||||||
PORTC = 0;
|
|
||||||
wait8;
|
|
||||||
}
|
|
||||||
|
|
||||||
int main() {
|
|
||||||
DDRC = 1; // PORT C0 output
|
|
||||||
// uart_init();
|
|
||||||
|
|
||||||
do{
|
|
||||||
// for( int i = 0; i < 7; i++) {
|
|
||||||
// if( i%2==0){
|
|
||||||
writeZero();writeZero();writeZero();writeZero();writeZero();writeZero();writeZero();writeOne();
|
|
||||||
writeZero();writeZero();writeZero();writeZero();writeZero();writeZero();writeZero();writeZero();
|
|
||||||
writeZero();writeZero();writeZero();writeZero();writeZero();writeZero();writeZero();writeZero();
|
|
||||||
// } else {
|
|
||||||
writeZero();writeZero();writeZero();writeZero();writeZero();writeZero();writeZero();writeZero();
|
|
||||||
writeZero();writeZero();writeZero();writeZero();writeZero();writeZero();writeZero();writeZero();
|
|
||||||
writeZero();writeZero();writeZero();writeZero();writeZero();writeZero();writeZero();writeZero();
|
|
||||||
// }
|
|
||||||
|
|
||||||
// }
|
|
||||||
_delay_ms(500);
|
|
||||||
|
|
||||||
|
|
||||||
// loop_until_bit_is_set(UCSR0A, UDRE0);
|
|
||||||
// UDR0 = 'D';
|
|
||||||
|
|
||||||
}while(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
int main2( void )
|
|
||||||
{
|
|
||||||
DDRC = 0xff; // (1 << PC0);
|
|
||||||
|
|
||||||
while(1) {
|
|
||||||
PORTC ^= 0xff; //(1 << PC0);
|
|
||||||
_delay_ms(1000);
|
|
||||||
}
|
}
|
||||||
return 0;
|
_delay_ms(500);
|
||||||
}
|
}
|
||||||
|
203
sketches/led-driver/old-but-gold.jojo
Normal file
203
sketches/led-driver/old-but-gold.jojo
Normal file
@ -0,0 +1,203 @@
|
|||||||
|
#define F_CPU 20000000UL
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <avr/io.h>
|
||||||
|
#include <util/delay.h>
|
||||||
|
#define BAUD 9600
|
||||||
|
#include <util/setbaud.h>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void uart_init(void) {
|
||||||
|
#define BAUDRATE ((F_CPU)/(BAUD*8UL)-1) // set baud rate value for UBRR
|
||||||
|
UBRR0H = (BAUDRATE>>8); // shift the register right by 8 bits to get the upper 8 bits
|
||||||
|
UBRR0L = BAUDRATE; // set baud rate
|
||||||
|
|
||||||
|
// UCSR0A |= (1 << U2X0); // double transmission speed
|
||||||
|
// UCSR0B = (1 << TXEN0) | (1 << RXEN0);
|
||||||
|
// UCSR0C = (1 << UCSZ01) | (1 << UCSZ00);
|
||||||
|
|
||||||
|
// UBRR0H = UBRRH_VALUE;
|
||||||
|
// UBRR0L = UBRRL_VALUE;
|
||||||
|
|
||||||
|
|
||||||
|
UCSR0A |= _BV(U2X0);
|
||||||
|
// UCSR0A &= ~(_BV(U2X0));
|
||||||
|
|
||||||
|
|
||||||
|
// UCSR0C = _BV(UCSZ01) | _BV(UCSZ00); /* 8-bit data */
|
||||||
|
UCSR0C = 0x06; /* 8-bit data */
|
||||||
|
UCSR0B = _BV(RXEN0) | _BV(TXEN0) | _BV(RXCIE0); /* Enable RX and TX */
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
// f=20MHz -> T=0,05 µs
|
||||||
|
uint8_t T0H = 6; // == 0.3 µs ~ 0.4 µs (+- 150ns) == [0.25, 0.55] µs
|
||||||
|
uint8_t T1H = 14; // == 0.7 µs ~ 0.8 µs (+- 150ns) == [0.65, 0.95] µs
|
||||||
|
uint8_t T0L = 15; // == 0.75 µs ~ 0.85µs (+- 150ns) == [0.70, 1.00] µs
|
||||||
|
uint8_t T1L = 8; // == 0.35 µs ~ 0.45µs (+- 150ns) == [0.30, 0.60] µs
|
||||||
|
uint8_t RES = 51; // > 50 µs
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define nop __asm__("nop\n\t")
|
||||||
|
#define wait6 __asm__("nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t")
|
||||||
|
#define wait8 __asm__("nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t")
|
||||||
|
#define wait14 __asm__("nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t")
|
||||||
|
#define wait15 __asm__("nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t""nop\n\t")
|
||||||
|
|
||||||
|
uint8_t const CMAX = 32;
|
||||||
|
uint8_t const STEPWIDTH = 4;
|
||||||
|
|
||||||
|
void writeZero();
|
||||||
|
void writeOne();
|
||||||
|
void writeRGB(uint8_t red, uint8_t green, uint8_t blue);
|
||||||
|
|
||||||
|
static uint8_t dNext[] = {1,2,0};
|
||||||
|
|
||||||
|
int main() {
|
||||||
|
DDRC = 1; // PORT C0 output
|
||||||
|
// uart_init();
|
||||||
|
uint8_t d = 0;
|
||||||
|
uint8_t r = 120, g = 120, b = 0;
|
||||||
|
|
||||||
|
/*
|
||||||
|
255 0 0
|
||||||
|
255 255 0
|
||||||
|
0 0 255
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
do{
|
||||||
|
for(uint8_t i = 120; i > 0; i -= STEPWIDTH) {
|
||||||
|
if( i >= 60 )
|
||||||
|
writeRGB( 120, (120-i)*2 , 0 );
|
||||||
|
if( i <= 60 )
|
||||||
|
writeRGB( i, (60+i)/2, 120-i);
|
||||||
|
}
|
||||||
|
_delay_ms(500);
|
||||||
|
|
||||||
|
|
||||||
|
/*if( d == 0 ) {
|
||||||
|
do{
|
||||||
|
for( uint8_t i = 0; i < 10; i++) {
|
||||||
|
writeRGB(r,g,b);
|
||||||
|
}
|
||||||
|
for( uint8_t i = 0; i < 10; i++) {
|
||||||
|
writeRGB(b,g,r);
|
||||||
|
}
|
||||||
|
for( uint8_t i = 0; i < 10; i++) {
|
||||||
|
writeRGB(g,r,b);
|
||||||
|
}
|
||||||
|
_delay_ms(1);
|
||||||
|
r -=1;
|
||||||
|
b +=1;
|
||||||
|
}while(r > 0);
|
||||||
|
|
||||||
|
}
|
||||||
|
if( d == 1 ) {
|
||||||
|
do{
|
||||||
|
for( uint8_t i = 0; i < 10; i++) {
|
||||||
|
writeRGB(r,g,b);
|
||||||
|
}
|
||||||
|
for( uint8_t i = 0; i < 10; i++) {
|
||||||
|
writeRGB(b,g,r);
|
||||||
|
}
|
||||||
|
for( uint8_t i = 0; i < 10; i++) {
|
||||||
|
writeRGB(g,r,b);
|
||||||
|
}
|
||||||
|
_delay_ms(1);
|
||||||
|
r +=1;
|
||||||
|
g -=1;
|
||||||
|
}while(g > 0);
|
||||||
|
|
||||||
|
}
|
||||||
|
if( d == 2 ) {
|
||||||
|
do{
|
||||||
|
for( uint8_t i = 0; i < 10; i++) {
|
||||||
|
writeRGB(r,g,b);
|
||||||
|
}
|
||||||
|
for( uint8_t i = 0; i < 10; i++) {
|
||||||
|
writeRGB(b,g,r);
|
||||||
|
}
|
||||||
|
for( uint8_t i = 0; i < 10; i++) {
|
||||||
|
writeRGB(g,r,b);
|
||||||
|
}
|
||||||
|
_delay_ms(1);
|
||||||
|
b -=1;
|
||||||
|
g +=1;
|
||||||
|
}while(b > 0);
|
||||||
|
|
||||||
|
}
|
||||||
|
/* for( int i = 0; i<30; i++) {
|
||||||
|
// if( d == 0 )
|
||||||
|
writeRGB(r,g,b);
|
||||||
|
if( d == 1 )
|
||||||
|
writeRGB(0,128,0);
|
||||||
|
if( d == 2 )
|
||||||
|
writeRGB(0,0,128);
|
||||||
|
d = dNext[d];
|
||||||
|
}*/
|
||||||
|
// _delay_ms(500);
|
||||||
|
d = dNext[d];
|
||||||
|
|
||||||
|
|
||||||
|
// loop_until_bit_is_set(UCSR0A, UDRE0);
|
||||||
|
// UDR0 = 'D';
|
||||||
|
|
||||||
|
}while(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
int main2( void )
|
||||||
|
{
|
||||||
|
DDRC = 0xff; // (1 << PC0);
|
||||||
|
|
||||||
|
while(1) {
|
||||||
|
PORTC ^= 0xff; //(1 << PC0);
|
||||||
|
_delay_ms(1000);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void writeZero() {
|
||||||
|
PORTC = 1;
|
||||||
|
wait6;
|
||||||
|
PORTC = 0;
|
||||||
|
wait15;
|
||||||
|
}
|
||||||
|
|
||||||
|
void writeOne() {
|
||||||
|
PORTC = 1;
|
||||||
|
wait14;
|
||||||
|
PORTC = 0;
|
||||||
|
wait8;
|
||||||
|
}
|
||||||
|
|
||||||
|
void writeRGB(uint8_t red, uint8_t green, uint8_t blue) {
|
||||||
|
int i,j;
|
||||||
|
|
||||||
|
for( i = 128; i > 0; i >>= 1 ) {
|
||||||
|
if( green & i ){
|
||||||
|
writeOne();
|
||||||
|
} else {
|
||||||
|
writeZero();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for( i = 128; i > 0; i >>= 1 ) {
|
||||||
|
if( red & i ){
|
||||||
|
writeOne();
|
||||||
|
} else {
|
||||||
|
writeZero();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for( i = 128; i > 0; i >>= 1 ) {
|
||||||
|
if( blue & i ){
|
||||||
|
writeOne();
|
||||||
|
} else {
|
||||||
|
writeZero();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user