mirror of
https://github.com/k3ng/k3ng_rotator_controller.git
synced 2025-01-23 21:08:04 +00:00
2017.05.13.01
Added the \V command to FEATURE_CLOCK to set timezone offset
This commit is contained in:
parent
886827f580
commit
f56f803567
@ -281,13 +281,16 @@
|
||||
2.0.2017042401
|
||||
configuration.brake_az_disabled is now set to 0 (not disabled) when initializing eeprom (Thanks, Patrick, TK5EP)
|
||||
|
||||
2017.05.13.01
|
||||
Added the \V command to FEATURE_CLOCK to set timezone offset
|
||||
|
||||
All library files should be placed in directories likes \sketchbook\libraries\library1\ , \sketchbook\libraries\library2\ , etc.
|
||||
Anything rotator_*.* should be in the ino directory!
|
||||
|
||||
|
||||
*/
|
||||
|
||||
#define CODE_VERSION "2.0.2017042401"
|
||||
#define CODE_VERSION "2017.05.13.01"
|
||||
|
||||
#include <avr/pgmspace.h>
|
||||
#include <EEPROM.h>
|
||||
@ -513,6 +516,7 @@ struct config_t {
|
||||
int azimuth_rotation_capability;
|
||||
#endif
|
||||
byte brake_az_disabled;
|
||||
float clock_timezone_offset;
|
||||
} configuration;
|
||||
|
||||
|
||||
@ -4117,6 +4121,7 @@ void initialize_eeprom_with_defaults(){
|
||||
configuration.azimuth_starting_point = AZIMUTH_STARTING_POINT_DEFAULT;
|
||||
configuration.azimuth_rotation_capability = AZIMUTH_ROTATION_CAPABILITY_DEFAULT;
|
||||
configuration.brake_az_disabled = 0; //(brake_az ? 1 : 0);
|
||||
configuration.clock_timezone_offset = 0;
|
||||
|
||||
#ifdef FEATURE_ELEVATION_CONTROL
|
||||
configuration.last_elevation = elevation;
|
||||
@ -9589,7 +9594,9 @@ char * clock_string(){
|
||||
}
|
||||
dtostrf(clock_seconds, 0, 0, temp_string);
|
||||
strcat(return_string, temp_string);
|
||||
strcat(return_string,"Z");
|
||||
if (configuration.clock_timezone_offset == 0){
|
||||
strcat(return_string,"Z");
|
||||
}
|
||||
return return_string;
|
||||
|
||||
} /* clock_string */
|
||||
@ -9602,7 +9609,7 @@ char * clock_string(){
|
||||
void update_time(){
|
||||
unsigned long runtime = millis() - millis_at_last_calibration;
|
||||
|
||||
unsigned long time = (3600L * clock_hour_set) + (60L * clock_min_set) + clock_sec_set + ((runtime + (runtime * INTERNAL_CLOCK_CORRECTION)) / 1000.0);
|
||||
unsigned long time = (configuration.clock_timezone_offset * 60L * 60L) + (3600L * clock_hour_set) + (60L * clock_min_set) + clock_sec_set + ((runtime + (runtime * INTERNAL_CLOCK_CORRECTION)) / 1000.0);
|
||||
|
||||
clock_years = clock_year_set;
|
||||
clock_months = clock_month_set;
|
||||
@ -9990,6 +9997,7 @@ byte process_backslash_command(byte input_buffer[], int input_buffer_index, byte
|
||||
byte temp_day = 0;
|
||||
byte temp_minute = 0;
|
||||
byte temp_hour = 0;
|
||||
byte negative_flag = 0;
|
||||
#endif // FEATURE_CLOCK
|
||||
|
||||
#if defined(FEATURE_MOON_TRACKING) || defined(FEATURE_SUN_TRACKING)
|
||||
@ -10237,10 +10245,6 @@ byte process_backslash_command(byte input_buffer[], int input_buffer_index, byte
|
||||
clock_sec_set = 0;
|
||||
millis_at_last_calibration = millis();
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#if defined(FEATURE_RTC_DS1307)
|
||||
rtc.adjust(DateTime(temp_year, temp_month, temp_day, temp_hour, temp_minute, 0));
|
||||
#endif // defined(FEATURE_RTC_DS1307)
|
||||
@ -10263,14 +10267,41 @@ byte process_backslash_command(byte input_buffer[], int input_buffer_index, byte
|
||||
update_time();
|
||||
strcat(return_string, clock_string());
|
||||
#endif
|
||||
|
||||
|
||||
} else {
|
||||
strcpy(return_string, "Error. Usage: \\OYYYYMMDDHHmm");
|
||||
}
|
||||
break;
|
||||
#endif // FEATURE_CLOCK
|
||||
|
||||
case 'V': // \Vx[xxx][.][xxxx] Set time zone offset
|
||||
negative_flag = 0;
|
||||
place_multiplier = 1;
|
||||
for (int x = input_buffer_index - 1; x > 1; x--) {
|
||||
if (char(input_buffer[x]) == '-') {
|
||||
negative_flag = 1;
|
||||
} else {
|
||||
if (char(input_buffer[x]) != '.') {
|
||||
tempfloat += (input_buffer[x] - 48) * place_multiplier;
|
||||
place_multiplier = place_multiplier * 10;
|
||||
} else {
|
||||
decimalplace = x;
|
||||
}
|
||||
}
|
||||
}
|
||||
if (decimalplace) {
|
||||
tempfloat = tempfloat / pow(10, (input_buffer_index - decimalplace - 1));
|
||||
}
|
||||
if (negative_flag){tempfloat = tempfloat * -1.0;}
|
||||
if ((tempfloat >= -24.0) && (tempfloat <= 24.0)) {
|
||||
configuration.clock_timezone_offset = tempfloat;
|
||||
configuration_dirty = 1;
|
||||
strcpy(return_string, "Timezone offset set to ");
|
||||
dtostrf(tempfloat, 0, 2, temp_string);
|
||||
strcat(return_string, temp_string);
|
||||
} else {
|
||||
strcpy(return_string, "Error.");
|
||||
}
|
||||
break;
|
||||
#endif // FEATURE_CLOCK
|
||||
|
||||
case 'D': // \D - Debug
|
||||
if (debug_mode & source_port) {
|
||||
|
@ -130,15 +130,15 @@
|
||||
#define OPTION_DISPLAY_HEADING_AZ_ONLY
|
||||
#define OPTION_DISPLAY_HEADING_EL_ONLY
|
||||
// #define OPTION_DISPLAY_HHMM_CLOCK // display HH:MM clock (set position with #define LCD_HHMM_CLOCK_POSITION)
|
||||
//#define OPTION_DISPLAY_HHMMSS_CLOCK // display HH:MM:SS clock (set position with #define LCD_HHMMSS_CLOCK_POSITION)
|
||||
// #define OPTION_DISPLAY_HHMMSS_CLOCK // display HH:MM:SS clock (set position with #define LCD_HHMMSS_CLOCK_POSITION)
|
||||
// #define OPTION_DISPLAY_ALT_HHMM_CLOCK_AND_MAIDENHEAD // display alternating HH:MM clock and maidenhead on LCD row 1 (set position with #define LCD_HHMMCLOCK_POSITION)
|
||||
// #define OPTION_DISPLAY_CONSTANT_HHMMSS_CLOCK_AND_MAIDENHEAD // display constant HH:MM:SS clock and maidenhead on LCD row 1 (set position with #define LCD_CONSTANT_HHMMSSCLOCK_MAIDENHEAD_POSITION)
|
||||
//#define OPTION_DISPLAY_BIG_CLOCK // display date & time clock (set row with #define LCD_BIG_CLOCK_ROW)
|
||||
#define OPTION_DISPLAY_BIG_CLOCK // display date & time clock (set row with #define LCD_BIG_CLOCK_ROW)
|
||||
//#define OPTION_CLOCK_ALWAYS_HAVE_HOUR_LEADING_ZERO
|
||||
#define OPTION_DISPLAY_GPS_INDICATOR // display GPS indicator on LCD - set position with LCD_GPS_INDICATOR_POSITION and LCD_GPS_INDICATOR_ROW
|
||||
#define OPTION_DISPLAY_MOON_TRACKING_CONTINUOUSLY
|
||||
//#define OPTION_DISPLAY_DIRECTION_STATUS // N, W, E, S, NW, etc. direction indicator
|
||||
#define OPTION_DISPLAY_SUN_TRACKING_CONTINUOUSLY
|
||||
// #define OPTION_DISPLAY_SUN_TRACKING_CONTINUOUSLY
|
||||
//#define OPTION_DISPLAY_MOON_OR_SUN_TRACKING_CONDITIONAL
|
||||
#define OPTION_DISPLAY_VERSION_ON_STARTUP //code provided by Paolo, IT9IPQ
|
||||
//#define OPTION_LCD_HEADING_FIELD_FIXED_DECIMAL_PLACE
|
||||
|
@ -153,7 +153,7 @@ You can tweak these, but read the online documentation!
|
||||
#define BRAKE_ACTIVE_STATE HIGH
|
||||
#define BRAKE_INACTIVE_STATE LOW
|
||||
|
||||
#define EEPROM_MAGIC_NUMBER 106
|
||||
#define EEPROM_MAGIC_NUMBER 107
|
||||
#define EEPROM_WRITE_DIRTY_CONFIG_TIME 30 //time in seconds
|
||||
|
||||
|
||||
|
@ -149,7 +149,7 @@ You can tweak these, but read the online documentation!
|
||||
#define BRAKE_ACTIVE_STATE HIGH
|
||||
#define BRAKE_INACTIVE_STATE LOW
|
||||
|
||||
#define EEPROM_MAGIC_NUMBER 104
|
||||
#define EEPROM_MAGIC_NUMBER 107
|
||||
#define EEPROM_WRITE_DIRTY_CONFIG_TIME 30 //time in seconds
|
||||
|
||||
|
||||
|
@ -149,7 +149,7 @@ You can tweak these, but read the online documentation!
|
||||
#define BRAKE_ACTIVE_STATE HIGH
|
||||
#define BRAKE_INACTIVE_STATE LOW
|
||||
|
||||
#define EEPROM_MAGIC_NUMBER 104
|
||||
#define EEPROM_MAGIC_NUMBER 107
|
||||
#define EEPROM_WRITE_DIRTY_CONFIG_TIME 30 //time in seconds
|
||||
|
||||
|
||||
|
@ -163,7 +163,7 @@ You can tweak these, but read the online documentation!
|
||||
#define BRAKE_ACTIVE_STATE HIGH
|
||||
#define BRAKE_INACTIVE_STATE LOW
|
||||
|
||||
#define EEPROM_MAGIC_NUMBER 105
|
||||
#define EEPROM_MAGIC_NUMBER 107
|
||||
#define EEPROM_WRITE_DIRTY_CONFIG_TIME 30 //time in seconds
|
||||
|
||||
|
||||
|
@ -150,7 +150,7 @@ You can tweak these, but read the online documentation!
|
||||
#define BRAKE_ACTIVE_STATE HIGH
|
||||
#define BRAKE_INACTIVE_STATE LOW
|
||||
|
||||
#define EEPROM_MAGIC_NUMBER 103
|
||||
#define EEPROM_MAGIC_NUMBER 107
|
||||
#define EEPROM_WRITE_DIRTY_CONFIG_TIME 30 //time in seconds
|
||||
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user