замеритель ускорения и gps трекер в одном флаконе с лцд дисплеем
Правила форума
разгонометр
-
admin
- Администратор
- Сообщений: 343
- Зарегистрирован: 10 июн 2017, 16:49
- Откуда: Rakun City @GanstaParadise-Telegram
-
Контактная информация:
Сообщение admin » 20 сен 2017, 11:06
исходники сервера
- gps.zip
- (3.69 KiB) Загружено 205 раз
то что в корне должно лежать в корне итд...
примечание пины rx tx поменяны крест на крест ,внимательно подключайте
Код: Выбрать все
#include <TinyGPS++.h>
#include <SoftwareSerial.h>
#include <EEPROM.h>
#include <ESP8266WiFi.h>
#include <ESP8266HTTPClient.h>
#include <ArduinoOTA.h> // Библиотека для OTA-прошивки
#include "math.h"
//wifii&server
const char* ssid = "Gansta-Paradise.guest";
const char* password = "";
const char* host = "www.gansta-paradise-forum.ru";
int interval = 0;
#include <OneWire.h>
#include <Wire.h>
#include <LiquidCrystal_I2C.h>
#if defined(ARDUINO) && ARDUINO >= 100
#define printByte(args) write(args);
#else
#define printByte(args) print(args,BYTE);
#endif
uint8_t bell[8] = {0x4,0xe,0xe,0xe,0x1f,0x0,0x4};
uint8_t note[8] = {0x2,0x3,0x2,0xe,0x1e,0xc,0x0};
uint8_t clock[8] = {0x0,0xe,0x15,0x17,0x11,0xe,0x0};
uint8_t heart[8] = {0x0,0xa,0x1f,0x1f,0xe,0x4,0x0};
uint8_t duck[8] = {0x0,0xc,0x1d,0xf,0xf,0x6,0x0};
uint8_t check[8] = {0x0,0x1,0x3,0x16,0x1c,0x8,0x0};
uint8_t cross[8] = {0x0,0x1b,0xe,0x4,0xe,0x1b,0x0};
uint8_t retarrow[8] = { 0x1,0x1,0x5,0x9,0x1f,0x8,0x4};
LiquidCrystal_I2C lcd(0x27,16,2); // set the LCD address to 0x27 for a 16 chars and 2 line display
/*
This sample code demonstrates the normal use of a TinyGPS++ (TinyGPSPlus) object.
It requires the use of SoftwareSerial, and assumes that you have a
4800-baud serial GPS device hooked up on pins 4(rx) and 3(tx).
*/
static const int RXPin = D5, TXPin = D6;
static const uint32_t GPSBaud = 9600;
// The TinyGPS++ object
TinyGPSPlus gps;
// The serial connection to the GPS device
SoftwareSerial ss(RXPin, TXPin);
///unsigned char meteringTime = 0; // Время замера
///unsigned long startMillis = 0; // Начало отсчета
unsigned long startITOW = 0; // Начало отсчета из GPS
///unsigned long currentMillis = 0; // Текущее время
float speedKM = 0; //////скорость
char gpsSpeed[3]; // Буфер для строки с скоростью
int gpsSpeedKm = 0; // Скорость в км/ч
bool start = false; // Старт замера
long startMillis = 0; // Начало отсчета
long currentMillis = 0; // Текущее время
float meteringTime = 0; //
struct Metering
{
float accel30;
float accel60;
float accel100;
};
Metering metering;
int startzamer = 0;
void setup()
{
pinMode(D5, INPUT_PULLUP);
Serial.begin(115200);
ss.begin(GPSBaud);
Serial.println(TinyGPSPlus::libraryVersion());
Serial.println();
Serial.println(F("Sats HDOP Latitude Longitude Fix Date Time Date Alt Course Speed Card Distance Course Card Chars Sentences Checksum"));
Serial.println(F(" (deg) (deg) Age Age (m) --- from GPS ---- ---- to London ---- RX RX Fail"));
Serial.println(F("---------------------------------------------------------------------------------------------------------------------------------------"));
lcd.init(); // initialize the lcd
lcd.backlight();
//lcd.createChar(0, bell);
//lcd.createChar(1, note);
lcd.createChar(2, clock);
lcd.createChar(3, heart);
lcd.createChar(4, duck);
lcd.createChar(5, check);
lcd.createChar(6, cross);
lcd.createChar(7, retarrow);
lcd.home();
lcd.print("RAZGONOMETR...");
lcd.setCursor(0, 1);
lcd.printByte(3);
lcd.print("GANSTA-PARADISE");
delay(5000);
//displayKeyCodes();
lcd.clear();
}
void loop()
{
static const double LONDON_LAT = 51.508131, LONDON_LON = -0.128002;
printInt(gps.satellites.value(), gps.satellites.isValid(), 5);
printInt(gps.hdop.value(), gps.hdop.isValid(), 5);
printFloat(gps.location.lat(), gps.location.isValid(), 11, 6);
printFloat(gps.location.lng(), gps.location.isValid(), 12, 6);
printInt(gps.location.age(), gps.location.isValid(), 5);
printDateTime(gps.date, gps.time);
printFloat(gps.altitude.meters(), gps.altitude.isValid(), 7, 2);
printFloat(gps.course.deg(), gps.course.isValid(), 7, 2);
printFloat(gps.speed.kmph(), gps.speed.isValid(), 6, 2);
printStr(gps.course.isValid() ? TinyGPSPlus::cardinal(gps.course.value()) : "*** ", 6);
lcd.home();
lcd.print(gps.location.lat(),5);
lcd.printByte(5);
lcd.print(gps.location.lng(),5);
lcd.setCursor(0, 1);
lcd.print(gps.speed.kmph());
lcd.printByte(4);
lcd.print("SPEED");
lcd.printByte(2);
lcd.print(interval);
delay(30);
speedKM = gps.speed.kmph();///////////////скорость..........вжжжжжж............
unsigned long distanceKmToLondon =
(unsigned long)TinyGPSPlus::distanceBetween(
gps.location.lat(),
gps.location.lng(),
LONDON_LAT,
LONDON_LON) / 1000;
printInt(distanceKmToLondon, gps.location.isValid(), 9);
double courseToLondon =
TinyGPSPlus::courseTo(
gps.location.lat(),
gps.location.lng(),
LONDON_LAT,
LONDON_LON);
printFloat(courseToLondon, gps.location.isValid(), 7, 2);
const char *cardinalToLondon = TinyGPSPlus::cardinal(courseToLondon);
printStr(gps.location.isValid() ? cardinalToLondon : "*** ", 6);
printInt(gps.charsProcessed(), true, 6);
printInt(gps.sentencesWithFix(), true, 10);
printInt(gps.failedChecksum(), true, 9);
Serial.println();
smartDelay(1000);
if (millis() > 5000 && gps.charsProcessed() < 10)
Serial.println(F("No GPS data received: check wiring"));
interval++;
zamer();
if(digitalRead(D5)==LOW){
lcd.clear();
startzamer++;
lcd.setCursor(0, 1);
lcd.print("STARTZAMER");
delay(10000);
lcd.setCursor(0, 0);
lcd.print("1");
delay(1000);
lcd.print("2");
delay(1000);
lcd.print("3-GO");
delay(1000);
}
/// Serial.println(interval);
if(interval>300&&gps.location.lat()>0){
/// delay(100);
sendtowebGPS();
delay(100);
interval = 0;
// lcd.init(); // initialize the lcd
// lcd.backlight();
// lcd.home();
lcd.clear();
lcd.setCursor(0, 0);
lcd.print("GPS-SEND");
delay(1000);
lcd.setCursor(0, 1);
///lcd.print( currentMillis);
lcd.print(gps.location.lat(),5);
lcd.printByte(5);
lcd.print(gps.location.lng(),5);
delay(10000);
lcd.clear();
}
////////////posl scob
if(interval==100){
lcd.clear();
}
}
// This custom version of delay() ensures that the gps object
// is being "fed".
static void smartDelay(unsigned long ms)
{
unsigned long start = millis();
do
{
while (ss.available())
gps.encode(ss.read());
} while (millis() - start < ms);
}
static void printFloat(float val, bool valid, int len, int prec)
{
if (!valid)
{
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 printInt(unsigned long val, bool valid, int len)
{
char sz[32] = "*****************";
if (valid)
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 printDateTime(TinyGPSDate &d, TinyGPSTime &t)
{
if (!d.isValid())
{
Serial.print(F("********** "));
}
else
{
char sz[32];
sprintf(sz, "%02d/%02d/%02d ", d.month(), d.day(), d.year());
Serial.print(sz);
}
if (!t.isValid())
{
Serial.print(F("******** "));
}
else
{
char sz[32];
sprintf(sz, "%02d:%02d:%02d ", t.hour(), t.minute(), t.second());
Serial.print(sz);
}
printInt(d.age(), d.isValid(), 5);
smartDelay(0);
}
static void printStr(const char *str, int len)
{
int slen = strlen(str);
for (int i=0; i<len; ++i)
Serial.print(i<slen ? str[i] : ' ');
smartDelay(0);
}
void zamer(){
// lcd.init(); // initialize the lcd
// lcd.backlight();
// lcd.home();
/// lcd.clear();
///lcd.setCursor(0, 0);
///lcd.print("ZAMER");
///delay(100);
///lcd.setCursor(0, 1);
///lcd.print( currentMillis);
//delay(100);
///delay(1000);
/// lcd.printByte(5);
currentMillis = millis();
gpsSpeedKm = gps.speed.kmph();
if (gpsSpeedKm > 0 && startzamer > 0) {
// Если это был старт
if (!start) {
start = true;
startMillis = millis();
}
meteringTime = (float)(currentMillis - startMillis) / 1000; // Время замера
// Результаты замера
if (0.0 == metering.accel30 && gpsSpeedKm >= 30) {
metering.accel30 = meteringTime; // Разгон до 30км/ч
}
else if (0.0 == metering.accel60 && gpsSpeedKm >= 60) {
metering.accel60 = meteringTime; // Разгон до 60км/ч
}
else if (0.0 == metering.accel100 && gpsSpeedKm >= 100) {
metering.accel100 = meteringTime; // Разгон до 100км/ч
}
}
else if (start && 0 == gpsSpeedKm) { // Если остановились
start = false;
}
if ( startzamer > 0 &&meteringTime > 1 ) {
lcd.clear();
lcd.setCursor(0, 0);
lcd.print("ZAMER");
lcd.printByte(5);
lcd.print( metering.accel30);
lcd.printByte(5);
lcd.print( metering.accel60);
delay(100);
lcd.setCursor(0, 1);
lcd.print( metering.accel100);
delay(10000);
interval = 0;
startzamer = 0;
}
}
///}
void sendtowebGPS(){
WiFi.softAPdisconnect();
WiFi.disconnect();
WiFi.mode(WIFI_STA);
delay(100);
WiFi.begin(ssid, password);
while (WiFi.waitForConnectResult() != WL_CONNECTED) {
delay(5000);
ESP.restart();
}
WiFiClient client;
EEPROM.begin(512);
if (client.connect(host, 80))
{
client.print( "GET /gps.php?");
client.print("pak0=");
client.print( gps.location.lat(),5);
client.print("&");
client.print("&");
client.print("pak1=");
client.print( gps.location.lng(),5 );
client.print("&");
client.print("&");
client.print("pak2=");
client.print( gps.speed.kmph() );
client.print("&");
client.print("&");
client.print("pak3=");
client.print( metering.accel30 );
client.print("&");
client.print("&");
client.print("pak4=");
client.print( metering.accel60 );
client.print("&");
client.print("&");
client.print("pak5=");
client.print( metering.accel100 );
client.print("&");
client.println( " HTTP/1.1");
client.print( "Host:" ); //////www.gansta-paradise.com
client.println(host);
client.println( "Connection: close" );
client.println();
client.println(); }
else {
// If Arduino can't connect to the server (your computer or web page)
Serial.println("--> connection failed\n");
}
Serial.println("srabotalo-web-GPS");
///ESP.reset();
}
///////////////////памяти еще много есть где разгуляться ......//////////
-
admin
- Администратор
- Сообщений: 343
- Зарегистрирован: 10 июн 2017, 16:49
- Откуда: Rakun City @GanstaParadise-Telegram
-
Контактная информация:
Сообщение admin » 20 сен 2017, 11:31
Код: Выбрать все
#include <TinyGPS++.h>
#include <SoftwareSerial.h>
#include <Wire.h>
#include <LiquidCrystal_I2C.h>
#if defined(ARDUINO) && ARDUINO >= 100
#define printByte(args) write(args);
#else
#define printByte(args) print(args,BYTE);
#endif
uint8_t bell[8] = {0x4,0xe,0xe,0xe,0x1f,0x0,0x4};
uint8_t note[8] = {0x2,0x3,0x2,0xe,0x1e,0xc,0x0};
uint8_t clock[8] = {0x0,0xe,0x15,0x17,0x11,0xe,0x0};
uint8_t heart[8] = {0x0,0xa,0x1f,0x1f,0xe,0x4,0x0};
uint8_t duck[8] = {0x0,0xc,0x1d,0xf,0xf,0x6,0x0};
uint8_t check[8] = {0x0,0x1,0x3,0x16,0x1c,0x8,0x0};
uint8_t cross[8] = {0x0,0x1b,0xe,0x4,0xe,0x1b,0x0};
uint8_t retarrow[8] = { 0x1,0x1,0x5,0x9,0x1f,0x8,0x4};
LiquidCrystal_I2C lcd(0x27,16,2); // set the LCD address to 0x27 for a 16 chars and 2 line display
/*
This sample code demonstrates the normal use of a TinyGPS++ (TinyGPSPlus) object.
It requires the use of SoftwareSerial, and assumes that you have a
4800-baud serial GPS device hooked up on pins 4(rx) and 3(tx).
*/
static const int RXPin = D5, TXPin = D6;
static const uint32_t GPSBaud = 9600;
// The TinyGPS++ object
TinyGPSPlus gps;
// The serial connection to the GPS device
SoftwareSerial ss(RXPin, TXPin);
void setup()
{
Serial.begin(115200);
ss.begin(GPSBaud);
Serial.println(F("FullExample.ino"));
Serial.println(F("An extensive example of many interesting TinyGPS++ features"));
Serial.print(F("Testing TinyGPS++ library v. ")); Serial.println(TinyGPSPlus::libraryVersion());
Serial.println(F("by Mikal Hart"));
Serial.println();
Serial.println(F("Sats HDOP Latitude Longitude Fix Date Time Date Alt Course Speed Card Distance Course Card Chars Sentences Checksum"));
Serial.println(F(" (deg) (deg) Age Age (m) --- from GPS ---- ---- to London ---- RX RX Fail"));
Serial.println(F("---------------------------------------------------------------------------------------------------------------------------------------"));
lcd.init(); // initialize the lcd
lcd.backlight();
//lcd.createChar(0, bell);
//lcd.createChar(1, note);
// lcd.createChar(2, clock);
lcd.createChar(3, heart);
// lcd.createChar(4, duck);
// lcd.createChar(5, check);
// lcd.createChar(6, cross);
// lcd.createChar(7, retarrow);
lcd.home();
lcd.print("RAZGONOMETR...");
lcd.setCursor(0, 1);
lcd.print(" i ");
lcd.printByte(3);
lcd.print(gps.location.lat());
delay(5000);
//displayKeyCodes();
}
void loop()
{
static const double LONDON_LAT = 51.508131, LONDON_LON = -0.128002;
printInt(gps.satellites.value(), gps.satellites.isValid(), 5);
printInt(gps.hdop.value(), gps.hdop.isValid(), 5);
printFloat(gps.location.lat(), gps.location.isValid(), 11, 6);
printFloat(gps.location.lng(), gps.location.isValid(), 12, 6);
printInt(gps.location.age(), gps.location.isValid(), 5);
printDateTime(gps.date, gps.time);
printFloat(gps.altitude.meters(), gps.altitude.isValid(), 7, 2);
printFloat(gps.course.deg(), gps.course.isValid(), 7, 2);
printFloat(gps.speed.kmph(), gps.speed.isValid(), 6, 2);
printStr(gps.course.isValid() ? TinyGPSPlus::cardinal(gps.course.value()) : "*** ", 6);
lcd.home();
lcd.print(gps.location.lat());
lcd.printByte(3);
lcd.print(gps.location.lng());
lcd.setCursor(0, 1);
lcd.print(gps.speed.kmph());
lcd.printByte(3);
lcd.print("SPEED");
delay(5000);
unsigned long distanceKmToLondon =
(unsigned long)TinyGPSPlus::distanceBetween(
gps.location.lat(),
gps.location.lng(),
LONDON_LAT,
LONDON_LON) / 1000;
printInt(distanceKmToLondon, gps.location.isValid(), 9);
double courseToLondon =
TinyGPSPlus::courseTo(
gps.location.lat(),
gps.location.lng(),
LONDON_LAT,
LONDON_LON);
printFloat(courseToLondon, gps.location.isValid(), 7, 2);
const char *cardinalToLondon = TinyGPSPlus::cardinal(courseToLondon);
printStr(gps.location.isValid() ? cardinalToLondon : "*** ", 6);
printInt(gps.charsProcessed(), true, 6);
printInt(gps.sentencesWithFix(), true, 10);
printInt(gps.failedChecksum(), true, 9);
Serial.println();
smartDelay(1000);
if (millis() > 5000 && gps.charsProcessed() < 10)
Serial.println(F("No GPS data received: check wiring"));
}
// This custom version of delay() ensures that the gps object
// is being "fed".
static void smartDelay(unsigned long ms)
{
unsigned long start = millis();
do
{
while (ss.available())
gps.encode(ss.read());
} while (millis() - start < ms);
}
static void printFloat(float val, bool valid, int len, int prec)
{
if (!valid)
{
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 printInt(unsigned long val, bool valid, int len)
{
char sz[32] = "*****************";
if (valid)
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 printDateTime(TinyGPSDate &d, TinyGPSTime &t)
{
if (!d.isValid())
{
Serial.print(F("********** "));
}
else
{
char sz[32];
sprintf(sz, "%02d/%02d/%02d ", d.month(), d.day(), d.year());
Serial.print(sz);
}
if (!t.isValid())
{
Serial.print(F("******** "));
}
else
{
char sz[32];
sprintf(sz, "%02d:%02d:%02d ", t.hour(), t.minute(), t.second());
Serial.print(sz);
}
printInt(d.age(), d.isValid(), 5);
smartDelay(0);
}
static void printStr(const char *str, int len)
{
int slen = strlen(str);
for (int i=0; i<len; ++i)
Serial.print(i<slen ? str[i] : ' ');
smartDelay(0);
}
Модернизация
-
admin
- Администратор
- Сообщений: 343
- Зарегистрирован: 10 июн 2017, 16:49
- Откуда: Rakun City @GanstaParadise-Telegram
-
Контактная информация:
Сообщение admin » 20 сен 2017, 11:56
Добавлена точность вывода на дисплей
Код: Выбрать все
#include <TinyGPS++.h>
#include <SoftwareSerial.h>
#include <Wire.h>
#include <LiquidCrystal_I2C.h>
#if defined(ARDUINO) && ARDUINO >= 100
#define printByte(args) write(args);
#else
#define printByte(args) print(args,BYTE);
#endif
uint8_t bell[8] = {0x4,0xe,0xe,0xe,0x1f,0x0,0x4};
uint8_t note[8] = {0x2,0x3,0x2,0xe,0x1e,0xc,0x0};
uint8_t clock[8] = {0x0,0xe,0x15,0x17,0x11,0xe,0x0};
uint8_t heart[8] = {0x0,0xa,0x1f,0x1f,0xe,0x4,0x0};
uint8_t duck[8] = {0x0,0xc,0x1d,0xf,0xf,0x6,0x0};
uint8_t check[8] = {0x0,0x1,0x3,0x16,0x1c,0x8,0x0};
uint8_t cross[8] = {0x0,0x1b,0xe,0x4,0xe,0x1b,0x0};
uint8_t retarrow[8] = { 0x1,0x1,0x5,0x9,0x1f,0x8,0x4};
LiquidCrystal_I2C lcd(0x27,16,2); // set the LCD address to 0x27 for a 16 chars and 2 line display
/*
This sample code demonstrates the normal use of a TinyGPS++ (TinyGPSPlus) object.
It requires the use of SoftwareSerial, and assumes that you have a
4800-baud serial GPS device hooked up on pins 4(rx) and 3(tx).
*/
static const int RXPin = D5, TXPin = D6;
static const uint32_t GPSBaud = 9600;
// The TinyGPS++ object
TinyGPSPlus gps;
// The serial connection to the GPS device
SoftwareSerial ss(RXPin, TXPin);
void setup()
{
Serial.begin(115200);
ss.begin(GPSBaud);
Serial.println(F("FullExample.ino"));
Serial.println(F("An extensive example of many interesting TinyGPS++ features"));
Serial.print(F("Testing TinyGPS++ library v. ")); Serial.println(TinyGPSPlus::libraryVersion());
Serial.println(F("by Mikal Hart"));
Serial.println();
Serial.println(F("Sats HDOP Latitude Longitude Fix Date Time Date Alt Course Speed Card Distance Course Card Chars Sentences Checksum"));
Serial.println(F(" (deg) (deg) Age Age (m) --- from GPS ---- ---- to London ---- RX RX Fail"));
Serial.println(F("---------------------------------------------------------------------------------------------------------------------------------------"));
lcd.init(); // initialize the lcd
lcd.backlight();
//lcd.createChar(0, bell);
//lcd.createChar(1, note);
// lcd.createChar(2, clock);
lcd.createChar(3, heart);
lcd.createChar(4, duck);
lcd.createChar(5, check);
lcd.createChar(6, cross);
lcd.createChar(7, retarrow);
lcd.home();
lcd.print("RAZGONOMETR...");
lcd.setCursor(0, 1);
lcd.print(" i ");
lcd.printByte(3);
lcd.print(gps.location.lat());
delay(5000);
//displayKeyCodes();
}
void loop()
{
static const double LONDON_LAT = 51.508131, LONDON_LON = -0.128002;
printInt(gps.satellites.value(), gps.satellites.isValid(), 5);
printInt(gps.hdop.value(), gps.hdop.isValid(), 5);
printFloat(gps.location.lat(), gps.location.isValid(), 11, 6);
printFloat(gps.location.lng(), gps.location.isValid(), 12, 6);
printInt(gps.location.age(), gps.location.isValid(), 5);
printDateTime(gps.date, gps.time);
printFloat(gps.altitude.meters(), gps.altitude.isValid(), 7, 2);
printFloat(gps.course.deg(), gps.course.isValid(), 7, 2);
printFloat(gps.speed.kmph(), gps.speed.isValid(), 6, 2);
printStr(gps.course.isValid() ? TinyGPSPlus::cardinal(gps.course.value()) : "*** ", 6);
lcd.home();
lcd.print(gps.location.lat(),5);
lcd.printByte(5);
lcd.print(gps.location.lng(),5);
lcd.setCursor(0, 1);
lcd.print(gps.speed.kmph());
lcd.printByte(4);
lcd.print("SPEED");
delay(5000);
unsigned long distanceKmToLondon =
(unsigned long)TinyGPSPlus::distanceBetween(
gps.location.lat(),
gps.location.lng(),
LONDON_LAT,
LONDON_LON) / 1000;
printInt(distanceKmToLondon, gps.location.isValid(), 9);
double courseToLondon =
TinyGPSPlus::courseTo(
gps.location.lat(),
gps.location.lng(),
LONDON_LAT,
LONDON_LON);
printFloat(courseToLondon, gps.location.isValid(), 7, 2);
const char *cardinalToLondon = TinyGPSPlus::cardinal(courseToLondon);
printStr(gps.location.isValid() ? cardinalToLondon : "*** ", 6);
printInt(gps.charsProcessed(), true, 6);
printInt(gps.sentencesWithFix(), true, 10);
printInt(gps.failedChecksum(), true, 9);
Serial.println();
smartDelay(1000);
if (millis() > 5000 && gps.charsProcessed() < 10)
Serial.println(F("No GPS data received: check wiring"));
}
// This custom version of delay() ensures that the gps object
// is being "fed".
static void smartDelay(unsigned long ms)
{
unsigned long start = millis();
do
{
while (ss.available())
gps.encode(ss.read());
} while (millis() - start < ms);
}
static void printFloat(float val, bool valid, int len, int prec)
{
if (!valid)
{
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 printInt(unsigned long val, bool valid, int len)
{
char sz[32] = "*****************";
if (valid)
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 printDateTime(TinyGPSDate &d, TinyGPSTime &t)
{
if (!d.isValid())
{
Serial.print(F("********** "));
}
else
{
char sz[32];
sprintf(sz, "%02d/%02d/%02d ", d.month(), d.day(), d.year());
Serial.print(sz);
}
if (!t.isValid())
{
Serial.print(F("******** "));
}
else
{
char sz[32];
sprintf(sz, "%02d:%02d:%02d ", t.hour(), t.minute(), t.second());
Serial.print(sz);
}
printInt(d.age(), d.isValid(), 5);
smartDelay(0);
}
static void printStr(const char *str, int len)
{
int slen = strlen(str);
for (int i=0; i<len; ++i)
Serial.print(i<slen ? str[i] : ' ');
smartDelay(0);
}
-
admin
- Администратор
- Сообщений: 343
- Зарегистрирован: 10 июн 2017, 16:49
- Откуда: Rakun City @GanstaParadise-Telegram
-
Контактная информация:
Сообщение admin » 20 сен 2017, 16:16
добавлен gps треккер посылающий координаты на веб + пробный замер разгона до 100
Код: Выбрать все
#include <TinyGPS++.h>
#include <SoftwareSerial.h>
#include <EEPROM.h>
#include <ESP8266WiFi.h>
#include <ESP8266HTTPClient.h>
#include <ArduinoOTA.h> // Библиотека для OTA-прошивки
#include "math.h"
//wifii&server
const char* ssid = "Gansta-Paradise.guest";
const char* password = "";
const char* host = "www.gansta-paradise-forum.ru";
int interval = 0;
#include <OneWire.h>
#include <Wire.h>
#include <LiquidCrystal_I2C.h>
#if defined(ARDUINO) && ARDUINO >= 100
#define printByte(args) write(args);
#else
#define printByte(args) print(args,BYTE);
#endif
uint8_t bell[8] = {0x4,0xe,0xe,0xe,0x1f,0x0,0x4};
uint8_t note[8] = {0x2,0x3,0x2,0xe,0x1e,0xc,0x0};
uint8_t clock[8] = {0x0,0xe,0x15,0x17,0x11,0xe,0x0};
uint8_t heart[8] = {0x0,0xa,0x1f,0x1f,0xe,0x4,0x0};
uint8_t duck[8] = {0x0,0xc,0x1d,0xf,0xf,0x6,0x0};
uint8_t check[8] = {0x0,0x1,0x3,0x16,0x1c,0x8,0x0};
uint8_t cross[8] = {0x0,0x1b,0xe,0x4,0xe,0x1b,0x0};
uint8_t retarrow[8] = { 0x1,0x1,0x5,0x9,0x1f,0x8,0x4};
LiquidCrystal_I2C lcd(0x27,16,2); // set the LCD address to 0x27 for a 16 chars and 2 line display
/*
This sample code demonstrates the normal use of a TinyGPS++ (TinyGPSPlus) object.
It requires the use of SoftwareSerial, and assumes that you have a
4800-baud serial GPS device hooked up on pins 4(rx) and 3(tx).
*/
static const int RXPin = D5, TXPin = D6;
static const uint32_t GPSBaud = 9600;
// The TinyGPS++ object
TinyGPSPlus gps;
// The serial connection to the GPS device
SoftwareSerial ss(RXPin, TXPin);
unsigned char meteringTime = 0; // Время замера
unsigned long startMillis = 0; // Начало отсчета
unsigned long startITOW = 0; // Начало отсчета из GPS
unsigned long currentMillis = 0; // Текущее время
float speedKM = 0; //////скорость
void setup()
{
pinMode(D5, INPUT_PULLUP);
Serial.begin(115200);
ss.begin(GPSBaud);
Serial.println(F("FullExample.ino"));
Serial.println(F("An extensive example of many interesting TinyGPS++ features"));
Serial.print(F("Testing TinyGPS++ library v. ")); Serial.println(TinyGPSPlus::libraryVersion());
Serial.println(F("by Mikal Hart"));
Serial.println();
Serial.println(F("Sats HDOP Latitude Longitude Fix Date Time Date Alt Course Speed Card Distance Course Card Chars Sentences Checksum"));
Serial.println(F(" (deg) (deg) Age Age (m) --- from GPS ---- ---- to London ---- RX RX Fail"));
Serial.println(F("---------------------------------------------------------------------------------------------------------------------------------------"));
lcd.init(); // initialize the lcd
lcd.backlight();
//lcd.createChar(0, bell);
//lcd.createChar(1, note);
// lcd.createChar(2, clock);
lcd.createChar(3, heart);
lcd.createChar(4, duck);
lcd.createChar(5, check);
lcd.createChar(6, cross);
lcd.createChar(7, retarrow);
lcd.home();
lcd.print("RAZGONOMETR...");
lcd.setCursor(0, 1);
lcd.print(" i ");
lcd.printByte(3);
lcd.print(gps.location.lat());
delay(5000);
//displayKeyCodes();
}
void loop()
{
static const double LONDON_LAT = 51.508131, LONDON_LON = -0.128002;
printInt(gps.satellites.value(), gps.satellites.isValid(), 5);
printInt(gps.hdop.value(), gps.hdop.isValid(), 5);
printFloat(gps.location.lat(), gps.location.isValid(), 11, 6);
printFloat(gps.location.lng(), gps.location.isValid(), 12, 6);
printInt(gps.location.age(), gps.location.isValid(), 5);
printDateTime(gps.date, gps.time);
printFloat(gps.altitude.meters(), gps.altitude.isValid(), 7, 2);
printFloat(gps.course.deg(), gps.course.isValid(), 7, 2);
printFloat(gps.speed.kmph(), gps.speed.isValid(), 6, 2);
printStr(gps.course.isValid() ? TinyGPSPlus::cardinal(gps.course.value()) : "*** ", 6);
lcd.home();
lcd.print(gps.location.lat(),5);
lcd.printByte(5);
lcd.print(gps.location.lng(),5);
lcd.setCursor(0, 1);
lcd.print(gps.speed.kmph());
lcd.printByte(4);
lcd.print("SPEED");
delay(30);
speedKM = gps.speed.kmph();///////////////скорость..........вжжжжжж............
unsigned long distanceKmToLondon =
(unsigned long)TinyGPSPlus::distanceBetween(
gps.location.lat(),
gps.location.lng(),
LONDON_LAT,
LONDON_LON) / 1000;
printInt(distanceKmToLondon, gps.location.isValid(), 9);
double courseToLondon =
TinyGPSPlus::courseTo(
gps.location.lat(),
gps.location.lng(),
LONDON_LAT,
LONDON_LON);
printFloat(courseToLondon, gps.location.isValid(), 7, 2);
const char *cardinalToLondon = TinyGPSPlus::cardinal(courseToLondon);
printStr(gps.location.isValid() ? cardinalToLondon : "*** ", 6);
printInt(gps.charsProcessed(), true, 6);
printInt(gps.sentencesWithFix(), true, 10);
printInt(gps.failedChecksum(), true, 9);
Serial.println();
smartDelay(1000);
if (millis() > 5000 && gps.charsProcessed() < 10)
Serial.println(F("No GPS data received: check wiring"));
interval++;
zamer();
///if(digitalRead(D5)==LOW){
/// lcd.clear();
///while(speedKM<100){
//// zamer();}
///}
/// Serial.println(interval);
if(interval>100&&gps.location.lat()>0){
sendtowebGPS();
delay(1000);
interval = 0;
// lcd.init(); // initialize the lcd
// lcd.backlight();
// lcd.home();
lcd.clear();
lcd.setCursor(0, 0);
lcd.print("GPS-SEND");
delay(1000);
lcd.setCursor(0, 1);
///lcd.print( currentMillis);
lcd.print(gps.location.lat(),5);
lcd.printByte(5);
lcd.print(gps.location.lng(),5);
delay(1000);
lcd.clear();
}
////////////posl scob
}
// This custom version of delay() ensures that the gps object
// is being "fed".
static void smartDelay(unsigned long ms)
{
unsigned long start = millis();
do
{
while (ss.available())
gps.encode(ss.read());
} while (millis() - start < ms);
}
static void printFloat(float val, bool valid, int len, int prec)
{
if (!valid)
{
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 printInt(unsigned long val, bool valid, int len)
{
char sz[32] = "*****************";
if (valid)
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 printDateTime(TinyGPSDate &d, TinyGPSTime &t)
{
if (!d.isValid())
{
Serial.print(F("********** "));
}
else
{
char sz[32];
sprintf(sz, "%02d/%02d/%02d ", d.month(), d.day(), d.year());
Serial.print(sz);
}
if (!t.isValid())
{
Serial.print(F("******** "));
}
else
{
char sz[32];
sprintf(sz, "%02d:%02d:%02d ", t.hour(), t.minute(), t.second());
Serial.print(sz);
}
printInt(d.age(), d.isValid(), 5);
smartDelay(0);
}
static void printStr(const char *str, int len)
{
int slen = strlen(str);
for (int i=0; i<len; ++i)
Serial.print(i<slen ? str[i] : ' ');
smartDelay(0);
}
void zamer(){
// lcd.init(); // initialize the lcd
// lcd.backlight();
// lcd.home();
/// lcd.clear();
///lcd.setCursor(0, 0);
///lcd.print("ZAMER");
///delay(100);
///lcd.setCursor(0, 1);
///lcd.print( currentMillis);
//delay(100);
///delay(1000);
/// lcd.printByte(5);
currentMillis = millis();
if(speedKM>0){
if(speedKM<10){
startMillis =0;
}
startMillis = millis();
if (speedKM>=100){
lcd.clear();
lcd.print("ZAMER=");
lcd.printByte(5);
lcd.setCursor(0, 1);
lcd.print(startMillis);
lcd.print("TIME");
delay(100000);
}
}
}
void sendtowebGPS(){
WiFi.mode(WIFI_STA);
WiFi.begin(ssid, password);
while (WiFi.waitForConnectResult() != WL_CONNECTED) {
delay(5000);
ESP.restart();
}
WiFiClient client;
EEPROM.begin(512);
if (client.connect(host, 80))
{
client.print( "GET /gps.php?");
client.print("pak0=");
client.print( gps.location.lat(),5);
client.print("&");
client.print("&");
client.print("pak1=");
client.print( gps.location.lng(),5 );
client.print("&");
client.println( " HTTP/1.1");
client.print( "Host:" ); //////www.gansta-paradise.com
client.println(host);
client.println( "Connection: close" );
client.println();
client.println(); }
else {
// If Arduino can't connect to the server (your computer or web page)
Serial.println("--> connection failed\n");
}
Serial.println("srabotalo-web-GPS");
/// ESP.reset();
}
-
admin
- Администратор
- Сообщений: 343
- Зарегистрирован: 10 июн 2017, 16:49
- Откуда: Rakun City @GanstaParadise-Telegram
-
Контактная информация:
Сообщение admin » 21 сен 2017, 10:16
Работает спидометр и ГПС Треккер без зависаний периуд 10
Код: Выбрать все
#include <TinyGPS++.h>
#include <SoftwareSerial.h>
#include <EEPROM.h>
#include <ESP8266WiFi.h>
#include <ESP8266HTTPClient.h>
#include <ArduinoOTA.h> // Библиотека для OTA-прошивки
#include "math.h"
//wifii&server
const char* ssid = "Gansta-Paradise.guest";
const char* password = "";
const char* host = "www.gansta-paradise-forum.ru";
int interval = 0;
#include <OneWire.h>
#include <Wire.h>
#include <LiquidCrystal_I2C.h>
#if defined(ARDUINO) && ARDUINO >= 100
#define printByte(args) write(args);
#else
#define printByte(args) print(args,BYTE);
#endif
uint8_t bell[8] = {0x4,0xe,0xe,0xe,0x1f,0x0,0x4};
uint8_t note[8] = {0x2,0x3,0x2,0xe,0x1e,0xc,0x0};
uint8_t clock[8] = {0x0,0xe,0x15,0x17,0x11,0xe,0x0};
uint8_t heart[8] = {0x0,0xa,0x1f,0x1f,0xe,0x4,0x0};
uint8_t duck[8] = {0x0,0xc,0x1d,0xf,0xf,0x6,0x0};
uint8_t check[8] = {0x0,0x1,0x3,0x16,0x1c,0x8,0x0};
uint8_t cross[8] = {0x0,0x1b,0xe,0x4,0xe,0x1b,0x0};
uint8_t retarrow[8] = { 0x1,0x1,0x5,0x9,0x1f,0x8,0x4};
LiquidCrystal_I2C lcd(0x27,16,2); // set the LCD address to 0x27 for a 16 chars and 2 line display
/*
This sample code demonstrates the normal use of a TinyGPS++ (TinyGPSPlus) object.
It requires the use of SoftwareSerial, and assumes that you have a
4800-baud serial GPS device hooked up on pins 4(rx) and 3(tx).
*/
static const int RXPin = D5, TXPin = D6;
static const uint32_t GPSBaud = 9600;
// The TinyGPS++ object
TinyGPSPlus gps;
// The serial connection to the GPS device
SoftwareSerial ss(RXPin, TXPin);
unsigned char meteringTime = 0; // Время замера
unsigned long startMillis = 0; // Начало отсчета
unsigned long startITOW = 0; // Начало отсчета из GPS
unsigned long currentMillis = 0; // Текущее время
float speedKM = 0; //////скорость
void setup()
{
pinMode(D5, INPUT_PULLUP);
Serial.begin(115200);
ss.begin(GPSBaud);
Serial.println(TinyGPSPlus::libraryVersion());
Serial.println();
Serial.println(F("Sats HDOP Latitude Longitude Fix Date Time Date Alt Course Speed Card Distance Course Card Chars Sentences Checksum"));
Serial.println(F(" (deg) (deg) Age Age (m) --- from GPS ---- ---- to London ---- RX RX Fail"));
Serial.println(F("---------------------------------------------------------------------------------------------------------------------------------------"));
lcd.init(); // initialize the lcd
lcd.backlight();
//lcd.createChar(0, bell);
//lcd.createChar(1, note);
lcd.createChar(2, clock);
lcd.createChar(3, heart);
lcd.createChar(4, duck);
lcd.createChar(5, check);
lcd.createChar(6, cross);
lcd.createChar(7, retarrow);
lcd.home();
lcd.print("RAZGONOMETR...");
lcd.setCursor(0, 1);
lcd.printByte(3);
lcd.print("GANSTA-PARADISE");
delay(5000);
//displayKeyCodes();
lcd.clear();
}
void loop()
{
static const double LONDON_LAT = 51.508131, LONDON_LON = -0.128002;
printInt(gps.satellites.value(), gps.satellites.isValid(), 5);
printInt(gps.hdop.value(), gps.hdop.isValid(), 5);
printFloat(gps.location.lat(), gps.location.isValid(), 11, 6);
printFloat(gps.location.lng(), gps.location.isValid(), 12, 6);
printInt(gps.location.age(), gps.location.isValid(), 5);
printDateTime(gps.date, gps.time);
printFloat(gps.altitude.meters(), gps.altitude.isValid(), 7, 2);
printFloat(gps.course.deg(), gps.course.isValid(), 7, 2);
printFloat(gps.speed.kmph(), gps.speed.isValid(), 6, 2);
printStr(gps.course.isValid() ? TinyGPSPlus::cardinal(gps.course.value()) : "*** ", 6);
lcd.home();
lcd.print(gps.location.lat(),5);
lcd.printByte(5);
lcd.print(gps.location.lng(),5);
lcd.setCursor(0, 1);
lcd.print(gps.speed.kmph());
lcd.printByte(4);
lcd.print("SPEED");
lcd.printByte(2);
lcd.print(interval);
delay(30);
speedKM = gps.speed.kmph();///////////////скорость..........вжжжжжж............
unsigned long distanceKmToLondon =
(unsigned long)TinyGPSPlus::distanceBetween(
gps.location.lat(),
gps.location.lng(),
LONDON_LAT,
LONDON_LON) / 1000;
printInt(distanceKmToLondon, gps.location.isValid(), 9);
double courseToLondon =
TinyGPSPlus::courseTo(
gps.location.lat(),
gps.location.lng(),
LONDON_LAT,
LONDON_LON);
printFloat(courseToLondon, gps.location.isValid(), 7, 2);
const char *cardinalToLondon = TinyGPSPlus::cardinal(courseToLondon);
printStr(gps.location.isValid() ? cardinalToLondon : "*** ", 6);
printInt(gps.charsProcessed(), true, 6);
printInt(gps.sentencesWithFix(), true, 10);
printInt(gps.failedChecksum(), true, 9);
Serial.println();
smartDelay(1000);
if (millis() > 5000 && gps.charsProcessed() < 10)
Serial.println(F("No GPS data received: check wiring"));
interval++;
zamer();
///if(digitalRead(D5)==LOW){
/// lcd.clear();
///while(speedKM<100){
//// zamer();}
///}
/// Serial.println(interval);
if(interval>10&&gps.location.lat()>0){
/// delay(100);
sendtowebGPS();
delay(100);
interval = 0;
// lcd.init(); // initialize the lcd
// lcd.backlight();
// lcd.home();
lcd.clear();
lcd.setCursor(0, 0);
lcd.print("GPS-SEND");
delay(1000);
lcd.setCursor(0, 1);
///lcd.print( currentMillis);
lcd.print(gps.location.lat(),5);
lcd.printByte(5);
lcd.print(gps.location.lng(),5);
delay(10000);
lcd.clear();
}
////////////posl scob
}
// This custom version of delay() ensures that the gps object
// is being "fed".
static void smartDelay(unsigned long ms)
{
unsigned long start = millis();
do
{
while (ss.available())
gps.encode(ss.read());
} while (millis() - start < ms);
}
static void printFloat(float val, bool valid, int len, int prec)
{
if (!valid)
{
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 printInt(unsigned long val, bool valid, int len)
{
char sz[32] = "*****************";
if (valid)
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 printDateTime(TinyGPSDate &d, TinyGPSTime &t)
{
if (!d.isValid())
{
Serial.print(F("********** "));
}
else
{
char sz[32];
sprintf(sz, "%02d/%02d/%02d ", d.month(), d.day(), d.year());
Serial.print(sz);
}
if (!t.isValid())
{
Serial.print(F("******** "));
}
else
{
char sz[32];
sprintf(sz, "%02d:%02d:%02d ", t.hour(), t.minute(), t.second());
Serial.print(sz);
}
printInt(d.age(), d.isValid(), 5);
smartDelay(0);
}
static void printStr(const char *str, int len)
{
int slen = strlen(str);
for (int i=0; i<len; ++i)
Serial.print(i<slen ? str[i] : ' ');
smartDelay(0);
}
void zamer(){
// lcd.init(); // initialize the lcd
// lcd.backlight();
// lcd.home();
/// lcd.clear();
///lcd.setCursor(0, 0);
///lcd.print("ZAMER");
///delay(100);
///lcd.setCursor(0, 1);
///lcd.print( currentMillis);
//delay(100);
///delay(1000);
/// lcd.printByte(5);
currentMillis = millis();
if(speedKM>0){
if(speedKM<10){
startMillis =0;
}
startMillis = millis();
if (speedKM>=100){
lcd.clear();
lcd.print("ZAMER=");
lcd.printByte(5);
lcd.setCursor(0, 1);
lcd.print(startMillis);
lcd.print("TIME");
delay(100000);
}
}
}
void sendtowebGPS(){
WiFi.softAPdisconnect();
WiFi.disconnect();
WiFi.mode(WIFI_STA);
delay(100);
WiFi.begin(ssid, password);
while (WiFi.waitForConnectResult() != WL_CONNECTED) {
delay(5000);
ESP.restart();
}
WiFiClient client;
EEPROM.begin(512);
if (client.connect(host, 80))
{
client.print( "GET /gps.php?");
client.print("pak0=");
client.print( gps.location.lat(),5);
client.print("&");
client.print("&");
client.print("pak1=");
client.print( gps.location.lng(),5 );
client.print("&");
client.println( " HTTP/1.1");
client.print( "Host:" ); //////www.gansta-paradise.com
client.println(host);
client.println( "Connection: close" );
client.println();
client.println(); }
else {
// If Arduino can't connect to the server (your computer or web page)
Serial.println("--> connection failed\n");
}
Serial.println("srabotalo-web-GPS");
///ESP.reset();
}
-
admin
- Администратор
- Сообщений: 343
- Зарегистрирован: 10 июн 2017, 16:49
- Откуда: Rakun City @GanstaParadise-Telegram
-
Контактная информация:
Сообщение admin » 21 сен 2017, 10:31
без зависаний рабочий треккере периуд 300
страница треков
GPS/map.htmlКод: Выбрать все
#include <TinyGPS++.h>
#include <SoftwareSerial.h>
#include <EEPROM.h>
#include <ESP8266WiFi.h>
#include <ESP8266HTTPClient.h>
#include <ArduinoOTA.h> // Библиотека для OTA-прошивки
#include "math.h"
//wifii&server
const char* ssid = "Gansta-Paradise.guest";
const char* password = "";
const char* host = "www.gansta-paradise-forum.ru";
int interval = 0;
#include <OneWire.h>
#include <Wire.h>
#include <LiquidCrystal_I2C.h>
#if defined(ARDUINO) && ARDUINO >= 100
#define printByte(args) write(args);
#else
#define printByte(args) print(args,BYTE);
#endif
uint8_t bell[8] = {0x4,0xe,0xe,0xe,0x1f,0x0,0x4};
uint8_t note[8] = {0x2,0x3,0x2,0xe,0x1e,0xc,0x0};
uint8_t clock[8] = {0x0,0xe,0x15,0x17,0x11,0xe,0x0};
uint8_t heart[8] = {0x0,0xa,0x1f,0x1f,0xe,0x4,0x0};
uint8_t duck[8] = {0x0,0xc,0x1d,0xf,0xf,0x6,0x0};
uint8_t check[8] = {0x0,0x1,0x3,0x16,0x1c,0x8,0x0};
uint8_t cross[8] = {0x0,0x1b,0xe,0x4,0xe,0x1b,0x0};
uint8_t retarrow[8] = { 0x1,0x1,0x5,0x9,0x1f,0x8,0x4};
LiquidCrystal_I2C lcd(0x27,16,2); // set the LCD address to 0x27 for a 16 chars and 2 line display
/*
This sample code demonstrates the normal use of a TinyGPS++ (TinyGPSPlus) object.
It requires the use of SoftwareSerial, and assumes that you have a
4800-baud serial GPS device hooked up on pins 4(rx) and 3(tx).
*/
static const int RXPin = D5, TXPin = D6;
static const uint32_t GPSBaud = 9600;
// The TinyGPS++ object
TinyGPSPlus gps;
// The serial connection to the GPS device
SoftwareSerial ss(RXPin, TXPin);
unsigned char meteringTime = 0; // Время замера
unsigned long startMillis = 0; // Начало отсчета
unsigned long startITOW = 0; // Начало отсчета из GPS
unsigned long currentMillis = 0; // Текущее время
float speedKM = 0; //////скорость
void setup()
{
pinMode(D5, INPUT_PULLUP);
Serial.begin(115200);
ss.begin(GPSBaud);
Serial.println(TinyGPSPlus::libraryVersion());
Serial.println();
Serial.println(F("Sats HDOP Latitude Longitude Fix Date Time Date Alt Course Speed Card Distance Course Card Chars Sentences Checksum"));
Serial.println(F(" (deg) (deg) Age Age (m) --- from GPS ---- ---- to London ---- RX RX Fail"));
Serial.println(F("---------------------------------------------------------------------------------------------------------------------------------------"));
lcd.init(); // initialize the lcd
lcd.backlight();
//lcd.createChar(0, bell);
//lcd.createChar(1, note);
lcd.createChar(2, clock);
lcd.createChar(3, heart);
lcd.createChar(4, duck);
lcd.createChar(5, check);
lcd.createChar(6, cross);
lcd.createChar(7, retarrow);
lcd.home();
lcd.print("RAZGONOMETR...");
lcd.setCursor(0, 1);
lcd.printByte(3);
lcd.print("GANSTA-PARADISE");
delay(5000);
//displayKeyCodes();
lcd.clear();
}
void loop()
{
static const double LONDON_LAT = 51.508131, LONDON_LON = -0.128002;
printInt(gps.satellites.value(), gps.satellites.isValid(), 5);
printInt(gps.hdop.value(), gps.hdop.isValid(), 5);
printFloat(gps.location.lat(), gps.location.isValid(), 11, 6);
printFloat(gps.location.lng(), gps.location.isValid(), 12, 6);
printInt(gps.location.age(), gps.location.isValid(), 5);
printDateTime(gps.date, gps.time);
printFloat(gps.altitude.meters(), gps.altitude.isValid(), 7, 2);
printFloat(gps.course.deg(), gps.course.isValid(), 7, 2);
printFloat(gps.speed.kmph(), gps.speed.isValid(), 6, 2);
printStr(gps.course.isValid() ? TinyGPSPlus::cardinal(gps.course.value()) : "*** ", 6);
lcd.home();
lcd.print(gps.location.lat(),5);
lcd.printByte(5);
lcd.print(gps.location.lng(),5);
lcd.setCursor(0, 1);
lcd.print(gps.speed.kmph());
lcd.printByte(4);
lcd.print("SPEED");
lcd.printByte(2);
lcd.print(interval);
delay(30);
speedKM = gps.speed.kmph();///////////////скорость..........вжжжжжж............
unsigned long distanceKmToLondon =
(unsigned long)TinyGPSPlus::distanceBetween(
gps.location.lat(),
gps.location.lng(),
LONDON_LAT,
LONDON_LON) / 1000;
printInt(distanceKmToLondon, gps.location.isValid(), 9);
double courseToLondon =
TinyGPSPlus::courseTo(
gps.location.lat(),
gps.location.lng(),
LONDON_LAT,
LONDON_LON);
printFloat(courseToLondon, gps.location.isValid(), 7, 2);
const char *cardinalToLondon = TinyGPSPlus::cardinal(courseToLondon);
printStr(gps.location.isValid() ? cardinalToLondon : "*** ", 6);
printInt(gps.charsProcessed(), true, 6);
printInt(gps.sentencesWithFix(), true, 10);
printInt(gps.failedChecksum(), true, 9);
Serial.println();
smartDelay(1000);
if (millis() > 5000 && gps.charsProcessed() < 10)
Serial.println(F("No GPS data received: check wiring"));
interval++;
zamer();
///if(digitalRead(D5)==LOW){
/// lcd.clear();
///while(speedKM<100){
//// zamer();}
///}
/// Serial.println(interval);
if(interval>300&&gps.location.lat()>0){
/// delay(100);
sendtowebGPS();
delay(100);
interval = 0;
// lcd.init(); // initialize the lcd
// lcd.backlight();
// lcd.home();
lcd.clear();
lcd.setCursor(0, 0);
lcd.print("GPS-SEND");
delay(1000);
lcd.setCursor(0, 1);
///lcd.print( currentMillis);
lcd.print(gps.location.lat(),5);
lcd.printByte(5);
lcd.print(gps.location.lng(),5);
delay(10000);
lcd.clear();
}
////////////posl scob
}
// This custom version of delay() ensures that the gps object
// is being "fed".
static void smartDelay(unsigned long ms)
{
unsigned long start = millis();
do
{
while (ss.available())
gps.encode(ss.read());
} while (millis() - start < ms);
}
static void printFloat(float val, bool valid, int len, int prec)
{
if (!valid)
{
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 printInt(unsigned long val, bool valid, int len)
{
char sz[32] = "*****************";
if (valid)
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 printDateTime(TinyGPSDate &d, TinyGPSTime &t)
{
if (!d.isValid())
{
Serial.print(F("********** "));
}
else
{
char sz[32];
sprintf(sz, "%02d/%02d/%02d ", d.month(), d.day(), d.year());
Serial.print(sz);
}
if (!t.isValid())
{
Serial.print(F("******** "));
}
else
{
char sz[32];
sprintf(sz, "%02d:%02d:%02d ", t.hour(), t.minute(), t.second());
Serial.print(sz);
}
printInt(d.age(), d.isValid(), 5);
smartDelay(0);
}
static void printStr(const char *str, int len)
{
int slen = strlen(str);
for (int i=0; i<len; ++i)
Serial.print(i<slen ? str[i] : ' ');
smartDelay(0);
}
void zamer(){
// lcd.init(); // initialize the lcd
// lcd.backlight();
// lcd.home();
/// lcd.clear();
///lcd.setCursor(0, 0);
///lcd.print("ZAMER");
///delay(100);
///lcd.setCursor(0, 1);
///lcd.print( currentMillis);
//delay(100);
///delay(1000);
/// lcd.printByte(5);
currentMillis = millis();
if(speedKM>0){
if(speedKM<10){
startMillis =0;
}
startMillis = millis();
if (speedKM>=100){
lcd.clear();
lcd.print("ZAMER=");
lcd.printByte(5);
lcd.setCursor(0, 1);
lcd.print(startMillis);
lcd.print("TIME");
delay(100000);
}
}
}
void sendtowebGPS(){
WiFi.softAPdisconnect();
WiFi.disconnect();
WiFi.mode(WIFI_STA);
delay(100);
WiFi.begin(ssid, password);
while (WiFi.waitForConnectResult() != WL_CONNECTED) {
delay(5000);
ESP.restart();
}
WiFiClient client;
EEPROM.begin(512);
if (client.connect(host, 80))
{
client.print( "GET /gps.php?");
client.print("pak0=");
client.print( gps.location.lat(),5);
client.print("&");
client.print("&");
client.print("pak1=");
client.print( gps.location.lng(),5 );
client.print("&");
client.println( " HTTP/1.1");
client.print( "Host:" ); //////www.gansta-paradise.com
client.println(host);
client.println( "Connection: close" );
client.println();
client.println(); }
else {
// If Arduino can't connect to the server (your computer or web page)
Serial.println("--> connection failed\n");
}
Serial.println("srabotalo-web-GPS");
///ESP.reset();
}
исходники серверных файлов
- gps.zip
- (3.69 KiB) Загружено 231 раз
-
admin
- Администратор
- Сообщений: 343
- Зарегистрирован: 10 июн 2017, 16:49
- Откуда: Rakun City @GanstaParadise-Telegram
-
Контактная информация:
Сообщение admin » 21 сен 2017, 15:03
Добавлен код разгонометра включатся кнопкой D5 ,но не факт что он работает ещё не проверилллл
Код: Выбрать все
#include <TinyGPS++.h>
#include <SoftwareSerial.h>
#include <EEPROM.h>
#include <ESP8266WiFi.h>
#include <ESP8266HTTPClient.h>
#include <ArduinoOTA.h> // Библиотека для OTA-прошивки
#include "math.h"
//wifii&server
const char* ssid = "Gansta-Paradise.guest";
const char* password = "";
const char* host = "www.gansta-paradise-forum.ru";
int interval = 0;
#include <OneWire.h>
#include <Wire.h>
#include <LiquidCrystal_I2C.h>
#if defined(ARDUINO) && ARDUINO >= 100
#define printByte(args) write(args);
#else
#define printByte(args) print(args,BYTE);
#endif
uint8_t bell[8] = {0x4,0xe,0xe,0xe,0x1f,0x0,0x4};
uint8_t note[8] = {0x2,0x3,0x2,0xe,0x1e,0xc,0x0};
uint8_t clock[8] = {0x0,0xe,0x15,0x17,0x11,0xe,0x0};
uint8_t heart[8] = {0x0,0xa,0x1f,0x1f,0xe,0x4,0x0};
uint8_t duck[8] = {0x0,0xc,0x1d,0xf,0xf,0x6,0x0};
uint8_t check[8] = {0x0,0x1,0x3,0x16,0x1c,0x8,0x0};
uint8_t cross[8] = {0x0,0x1b,0xe,0x4,0xe,0x1b,0x0};
uint8_t retarrow[8] = { 0x1,0x1,0x5,0x9,0x1f,0x8,0x4};
LiquidCrystal_I2C lcd(0x27,16,2); // set the LCD address to 0x27 for a 16 chars and 2 line display
/*
This sample code demonstrates the normal use of a TinyGPS++ (TinyGPSPlus) object.
It requires the use of SoftwareSerial, and assumes that you have a
4800-baud serial GPS device hooked up on pins 4(rx) and 3(tx).
*/
static const int RXPin = D5, TXPin = D6;
static const uint32_t GPSBaud = 9600;
// The TinyGPS++ object
TinyGPSPlus gps;
// The serial connection to the GPS device
SoftwareSerial ss(RXPin, TXPin);
///unsigned char meteringTime = 0; // Время замера
///unsigned long startMillis = 0; // Начало отсчета
unsigned long startITOW = 0; // Начало отсчета из GPS
///unsigned long currentMillis = 0; // Текущее время
float speedKM = 0; //////скорость
char gpsSpeed[3]; // Буфер для строки с скоростью
int gpsSpeedKm = 0; // Скорость в км/ч
bool start = false; // Старт замера
long startMillis = 0; // Начало отсчета
long currentMillis = 0; // Текущее время
float meteringTime = 0; //
struct Metering
{
float accel30;
float accel60;
float accel100;
};
Metering metering;
int startzamer = 0;
void setup()
{
pinMode(D5, INPUT_PULLUP);
Serial.begin(115200);
ss.begin(GPSBaud);
Serial.println(TinyGPSPlus::libraryVersion());
Serial.println();
Serial.println(F("Sats HDOP Latitude Longitude Fix Date Time Date Alt Course Speed Card Distance Course Card Chars Sentences Checksum"));
Serial.println(F(" (deg) (deg) Age Age (m) --- from GPS ---- ---- to London ---- RX RX Fail"));
Serial.println(F("---------------------------------------------------------------------------------------------------------------------------------------"));
lcd.init(); // initialize the lcd
lcd.backlight();
//lcd.createChar(0, bell);
//lcd.createChar(1, note);
lcd.createChar(2, clock);
lcd.createChar(3, heart);
lcd.createChar(4, duck);
lcd.createChar(5, check);
lcd.createChar(6, cross);
lcd.createChar(7, retarrow);
lcd.home();
lcd.print("RAZGONOMETR...");
lcd.setCursor(0, 1);
lcd.printByte(3);
lcd.print("GANSTA-PARADISE");
delay(5000);
//displayKeyCodes();
lcd.clear();
}
void loop()
{
static const double LONDON_LAT = 51.508131, LONDON_LON = -0.128002;
printInt(gps.satellites.value(), gps.satellites.isValid(), 5);
printInt(gps.hdop.value(), gps.hdop.isValid(), 5);
printFloat(gps.location.lat(), gps.location.isValid(), 11, 6);
printFloat(gps.location.lng(), gps.location.isValid(), 12, 6);
printInt(gps.location.age(), gps.location.isValid(), 5);
printDateTime(gps.date, gps.time);
printFloat(gps.altitude.meters(), gps.altitude.isValid(), 7, 2);
printFloat(gps.course.deg(), gps.course.isValid(), 7, 2);
printFloat(gps.speed.kmph(), gps.speed.isValid(), 6, 2);
printStr(gps.course.isValid() ? TinyGPSPlus::cardinal(gps.course.value()) : "*** ", 6);
lcd.home();
lcd.print(gps.location.lat(),5);
lcd.printByte(5);
lcd.print(gps.location.lng(),5);
lcd.setCursor(0, 1);
lcd.print(gps.speed.kmph());
lcd.printByte(4);
lcd.print("SPEED");
lcd.printByte(2);
lcd.print(interval);
delay(30);
speedKM = gps.speed.kmph();///////////////скорость..........вжжжжжж............
unsigned long distanceKmToLondon =
(unsigned long)TinyGPSPlus::distanceBetween(
gps.location.lat(),
gps.location.lng(),
LONDON_LAT,
LONDON_LON) / 1000;
printInt(distanceKmToLondon, gps.location.isValid(), 9);
double courseToLondon =
TinyGPSPlus::courseTo(
gps.location.lat(),
gps.location.lng(),
LONDON_LAT,
LONDON_LON);
printFloat(courseToLondon, gps.location.isValid(), 7, 2);
const char *cardinalToLondon = TinyGPSPlus::cardinal(courseToLondon);
printStr(gps.location.isValid() ? cardinalToLondon : "*** ", 6);
printInt(gps.charsProcessed(), true, 6);
printInt(gps.sentencesWithFix(), true, 10);
printInt(gps.failedChecksum(), true, 9);
Serial.println();
smartDelay(1000);
if (millis() > 5000 && gps.charsProcessed() < 10)
Serial.println(F("No GPS data received: check wiring"));
interval++;
zamer();
if(digitalRead(D5)==LOW){
lcd.clear();
startzamer++;
lcd.setCursor(0, 1);
lcd.print("STARTZAMER");
delay(10000);
}
/// Serial.println(interval);
if(interval>300&&gps.location.lat()>0){
/// delay(100);
sendtowebGPS();
delay(100);
interval = 0;
// lcd.init(); // initialize the lcd
// lcd.backlight();
// lcd.home();
lcd.clear();
lcd.setCursor(0, 0);
lcd.print("GPS-SEND");
delay(1000);
lcd.setCursor(0, 1);
///lcd.print( currentMillis);
lcd.print(gps.location.lat(),5);
lcd.printByte(5);
lcd.print(gps.location.lng(),5);
delay(10000);
lcd.clear();
}
////////////posl scob
if(interval==100){
lcd.clear();
}
}
// This custom version of delay() ensures that the gps object
// is being "fed".
static void smartDelay(unsigned long ms)
{
unsigned long start = millis();
do
{
while (ss.available())
gps.encode(ss.read());
} while (millis() - start < ms);
}
static void printFloat(float val, bool valid, int len, int prec)
{
if (!valid)
{
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 printInt(unsigned long val, bool valid, int len)
{
char sz[32] = "*****************";
if (valid)
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 printDateTime(TinyGPSDate &d, TinyGPSTime &t)
{
if (!d.isValid())
{
Serial.print(F("********** "));
}
else
{
char sz[32];
sprintf(sz, "%02d/%02d/%02d ", d.month(), d.day(), d.year());
Serial.print(sz);
}
if (!t.isValid())
{
Serial.print(F("******** "));
}
else
{
char sz[32];
sprintf(sz, "%02d:%02d:%02d ", t.hour(), t.minute(), t.second());
Serial.print(sz);
}
printInt(d.age(), d.isValid(), 5);
smartDelay(0);
}
static void printStr(const char *str, int len)
{
int slen = strlen(str);
for (int i=0; i<len; ++i)
Serial.print(i<slen ? str[i] : ' ');
smartDelay(0);
}
void zamer(){
// lcd.init(); // initialize the lcd
// lcd.backlight();
// lcd.home();
/// lcd.clear();
///lcd.setCursor(0, 0);
///lcd.print("ZAMER");
///delay(100);
///lcd.setCursor(0, 1);
///lcd.print( currentMillis);
//delay(100);
///delay(1000);
/// lcd.printByte(5);
currentMillis = millis();
gpsSpeedKm = gps.speed.kmph();
if (gpsSpeedKm > 0 && startzamer > 0) {
// Если это был старт
if (!start) {
start = true;
startMillis = millis();
}
meteringTime = (float)(currentMillis - startMillis) / 1000; // Время замера
// Результаты замера
if (0.0 == metering.accel30 && gpsSpeedKm >= 30) {
metering.accel30 = meteringTime; // Разгон до 30км/ч
}
else if (0.0 == metering.accel60 && gpsSpeedKm >= 60) {
metering.accel60 = meteringTime; // Разгон до 60км/ч
}
else if (0.0 == metering.accel100 && gpsSpeedKm >= 100) {
metering.accel100 = meteringTime; // Разгон до 100км/ч
}
}
else if (start && 0 == gpsSpeedKm) { // Если остановились
start = false;
}
if ( startzamer > 0 &&meteringTime > 1 ) {
lcd.clear();
lcd.setCursor(0, 0);
lcd.print("ZAMER");
lcd.printByte(5);
lcd.print( metering.accel30);
lcd.printByte(5);
lcd.print( metering.accel60);
delay(100);
lcd.setCursor(0, 1);
lcd.print( metering.accel100);
delay(10000);}
}
///}
void sendtowebGPS(){
WiFi.softAPdisconnect();
WiFi.disconnect();
WiFi.mode(WIFI_STA);
delay(100);
WiFi.begin(ssid, password);
while (WiFi.waitForConnectResult() != WL_CONNECTED) {
delay(5000);
ESP.restart();
}
WiFiClient client;
EEPROM.begin(512);
if (client.connect(host, 80))
{
client.print( "GET /gps.php?");
client.print("pak0=");
client.print( gps.location.lat(),5);
client.print("&");
client.print("&");
client.print("pak1=");
client.print( gps.location.lng(),5 );
client.print("&");
client.print("&");
client.print("pak2=");
client.print( gps.speed.kmph() );
client.print("&");
client.println( " HTTP/1.1");
client.print( "Host:" ); //////www.gansta-paradise.com
client.println(host);
client.println( "Connection: close" );
client.println();
client.println(); }
else {
// If Arduino can't connect to the server (your computer or web page)
Serial.println("--> connection failed\n");
}
Serial.println("srabotalo-web-GPS");
///ESP.reset();
}
///////////////////памяти еще много есть где разгуляться ......//////////
Вернуться в «Разгонометр»
Количество пользователей, которые сейчас просматривают этот форум: нет зарегистрированных пользователей и 3 гостей