#91 Frasnow Sab 31 Ott, 2015 14:39
Complimenti!!!
____________ Cricca Inox
La meteorologia è una scienza inesatta, che elabora dati incompleti, con metodi discutibili per fornire previsioni inaffidabili. Andrea Baroni
-
-
Contributor Socio Ordinario
-
- Utente #: 510
- Registrato: 19 Gen 2009
- Età: 31
- Messaggi: 17261
-
4631 Punti
- Preferenza Meteo: Freddofilo
- Stazione Meteo: Ecowitt
- Località: Beroide (PG) - 223mslm
-
#92 As_Needed Sab 31 Ott, 2015 17:29
Grazie ancora! Comunque vorrei specificare che purtroppo non posso inserirci anche un datalogger, usando una semplice sd, perché se no dovrei rifare tutto il circuito stampato e non credo possa rifarlo... In ogni caso per le massime e minime ci vuole un RTC, che serve come orologio, se no arduino non sa che giorno è e che ora è! Quello non ha bisogno di resistenze e niente e forse posso inserirlo nel circuito stampato, devo chiedere se si può fare... Speriamo perché mi dispiacerebbe se magari riuscissi a mettere tutto online non sapere né massime né minime.
Ultima modifica di As_Needed il Sab 31 Ott, 2015 17:30, modificato 1 volta in totale
-
-
Guru Socio Ordinario
-
- Utente #: 1789
- Registrato: 15 Ott 2014
- Età: 28
- Messaggi: 7489
-
174 Punti
- Preferenza Meteo: Indifferente
- Stazione Meteo: Altro
- Località: Melbourne, Australia
-
#93 Gab78 Dom 01 Nov, 2015 10:27
Bene bene, se dovessi avere problemi con la Davis, (scrat... scrat...  ) so già a chi potrei rivolgermi...
____________ I love Appennino...
-
-
Guru Socio Sostenitore
-
- Utente #: 874
- Registrato: 30 Ott 2010
- Età: 47
- Messaggi: 12048
-
3995 Punti
- Preferenza Meteo: Indifferente
- Stazione Meteo: Davis Vantage Vue, Ventus W83x e Altro
- Località: San Giovanni Profiamma - 270 m s.l.m. - frazione di Foligno (PG)
-
#95 As_Needed Dom 01 Nov, 2015 12:33
 Comunque vi rivolgo una domanda ai più esperti. Siccome me ne sono fregato che si legge piccolo sul display e ho voluto aggiungere tutti i valori che riesco a inserire, ho aggiunto pure il wind chill, che però ho visto che la sua equazione è applicabile solo con valori inferiori a 10 gradi e superiori a 4.8km/h... Fin qui ci siamo, ho messo un if che per valori non in quel modo il wind chill è uguale alla temperatura. Però per l'indice di calore ho usato questa equazione
http://www.centrometeo.com/articoli...e-heat-index-hi
Qui ho scoperto che è applicabile in modo veritiero solo per valori sopra 26.7... Conoscete quella con il dew point che penso sia applicabile anche con tutti i valori?
Foto
EDIT: Adesso sì che c'è spazio
Con questa disposizione posso metterci anche volendo l'indice THW, UMIDEX e temperatura interna utilizzando il sensore di pressione e ovviamente anche la pressione.
Se riesco a mettere il RTC lascio perdere il THW etc e metto le massime e le minime sul display stesso
Ultima modifica di As_Needed il Dom 01 Nov, 2015 13:17, modificato 3 volte in totale
-
-
Guru Socio Ordinario
-
- Utente #: 1789
- Registrato: 15 Ott 2014
- Età: 28
- Messaggi: 7489
-
174 Punti
- Preferenza Meteo: Indifferente
- Stazione Meteo: Altro
- Località: Melbourne, Australia
-
#97 As_Needed Dom 01 Nov, 2015 13:43
Se vuoi ti do quella che uso per la rete... considera che però è una funzione in PHP. Dovrai poi riconvertirla. 
Va bene ci provo  Quella del windchill pare che va bene, anche se però vedo sulla stazione di pigi che anche con valori sopra 10 gradi il wind chill non è identico alla temperatura, quindi se hai anche quella mi farebbe piacere 
Il dew point invece quello che ho è perfetto l'ho confrontato ovunque ed è precisissimo
Ultima modifica di As_Needed il Dom 01 Nov, 2015 13:44, modificato 1 volta in totale
-
-
Guru Socio Ordinario
-
- Utente #: 1789
- Registrato: 15 Ott 2014
- Età: 28
- Messaggi: 7489
-
174 Punti
- Preferenza Meteo: Indifferente
- Stazione Meteo: Altro
- Località: Melbourne, Australia
-
#98 andrea75 Dom 01 Nov, 2015 15:15
Se vuoi ti do quella che uso per la rete... considera che però è una funzione in PHP. Dovrai poi riconvertirla. 
Va bene ci provo  Quella del windchill pare che va bene, anche se però vedo sulla stazione di pigi che anche con valori sopra 10 gradi il wind chill non è identico alla temperatura, quindi se hai anche quella mi farebbe piacere 
Il dew point invece quello che ho è perfetto l'ho confrontato ovunque ed è precisissimo 
Allora, te l'ho un po' semplificata, perché in quella "ufficiale" ci sono più variabili. Cmq dovrebbe andare lo stesso:
-
$var1 = (7.5*temp)/(237.7+temp) // temp in °C
-
$var2 = 6.11*Pow(10,$var1) // cioè 10 elevato al valore di $var1
-
$var3 = (umid*$var2)/100 // umidità senza % (ad es: 75)
-
$var4 = log($var3/6.11) // cioè logaritmo in base e del valore di ($var3/6.11)
-
$dewp = $var4*237.7/(7.5*log(10)-$var4) // risultato finale in °C
Le tue variabili in ingresso sono ovviamente "temp" e "umid".
Quella del windchill che uso è questa, con gli <if> del range di temperatura e vento già inclusi
-
if (($temp<10)&&($wind>4.6))
-
{
-
$windc=13.12+0.6215*$temp-11.37*pow($wind,0.16)+0.3965*$temp*pow($wind,0.16);
-
}
-
____________ Facebook: lineameteo - Twitter: @lineameteo
Stazione meteo di San Mariano (PG)
Dati meteo in tempo reale
http://sanmariano.lineameteo.it
-
-
Presidente
-
- Utente #: 2
- Registrato: 31 Mar 2005
- Età: 49
- Messaggi: 45082
-
3593 Punti
- Preferenza Meteo: Freddofilo
- Stazione Meteo: LaCrosse WS2300
- Località: San Mariano (PG) - 290 mt.
-
#99 As_Needed Dom 01 Nov, 2015 15:22
Se vuoi ti do quella che uso per la rete... considera che però è una funzione in PHP. Dovrai poi riconvertirla. 
Va bene ci provo  Quella del windchill pare che va bene, anche se però vedo sulla stazione di pigi che anche con valori sopra 10 gradi il wind chill non è identico alla temperatura, quindi se hai anche quella mi farebbe piacere 
Il dew point invece quello che ho è perfetto l'ho confrontato ovunque ed è precisissimo 
Allora, te l'ho un po' semplificata, perché in quella "ufficiale" ci sono più variabili. Cmq dovrebbe andare lo stesso:
-
$var1 = (7.5*temp)/(237.7+temp) // temp in °C
-
$var2 = 6.11*Pow(10,$var1) // cioè 10 elevato al valore di $var1
-
$var3 = (umid*$var2)/100 // umidità senza % (ad es: 75)
-
$var4 = log($var3/6.11) // cioè logaritmo in base e del valore di ($var3/6.11)
-
$dewp = $var4*237.7/(7.5*log(10)-$var4) // risultato finale in °C
Le tue variabili in ingresso sono ovviamente "temp" e "umid".
Quella del windchill che uso è questa, con gli <if> del range di temperatura e vento già inclusi
-
if (($temp<10)&&($wind>4.6))
-
{
-
$windc=13.12+0.6215*$temp-11.37*pow($wind,0.16)+0.3965*$temp*pow($wind,0.16);
-
}
-
Allora quella del wind chill praticamente è identica:
- windchill=(13.12+0.6215*sensors.getTempCByIndex(0))-(11.37*pow(KMH,0.16))+(0.3965*sensors.getTempCByIndex(0)*pow(KMH,0.16));
- if ((windchill<sensors.getTempCByIndex(0))&&(KMH>4.6))
- {
- windchill=(13.12+0.6215*sensors.getTempCByIndex(0))-(11.37*pow(KMH,0.16))+(0.3965*sensors.getTempCByIndex(0)*pow(KMH,0.16));
- }
- else
- {
- windchill=sensors.getTempCByIndex(0);
- }
-
-
solo che ho messo per farla più precisa che se il wind chill diventa meno della temperatura allora esegue la formula, per non perdersi niente, mentre invece se è sopra alla temperatura allora il wind chill diventa uguale alla temperatura.
Per l'heat index non ho ben capito, devo calcolare tutte le variabili e poi con quelle si trova l'indice?
Comunque il dew point con linguaggio C il l'ho messo così è quello come ho detto è precisissimo, l'unico che non riesco a capire come fare è l'heat index...
- dewPoint = (pow (h/100,0.125)*(112+(0.9*sensors.getTempCByIndex(0)))+0.1*sensors.getTempCByIndex(0)-112);
-
-
Ultima modifica di As_Needed il Dom 01 Nov, 2015 15:53, modificato 2 volte in totale
-
-
Guru Socio Ordinario
-
- Utente #: 1789
- Registrato: 15 Ott 2014
- Età: 28
- Messaggi: 7489
-
174 Punti
- Preferenza Meteo: Indifferente
- Stazione Meteo: Altro
- Località: Melbourne, Australia
-
#100 andrea75 Dom 01 Nov, 2015 16:09
Questo è l'heat hindex, dove $temp è la temperatura e $ UR l'umidità relativa.
-
if (($temp >= 27)&&($UR >= 40))
-
{
-
$Tf = $temp*(9/5) + 32;
-
$t2 = $Tf*$Tf;
-
$u2 = $UR*$UR;
-
$HIf = -42.379 + (2.04901523*$Tf) + (10.14333127*$UR) - (0.22475541*$Tf*$UR) - (6.83783e-3*$t2) - (5.481717e-2*$u2) + (1.22874e-3*$t2*$UR) + (8.5282e-4*$Tf*$u2) - (1.99e-6*$t2*$u2);
-
$hi = (5/9) * ($HIf - 32);
-
$hi = number_format($hi,1,'.','');
-
}
-
else
-
{
-
$hi = $temp;
-
}
-
____________ Facebook: lineameteo - Twitter: @lineameteo
Stazione meteo di San Mariano (PG)
Dati meteo in tempo reale
http://sanmariano.lineameteo.it
-
-
Presidente
-
- Utente #: 2
- Registrato: 31 Mar 2005
- Età: 49
- Messaggi: 45082
-
3593 Punti
- Preferenza Meteo: Freddofilo
- Stazione Meteo: LaCrosse WS2300
- Località: San Mariano (PG) - 290 mt.
-
#101 As_Needed Dom 01 Nov, 2015 16:41
Questo è l'heat hindex, dove $temp è la temperatura e $ UR l'umidità relativa.
-
if (($temp >= 27)&&($UR >= 40))
-
{
-
$Tf = $temp*(9/5) + 32;
-
$t2 = $Tf*$Tf;
-
$u2 = $UR*$UR;
-
$HIf = -42.379 + (2.04901523*$Tf) + (10.14333127*$UR) - (0.22475541*$Tf*$UR) - (6.83783e-3*$t2) - (5.481717e-2*$u2) + (1.22874e-3*$t2*$UR) + (8.5282e-4*$Tf*$u2) - (1.99e-6*$t2*$u2);
-
$hi = (5/9) * ($HIf - 32);
-
$hi = number_format($hi,1,'.','');
-
}
-
else
-
{
-
$hi = $temp;
-
}
-
Ah ecco hai inserito l'if visto che vale solo per un certo valore, anche io adesso l'ho messo, però siccome ho visto che sulla stazione di pigi l'indice di calore varia anche sotto quella temperatura, mi chiedevo se esisteva un'altra equazione, in ogni caso adesso lascio questa.
Ultima modifica di As_Needed il Ven 06 Nov, 2015 17:12, modificato 6 volte in totale
-
-
Guru Socio Ordinario
-
- Utente #: 1789
- Registrato: 15 Ott 2014
- Età: 28
- Messaggi: 7489
-
174 Punti
- Preferenza Meteo: Indifferente
- Stazione Meteo: Altro
- Località: Melbourne, Australia
-
#103 As_Needed Dom 01 Nov, 2015 17:00
Ho trovato che la davis utilizza uno strano metodo di calcolo rispetto al normale ecco perché varia
http://forum.meteonetwork.it/stazio...ice-calore.html
http://forum.meteonetwork.it/strume...heat-index.html
mha mi tengo questa dei 27 gradi intanto a che serve sotto l'indice di calore
pubblico qui per arduino le formule 
DEW POINT
- dewPoint = (pow (h/100,0.125)*(112+(0.9*sensors.getTempCByIndex(0)))+0.1*sensors.getTempCByIndex(0)-112);
-
-
h è l'umidità e sensor etc è la temperatura
WIND CHILL
- windchill=(13.12+0.6215*sensors.getTempCByIndex(0))-(11.37*pow(KMH,0.16))+(0.3965*sensors.getTempCByIndex(0)*pow(KMH,0.16));
- if ((windchill<sensors.getTempCByIndex(0))&&(KMH>4.6))
- {
- windchill=(13.12+0.6215*sensors.getTempCByIndex(0))-(11.37*pow(KMH,0.16))+(0.3965*sensors.getTempCByIndex(0)*pow(KMH,0.16));
- }
- else
- {
- windchill=sensors.getTempCByIndex(0);
- }
-
sensor ect è la temperatura e KMH la velocità del vento in km/h
ho messo all'inizio l'if diverso in modo tale che così non si perda niente del wind chill, se no magari siccome sono 12 gradi segna sempre 12 anche se c'è un vento di 50 km/h
HEAT INDEX
-
- temperaturaf=sensors.getTempCByIndex(0)*1.8+32;
-
- if ((sensors.getTempCByIndex(0)>=26.7)&&(h>=40))
- {
- heatindexf=(-42.379+2.04901523*temperaturaf+10.14333127*h-0.22475541*temperaturaf*h-0.00683783*pow(temperaturaf,2)-0.05481717*pow(h,2)+0.00122874*pow(temperaturaf,2)*h+0.00085282*temperaturaf*pow(h,2)-0.00000199*pow(temperaturaf,2)*pow(h,2));
- heatindexc= (heatindexf-32)/1.8;
- }
- else
- {
- heatindexc=sensors.getTempCByIndex(0);
- }
-
Uguale a quella di Andrea
Piccolo aggiornamento di dove vedrò la pressione
Ultima modifica di As_Needed il Dom 01 Nov, 2015 17:13, modificato 1 volta in totale
-
-
Guru Socio Ordinario
-
- Utente #: 1789
- Registrato: 15 Ott 2014
- Età: 28
- Messaggi: 7489
-
174 Punti
- Preferenza Meteo: Indifferente
- Stazione Meteo: Altro
- Località: Melbourne, Australia
-
#104 As_Needed Ven 06 Nov, 2015 16:58
Finalmente ho finito il programma!! Successivamente lavorerò per le minime e massime, adesso veramente devo solo montare il tutto.
Questo il programma completo (ho migliorato anche la grafica  Ho messo 4 if che a seconda di quanto è la temperatura esterna, il colore del valore della temperatura cambia)
- #include <Wire.h>
- #include <BMP180.h>
- #include <SPI.h>
- #include <Adafruit_GFX.h>
- #define sclk 13
- #define mosi 11
- #define cs 10
- #define dc 9
- #define rst 8
- #include <Adafruit_GFX.h> // Core graphics library
- #include <Adafruit_ST7735.h> // Hardware-specific library
- #include <SPI.h>
- Adafruit_ST7735 tft = Adafruit_ST7735(cs, dc, rst);
- #include "DHT.h"
- #include <OneWire.h>
- #include <DallasTemperature.h>
- // Data wire is plugged into pin 2 on the Arduino
- #define ONE_WIRE_BUS 2
- // Setup a oneWire instance to communicate with any OneWire devices
- // (not just Maxim/Dallas temperature ICs)
- OneWire oneWire(ONE_WIRE_BUS);
- // Pass our oneWire reference to Dallas Temperature.
- DallasTemperature sensors(&oneWire);
- DHT dht(3,DHT22); //Definisco il pin al quale è collegato il sensore e il tipo
- float dewPoint;
- float windchill;
- float temperaturaf;
- float heatindexf;
- float heatindexc;
- float pressionelivellodelmarehPa;
- float pressionelivellodelmare;
- int dataPin = 4;
- int bitLength = -1;
- int data[45];
- int gooddata = 1;
- int timeout;
- int loops = 0;
- int spd[8];
- int i = 0;
- int j = 0;
- char windDirection[16][4] = {
- "N","NNE","NE", "ENE","E","ESE","SE","SSE","S","SSW","SW","WSW","W","WNW","NW","NNW"};
- // Store an instance of the BMP180 sensor.
- BMP180 barometer;
- // Store the current sea level pressure at your location in Pascals.
- float seaLevelPressure = 102500;
-
- void setup() {
- tft.initR(INITR_BLACKTAB);
- Serial.begin(9600);
- //Serial.println("DHT test");
- dht.begin();
- // Start up the library
- sensors.begin();
- Serial.print("\n\nInitializing...\n");
- // Serial.print("Data Pin: ");
- // Serial.println(digitalRead(dataPin));
- pinMode(dataPin, INPUT);
- // We start the I2C on the Arduino for communication with the BMP180 sensor.
- Wire.begin();
- // We create an instance of our BMP180 sensor.
- barometer = BMP180();
- // We check to see if we can connect to the sensor.
- if(barometer.EnsureConnected())
- {
- Serial.println("Connected to BMP180."); // Output we are connected to the computer.
- // When we have connected, we reset the device to ensure a clean start.
- barometer.SoftReset();
- // Now we initialize the sensor and pull the calibration data.
- barometer.Initialize();
- }
- else
- {
- Serial.println("No sensor found.");
- }
- }
-
-
- //void delay2(unsigned long ms){
- // unsigned long start = micros();
- // while (micros() - start <= ms);
- //}
-
- void loop() {
- sensors.requestTemperatures();
- pressionelivellodelmare=barometer.GetPressure()+5473;
- pressionelivellodelmarehPa=pressionelivellodelmare/100;
- float h = dht.readHumidity(); // Leggo il valore di umidità
- //float t = dht.readTemperature(); // Leggo il valore di temperatura
- //if (isnan(t) || isnan(h)) // Se almeno uno dei due valori è NaN (Not a Number)
-
- //Serial.println("Impossibile leggere il sensore!");
-
- //else //altrimenti
- if(barometer.IsConnected)
- {
- // Retrive the current pressure in Pascals.
- long currentPressureP = barometer.GetPressure();
- float currentPressuremb = currentPressureP/100.0;
- float currentPressureinHg = currentPressuremb*0.02953;
-
-
- // Retrive the current altitude (in meters). Current Sea Level Pressure is required for this.
- float altitudem = barometer.GetAltitude(seaLevelPressure);
- float altitudeft = altitudem*3.2808;
-
-
- // Retrive the current temperature in degrees celcius.
- float currentTemperatureC = barometer.GetTemperature();
- float currentTemperatureF = (9.0/5.0)*currentTemperatureC+32.0;
- }
- Serial.print("Temperatura ");
- Serial.println(sensors.getTempCByIndex(0));
- Serial.print("Umidita' ");
- Serial.print(h);
- Serial.print(" %\t");
-
- Serial.println ("Dew Point");
- Serial.print (dewPoint);
- Serial.println ("C");
- //Serial.println ("Wind Chill");
- //Serial.print (windchillc);
- //Serial.print ("C");
-
- dewPoint = (pow (h/100,0.125)*(112+(0.9*sensors.getTempCByIndex(0)))+0.1*sensors.getTempCByIndex(0)-112);
- temperaturaf=sensors.getTempCByIndex(0)*1.8+32;
-
- if ((sensors.getTempCByIndex(0)>=26.7)&&(h>=40))
- {
- heatindexf=(-42.379+2.04901523*temperaturaf+10.14333127*h-0.22475541*temperaturaf*h-0.00683783*pow(temperaturaf,2)-0.05481717*pow(h,2)+0.00122874*pow(temperaturaf,2)*h+0.00085282*temperaturaf*pow(h,2)-0.00000199*pow(temperaturaf,2)*pow(h,2));
- heatindexc= (heatindexf-32)/1.8;
- }
- else
- {
- heatindexc=sensors.getTempCByIndex(0);
- }
- //delay(1000);
-
- //Serial.print("Temperatura: ");
- //Serial.print(t);
- //Serial.println(" *C");
- // non è necessario mettere un delay() perchè ci vogliono due secondi per leggere i valori, quindi il serial monitor riceverà dati ogni 2 secondi.
-
- Serial.println("Start");
- gooddata = 1;
- collectData();
- if (gooddata == 1) {
- rawdump();
- outputResults();
- TheData();
- }
- else {
- Serial.println ("READ ERROR");
- }
- Serial.println(++loops);
- Serial.println();
- delay(1500);
- }
-
- int collectData(void) {
- if (bitLength <0){
- bitLength = 1220;//getbitlenght2();
-
- }
-
- pinMode(dataPin, OUTPUT);
-
- digitalWrite(dataPin, HIGH);
- delay(100);
- digitalWrite(dataPin, LOW );
- delay(500);
- pinMode(dataPin, INPUT);
-
-
- while(digitalRead(dataPin) == LOW){
- }
- //wait slave start signal
- while(digitalRead(dataPin) == HIGH){
- }
- while(digitalRead(dataPin) == LOW){
- }
-
-
-
-
- for (int i=0 ; i<42 ; i++) {
- data[i] = (digitalRead(dataPin) == LOW)? 0:1; // read and save either a 0 or 1
- delayMicroseconds(bitLength);
- }
- }
-
- int TheData() {
- Serial.println("TheData");
- int i, idx = 0, idy = 0;
- // for (i=8; i>4; i--) { dato originale
- for (i=6; i>2; i--) { // dato modificato
- idx = idx *2 + data[i];
- }
-
- // Serial.print("idx: ");
- // Serial.println(idx, DEC);
- Serial.print("Wind: ");
- Serial.println(windDirection[idx] );
-
- // for (i=17; i>8; i--) { dato originale per velocità
- for (i=15; i>6; i--) { // dato modificato
- idy = idy * 2 + data[i];
- }
-
- Serial.print("Speed: ");
- Serial.print(idy, DEC);
- Serial.println (" m/s read");
-
- float idz = idy/10.0;
- Serial.print("Speed: ");
- Serial.print(idz);
- Serial.println (" m/s real");
-
- float KMH = idz * 3.6;
- Serial.print("Speed: ");
- Serial.print(KMH);
- Serial.println (" kmh");
-
- float MPH = KMH * 0.621371192;
- Serial.print("Speed: ");
- Serial.print(MPH);
- Serial.println (" mph");
-
- windchill=(13.12+0.6215*sensors.getTempCByIndex(0))-(11.37*pow(KMH,0.16))+(0.3965*sensors.getTempCByIndex(0)*pow(KMH,0.16));
- if ((windchill<sensors.getTempCByIndex(0))&&(KMH>4.6))
- {
- windchill=(13.12+0.6215*sensors.getTempCByIndex(0))-(11.37*pow(KMH,0.16))+(0.3965*sensors.getTempCByIndex(0)*pow(KMH,0.16));
- }
- else
- {
- windchill=sensors.getTempCByIndex(0);
- }
-
- tft.fillScreen(ST7735_BLACK);
- tft.setTextColor (ST7735_GREEN);
- tft.setCursor(0, 0);
- tft.setTextSize(1);
- tft.println("Temp.OUTSIDE");
- if (sensors.getTempCByIndex(0)<3)
- {
- tft.setTextColor (ST7735_BLUE);
- tft.setCursor(80, 0);
- tft.setTextSize(1);
- tft.print(sensors.getTempCByIndex(0));
- tft.print ( (char)248);
- tft.println("C");
- //delay(5000);
- }
- if ((sensors.getTempCByIndex(0)>=3)&&(sensors.getTempCByIndex(0)<=15))
- {
- tft.setTextColor (ST7735_GREEN);
- tft.setCursor(80, 0);
- tft.setTextSize(1);
- tft.print(sensors.getTempCByIndex(0));
- tft.print ( (char)248);
- tft.println("C");
- }
- if ((sensors.getTempCByIndex(0)>15)&&(sensors.getTempCByIndex(0)<30))
- {
- tft.setTextColor (ST7735_YELLOW);
- tft.setCursor(80, 0);
- tft.setTextSize(1);
- tft.print(sensors.getTempCByIndex(0));
- tft.print ( (char)248);
- tft.println("C");
- }
- if ((sensors.getTempCByIndex(0)>=30))
- {
- tft.setTextColor (ST7735_RED);
- tft.setCursor(80, 0);
- tft.setTextSize(1);
- tft.print(sensors.getTempCByIndex(0));
- tft.print ( (char)248);
- tft.println("C");
- }
-
- tft.setTextColor (ST7735_WHITE);
- tft.setCursor (0,10);
- tft.setTextSize (1);
- tft.print ("Umidita'");
- tft.setCursor (80,10);
- tft.setTextSize (1);
- tft.print (dht.readHumidity());
-
- tft.print (" %");
-
- tft.setCursor (0,20);
- tft.setTextSize (1);
- tft.print ("Dew Point");
- tft.setCursor (80,20);
- tft.setTextSize (1);
- tft.print (dewPoint);
- tft.print ((char)248);
- tft.print ("C");
- tft.setCursor (0,30);
- tft.setTextSize (1);
- tft.println ("Vento");
- tft.setCursor (55,30);
- tft.setTextSize (1);
- tft.print (KMH);
- tft.print ("Km/h");
- tft.setCursor (110,30);
- tft.setTextSize (1);
- tft.print (windDirection[idx]);
- tft.setCursor (0,40);
- tft.setTextSize (1);
- tft.print ("Pressione");
- tft.setCursor (65,40);
- tft.setTextSize (1);
- tft.print (pressionelivellodelmarehPa);
- tft.setCursor (110,40);
- tft.setTextSize (1);
- tft.print ("hPa");
- tft.setTextColor (ST7735_BLUE);
- tft.setCursor (0,50);
- tft.setTextSize(1);
- tft.print ("Wind Chill");
- tft.setCursor (80,50);
- tft.setTextSize(1);
- tft.print (windchill);
- tft.print ((char)248);
- tft.print ("C");
- tft.setTextColor (ST7735_RED);
- tft.setCursor (0,60);
- tft.setTextSize (1);
- tft.println ("Heat Index");
- tft.setCursor (80,60);
- tft.setTextSize (1);
- tft.print (heatindexc);
- tft.print ((char)248);
- tft.print ("C");
- tft.setTextColor (ST7735_YELLOW);
- tft.setCursor(0, 70);
- tft.setTextSize(1);
- tft.println("Temp.INSIDE");
- tft.setCursor(80, 70);
- tft.setTextSize(1);
- tft.print(barometer.GetTemperature());
- tft.setTextSize(1);
- tft.print((char)248);
- tft.setTextSize(1);
- tft.println("C");
- tft.drawLine (0,80,tft.width()-1,80,ST7735_WHITE);
- }
- void rawdump() {
- Serial.print("Raw: ");
- for (int i=0 ; i<41 ; i++) {
- Serial.print (data[i]);
- if (i == 4) {
- Serial.print (" ");
- }
- if (i == 8) {
- Serial.print (" ");
- }
- if (i == 17) {
- Serial.print (" ");
- }
- if (i == 20) {
- Serial.print (" ");
- }
- if (i == 24) {
- Serial.print (" ");
- }
- if (i == 28) {
- Serial.print (" ");
- }
- if (i == 37) {
- Serial.print (" ");
- }
- }
- }
-
- void outputResults() {
- Serial.println();
-
- int idx =0;
- for (int i=8 ; i> 4 ; i--)
- //for (int i=6 ; i> 2 ; i--) // dato modificato
- {
- idx = idx *2 + data[i]; // data[i] == 0/1.. see prev post. //
- }
-
- Serial.print("idx: ");
- Serial.println(idx, DEC);
- Serial.print("Wind: ");
- Serial.println(windDirection[idx] );
- // Serial.println();
-
- Serial.print("Swapped: ");
-
- //HEAD
- for (int i =0 ; i< 5 ; i++)
- {
- Serial.print(data[i]); // it contains 0 or 1
- }
-
- Serial.print(" ");
-
- //WINDDIR
- for (int i =8 ; i> 4 ; i--)
- {
- Serial.print(data[i]);
- }
- Serial.print(" ");
-
- //WIND SPEED
- for (int i =17 ; i> 8 ; i--)
- {
- Serial.print(data[i]);
- }
-
- Serial.print(" ");
-
- //WIND SPEED+3
- for (int i =20 ; i> 17 ; i--)
- {
- Serial.print(data[i]);
- }
-
- Serial.print(" ");
-
- /*
- // Checksum
- for (iCounter=0;iCounter<4;iCounter++)
- {
- checksum |= (TX23_DATA_GET_BIT << iCounter);
- delayTargetuSec += bitLength;
- TX23_DoDelay;
- }
-
- //Calculate Checksum
- unsigned int checksumCalc = 0;
- checksumCalc += (winddir & 15);
- checksumCalc += ((windspeed >> 8) & 15);
- checksumCalc += ((windspeed >> 4) & 15);
- checksumCalc += (windspeed & 15);
- */
-
- // Checksum
- for (int i =24 ; i> 20 ; i--)
- {
- Serial.print(data[i]);
- }
-
- Serial.print(" ");
-
- //WIND DIR NEGATEIVE
- for (int i =28 ; i> 24 ; i--)
- {
- Serial.print(data[i]);
- }
-
- Serial.print(" ");
-
- //WIND SPEED NEGATED
- for (int i =37 ; i> 28 ; i--){
- Serial.print(data[i]);
- }
-
- Serial.print(" ");
-
- //WIND SPEED NEGATED +3
- for (int i =40 ; i> 37 ; i--){
- Serial.print(data[i]);
- }
- Serial.println();
- // Serial.println();
- // Serial.println();
-
-
-
- }
-
Comprende tutti i valori che si leggono in questa foto la stazione meteo.
Ho tarato la pressione con la davis di pigi ed è identico il valore di pressione, ovviamente sul livello del mare, alla sua che sta a 2km. In più ovviamente adesso che c'è questa struttura anticiclonica di sicuro non mi sbaglio  Vedi che serve a qualcosa
P.S. A leggere tutto ci vogliono circa 5/6 secondi per via della lunghezza del programma.
Ultima modifica di As_Needed il Ven 06 Nov, 2015 17:13, modificato 3 volte in totale
-
-
Guru Socio Ordinario
-
- Utente #: 1789
- Registrato: 15 Ott 2014
- Età: 28
- Messaggi: 7489
-
174 Punti
- Preferenza Meteo: Indifferente
- Stazione Meteo: Altro
- Località: Melbourne, Australia
-
#105 Gab78 Ven 06 Nov, 2015 22:10
Ancora complimenti...!
____________ I love Appennino...
-
-
Guru Socio Sostenitore
-
- Utente #: 874
- Registrato: 30 Ott 2010
- Età: 47
- Messaggi: 12048
-
3995 Punti
- Preferenza Meteo: Indifferente
- Stazione Meteo: Davis Vantage Vue, Ventus W83x e Altro
- Località: San Giovanni Profiamma - 270 m s.l.m. - frazione di Foligno (PG)
-
Questo argomento è stato utile?
Questo argomento è stato utile?
Condividi Argomento |
|
 |
Inserisci un link per questo argomento |
URL |
|
BBCode |
|
HTML |
|
Argomenti Simili
Argomenti Simili
Lista Permessi
|
Non puoi inserire nuovi Argomenti Non puoi rispondere ai Messaggi Non puoi modificare i tuoi Messaggi Non puoi cancellare i tuoi Messaggi Non puoi votare nei Sondaggi Non puoi allegare files Puoi scaricare gli allegati Non puoi inserire eventi calendario
|
|
|
|
|