presets v0.2

This commit is contained in:
IMback
2017-05-23 10:17:36 +02:00
parent f37e2add81
commit 75a980ee6a
3 changed files with 29 additions and 33 deletions

View File

@ -19,7 +19,7 @@ set(COMPILE_FLAGS "" CACHE STRING "Additional Compiler Flags")
# Set own source files # Set own source files
# Simply list all your C / C++ source (not header!) files here # Simply list all your C / C++ source (not header!) files here
set(SRC_FILES main.cpp serial.cpp WirelessRelay.cpp pwm.cpp) set(SRC_FILES main.cpp serial.cpp WirelessRelay.cpp pwm.cpp rgbled.cpp)
# Compiler suite specification # Compiler suite specification
set(CMAKE_C_COMPILER /usr/bin/avr-gcc) set(CMAKE_C_COMPILER /usr/bin/avr-gcc)

View File

@ -1,8 +1,7 @@
void EEPROM_write_char(uint16_t address, unsigned char data) void EEPROM_write_char(uint16_t address, unsigned char data)
{ {
/* Wait for completion of previous write */ /* Wait for completion of previous write */
while(EECR & (1<<EEPE)) while(EECR & (1<<EEPE));
;
/* Set up address and Data Registers */ /* Set up address and Data Registers */
EEAR = address; EEAR = address;
EEDR = data; EEDR = data;
@ -15,8 +14,7 @@ void EEPROM_write_char(uint16_t address, unsigned char data)
unsigned char EEPROM_read_char(uint16_t uiAddress) unsigned char EEPROM_read_char(uint16_t uiAddress)
{ {
/* Wait for completion of previous write */ /* Wait for completion of previous write */
while(EECR & (1<<EEPE)) while(EECR & (1<<EEPE));
;
/* Set up address register */ /* Set up address register */
EEAR = uiAddress; EEAR = uiAddress;
/* Start eeprom read by writing EERE */ /* Start eeprom read by writing EERE */

View File

@ -7,6 +7,7 @@
#include "writepin.h" #include "writepin.h"
#include "WirelessRelay.h" #include "WirelessRelay.h"
#include "pwm.h" #include "pwm.h"
#include "rgbled.h"
#include "eeprom.h" #include "eeprom.h"
#define MAX_RELAYS 32 #define MAX_RELAYS 32
@ -28,8 +29,8 @@ inline static void printHelp(Serial* serial)
erase : Erase epprom\n\ erase : Erase epprom\n\
rgb [on/off] : Turn on/off RGB leds at current value.\n\ rgb [on/off] : Turn on/off RGB leds at current value.\n\
rgb print : Print current RGB value.\n\ rgb print : Print current RGB value.\n\
rgb set [RRR] [GGG] [BBB] : Set RGB value.\n\ rgb set [RRR] [GGG] [BBB] : Set RGB value, pattern must be 0.\n\
rgb pattern : RGB pattern\n\ rgb pattern [id] : RGB pattern\n\
version : Print Version.\n\n"); version : Print Version.\n\n");
} }
@ -87,24 +88,22 @@ void relayDispatch(WirelessRelayStore* relays, char* inBuffer, Serial* serial)
} }
} }
void rgbDispatch(Pwm8b* pwmTc0, Pwm8b* pwmTc2, char* inBuffer, Serial* serial) void rgbDispatch(RgbLed* rgbled, char* inBuffer, Serial* serial)
{ {
if( strncmp(inBuffer, "on", 2) == 0 ) if( strncmp(inBuffer, "on", 2) == 0 )
{ {
pwmTc0->on(); rgbled->on();
pwmTc2->on();
serial->putString("RGB lights on\n\n"); serial->putString("RGB lights on\n\n");
} }
else if( strncmp(inBuffer, "off", 3) == 0 ) else if( strncmp(inBuffer, "off", 3) == 0 )
{ {
pwmTc0->off(); rgbled->off();
pwmTc2->off();
serial->putString("RGB lights off\n\n"); serial->putString("RGB lights off\n\n");
} }
else if( strncmp(inBuffer, "print", 5) == 0 ) else if( strncmp(inBuffer, "print", 5) == 0 )
{ {
char buffer[64]; char buffer[64];
sprintf(buffer, "Current RGB values:\nR: %u G: %u B: %u\n\n", OCR0A, OCR0B, OCR2B); sprintf(buffer, "Current RGB values:\nR: %u G: %u B: %u\n\n", rgbled->getR(), rgbled->getG(), rgbled->getB());
serial->putString(buffer, 64); serial->putString(buffer, 64);
} }
else if( strncmp(inBuffer, "set", 3) == 0 ) else if( strncmp(inBuffer, "set", 3) == 0 )
@ -115,21 +114,27 @@ void rgbDispatch(Pwm8b* pwmTc0, Pwm8b* pwmTc2, char* inBuffer, Serial* serial)
{ {
inBuffer[7] = '\0'; inBuffer[7] = '\0';
inBuffer[11] = '\0'; inBuffer[11] = '\0';
pwmTc0->setDutyA(atoi(inBuffer+4)); rgbled->setSolidColor(atoi(inBuffer+4), atoi(inBuffer+8), atoi(inBuffer+12));
pwmTc0->setDutyB(atoi(inBuffer+8));
pwmTc2->setDutyB(atoi(inBuffer+12));
serial->putString("Set RGB values\n\n"); serial->putString("Set RGB values\n\n");
} }
else serial->putString("Usage: rgb set [RRR] [GGG] [BBB]\n\n"); else serial->putString("Usage: rgb set [RRR] [GGG] [BBB]\n\n");
} }
else if( strncmp(inBuffer, "pattern", 7) == 0 )
{
rgbled->setPattern(atoi(inBuffer+8));
}
else if( strncmp(inBuffer, "preset", 6) == 0 )
{
rgbled->setPreset(atoi(inBuffer+7));
}
else else
{ {
serial->putString(inBuffer, COMMAND_BUFFER_SIZE-4); serial->putString(inBuffer, COMMAND_BUFFER_SIZE-4);
serial->putString(" is not a valid subcommand: rgb [/on/off/print/set]\n\n"); serial->putString(" is not a valid subcommand: rgb [/on/off/print/set/pattern/preset]\n\n");
} }
} }
void serialDispatch(Serial* serial , WirelessRelayStore* relays, Pwm8b* pwmTc0, Pwm8b* pwmTc2) void serialDispatch(Serial* serial , WirelessRelayStore* relays, RgbLed* rgbled)
{ {
if(serial->dataIsWaiting()) if(serial->dataIsWaiting())
@ -147,7 +152,7 @@ void serialDispatch(Serial* serial , WirelessRelayStore* relays, Pwm8b* pwmTc0,
} }
else if(length > 2 && strncmp(buffer, "rgb", 3) == 0) else if(length > 2 && strncmp(buffer, "rgb", 3) == 0)
{ {
rgbDispatch(pwmTc0, pwmTc2, buffer+4, serial); rgbDispatch(rgbled, buffer+4, serial);
} }
else if(length > 4 && strncmp(buffer, "erase", 5) == 0) else if(length > 4 && strncmp(buffer, "erase", 5) == 0)
{ {
@ -200,29 +205,22 @@ int main()
*/ */
Pwm8b pwmTc0( &TCCR0A, &TCCR0B, &OCR0A, &OCR0B, 0b00000011, true, true ); Pwm8b pwmTc0( &TCCR0A, &TCCR0B, &OCR0A, &OCR0B, 0b00000011, true, true );
Pwm8b pwmTc2( &TCCR2A, &TCCR2B, &OCR2A, &OCR2B, 0b00000101, false, true ); Pwm8b pwmTc2( &TCCR2A, &TCCR2B, &OCR2A, &OCR2B, 0b00000101, false, true );
pwmTc0.off();
pwmTc2.off();
bool pattern = true; RgbLed rgbled( &pwmTc0, &pwmTc2 );
WirelessRelayStore relays; WirelessRelayStore relays;
relays.count=0; relays.count=0;
restore_relays(&relays); restore_relays(&relays);
uint8_t counter = 0; serial.putString("RGBController v0.2 starting\n\n");
serial.putString("RGBController v0.1 starting\n\n");
while(true) while(true)
{ {
serialDispatch(&serial, &relays, &pwmTc0, &pwmTc2); serialDispatch(&serial, &relays, &rgbled);
if(pattern) rgbled.logic();
{ _delay_ms(2);
counter++;
pwmTc0.setDutyA(counter);
pwmTc0.setDutyB(counter-64);
pwmTc2.setDutyB(counter-128);
_delay_ms(20);
}
} }
return 0; //master interupt. return 0; //master interupt.