Un mensaje por cada activación.

Hola a todos.
Tengo un proyecto donde se activa y queda encendido un motor una vez que determinado botón se presiona por más de un segundo. Además envía que el motor fue encendido. Y ahí está lo que quiero modificar.

En mi código el mensaje se envía cada vez. Es decir, si el motor está más de un segundo envía un mensaje, mientras el botón no se suelta la variable se incrementa, por lo que a los 2,3,4,5, etc. manda un mensaje, hasta que se libera el botón.

Lo que yo quiero es que el mensaje se envíe cuando se libera, enviando el tiempo que estuvo presionado. Es decir obtener un mensaje con su duración por cada activación del botón en vez de muchísimos mensajes por cada vez que el botón se mantiene presionado.

Esta es la parte relevante del código.
Un saludo a todos y gracias, espero puedan darme una mano.

pinMode(5, INPUT); //boton
  //digitalWrite(5, LOW);
  pinMode(4, OUTPUT); //relay
 // digitalWrite(4,LOW);
  delay(200);
}

//--------------------------LOOP--------------------------------
void loop() {
delay(200);
valboton = digitalRead(5);
Serial.println(valboton);

if (valboton==LOW) {
       Serial.println("Comenzando el if");
       if (!countingTime) {
       startBeing1orMore = millis();
       }
   countingTime = true;
   } else {
   countingTime = false;
   }
   if (countingTime && millis() - startBeing1orMore > 1000) {
    digitalWrite(4, HIGH);
    Serial.println("MOTOR ENCENDIDO");
    enviardatos("chipid=" + chipid + "&temperatura=" + solta);
    delay(100);
   } 
  if (valboton==HIGH) {
    digitalWrite(4,LOW);
    Serial.println("MOTOR APAGADO");
    delay(100);
   }
}

Pd.:sorry i put in english, no spanish..... sorry.

Por favor respeta el idioma del foro en el que posteas. Si estas en un foro en inglés no puedes consultar en español.
Por esa razón tu hilo fue movido.

Estudia este ejemplo:

unsigned long t;
bool actual,anterior;

void setup(){
   Serial.begin(9600);
   pinMode(5, INPUT);
}

void loop() {
   actual = digitalRead(5);
   if (actual && !anterior){
      t = millis();      
   }
   if (!actual && anterior){
      Serial.println(millis()-t);      //Tiempo en milisegundos
   }
   anterior = actual;
}

El primer if() detecta el flanco de subida (RISING = LOW --> HIGH) y guarda los milisegundos y el segundo if() detecta el flanco de bajada (FALLING ) HIGH --> LOW)