123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168 |
- #include <SoftwareSerial.h>
- #include <TinyGPS.h>
- TinyGPS gps;
- SoftwareSerial ss(3, 2);
- unsigned long pattern = 0x00000000; //0000 speed, 0000 error
- static void smartdelay(unsigned long ms);
- static void print_float(float val, float invalid, int len, int prec);
- static void print_int(unsigned long val, unsigned long invalid, int len);
- static void print_date(TinyGPS &gps);
- static void print_str(const char *str, int len);
- long readVcc();
- void setup()
- {
- Serial.begin(115200);
- pinMode(13, OUTPUT);/*
- Serial.print("Testing TinyGPS library v. "); Serial.println(TinyGPS::library_version());
- Serial.println("by Mikal Hart");
- Serial.println();
- Serial.println("Date, Latitude, Longitude, Altitude, HDOP, Sats");
- Serial.println("------------------------------------------------");
- */
- ss.begin(9600);
- }
- float flat, flon;
- unsigned long age, date, time, chars = 0, chars2 = 0;
- unsigned short sentences = 0, sentences2 = 0, failed = 0;
- void loop()
- {
- gps.stats(&chars, &sentences, &failed);
- if(gps.satellites() != TinyGPS::GPS_INVALID_SATELLITES && sentences != sentences2) {
- gps.f_get_position(&flat, &flon, &age);
- Serial.print(",");
- print_date(gps);
- Serial.print(",");
- Serial.print(flat,6);
- Serial.print(",");
- Serial.print(flon,6);
- Serial.print(",");
- Serial.print(gps.f_altitude(),1);
- Serial.print(",");
- Serial.println(gps.hdop());
- //Serial.println(gps.satellites());
- } else {
- }
-
- //print_int(gps.satellites(), TinyGPS::GPS_INVALID_SATELLITES, 5);
- //print_int(gps.hdop(), TinyGPS::GPS_INVALID_HDOP, 5);
-
- /*print_float(flat, TinyGPS::GPS_INVALID_F_ANGLE, 10, 6);
- print_float(flon, TinyGPS::GPS_INVALID_F_ANGLE, 11, 6);
- print_int(age, TinyGPS::GPS_INVALID_AGE, 5);
- print_date(gps);
- print_float(gps.f_altitude(), TinyGPS::GPS_INVALID_F_ALTITUDE, 7, 2);
- print_float(gps.f_course(), TinyGPS::GPS_INVALID_F_ANGLE, 7, 2);
- print_float(gps.f_speed_kmph(), TinyGPS::GPS_INVALID_F_SPEED, 6, 2);
- print_str(gps.f_course() == TinyGPS::GPS_INVALID_F_ANGLE ? "*** " : TinyGPS::cardinal(gps.f_course()), 6);
- print_int(flat == TinyGPS::GPS_INVALID_F_ANGLE ? 0xFFFFFFFF : (unsigned long)TinyGPS::distance_between(flat, flon, HOME_LAT, HOME_LON) , 0xFFFFFFFF, 9);
- print_float(flat == TinyGPS::GPS_INVALID_F_ANGLE ? TinyGPS::GPS_INVALID_F_ANGLE : TinyGPS::course_to(flat, flon, HOME_LAT, HOME_LON), TinyGPS::GPS_INVALID_F_ANGLE, 7, 2);
- print_str(flat == TinyGPS::GPS_INVALID_F_ANGLE ? "*** " : TinyGPS::cardinal(TinyGPS::course_to(flat, flon, HOME_LAT, HOME_LON)), 6);
- */
-
- if(chars == chars2) pattern = 0xffff;
- else if(sentences == sentences2) pattern = chars % 2;
- else if(readVcc()<4000) pattern = 0;
- else pattern = (gps.speed() << 16) + gps.satellites()-4;
-
- /*print_int(chars, 0xFFFFFFFF, 6);
- print_int(sentences, 0xFFFFFFFF, 10);
- print_int(failed, 0xFFFFFFFF, 9);
- */
- chars2 = chars;
- sentences2 = sentences;
- //Serial.println();
-
- smartdelay(1000);
- }
- long readVcc() {
- long result; // Read 1.1V reference against AVcc
- ADMUX = _BV(REFS0) | _BV(MUX3) | _BV(MUX2) | _BV(MUX1);
- delay(2); // Wait for Vref to settle
- ADCSRA |= _BV(ADSC); // Convert
- while (bit_is_set(ADCSRA,ADSC));
- result = ADCL;
- result |= ADCH<<8;
- result = 1126400L / result; // Back-calculate AVcc in mV
- return result;
- }
- static void smartdelay(unsigned long ms)
- {
- unsigned long start = millis();
- do
- {
- digitalWrite(13, (pattern >> ((millis() % 1000) * 32 / 1000)) & 0x1 );
- while (ss.available())
- gps.encode(ss.read());
- } while (millis() - start < ms);
- }
- static void print_float(float val, float invalid, int len, int prec)
- {
- if (val == invalid)
- {
- while (len-- > 1)
- Serial.print('*');
- Serial.print(' ');
- }
- else
- {
- Serial.print(val, prec);
- int vi = abs((int)val);
- int flen = prec + (val < 0.0 ? 2 : 1); // . and -
- flen += vi >= 1000 ? 4 : vi >= 100 ? 3 : vi >= 10 ? 2 : 1;
- for (int i=flen; i<len; ++i)
- Serial.print(' ');
- }
- smartdelay(0);
- }
- static void print_int(unsigned long val, unsigned long invalid, int len)
- {
- char sz[32];
- if (val == invalid)
- strcpy(sz, "*******");
- else
- sprintf(sz, "%ld", val);
- sz[len] = 0;
- for (int i=strlen(sz); i<len; ++i)
- sz[i] = ' ';
- if (len > 0)
- sz[len-1] = ' ';
- Serial.print(sz);
- smartdelay(0);
- }
- static void print_date(TinyGPS &gps)
- {
- int year;
- byte month, day, hour, minute, second, hundredths;
- unsigned long age;
- gps.crack_datetime(&year, &month, &day, &hour, &minute, &second, &hundredths, &age);
- if (age == TinyGPS::GPS_INVALID_AGE)
- Serial.print("********** ******** ");
- else
- {
- char sz[32];
- sprintf(sz, "%02d-%02d-%02d %02d:%02d:%02d",
- year, month, day, hour, minute, second);
- Serial.print(sz);
- }
- //print_int(age, TinyGPS::GPS_INVALID_AGE, 5);
- smartdelay(0);
- }
- static void print_str(const char *str, int len)
- {
- int slen = strlen(str);
- for (int i=0; i<len; ++i)
- Serial.print(i<slen ? str[i] : ' ');
- smartdelay(0);
- }
|