Sonar réalisation 3
Le modèle est consu pour être porté à la taille et avec des notes séparées par deux degrés afin de rester dans sa plage d'audition.
La photo :
Le programme :
/*
* Code pour Manu pour un capteur à ultrasons HC-SR04.
le son est sur le pin 7
*/
/* Constantes pour les broches */
const byte TRIGGER_PIN = 2; // Broche TRIGGER
const byte ECHO_PIN = 3; // Broche ECHO
/* Constantes pour le timeout */
const unsigned long MEASURE_TIMEOUT = 25000UL; // 25ms = ~8m à 340m/s
/* Vitesse du son dans l'air en mm/us */
const float SOUND_SPEED = 340.0 / 1000;
/** Fonction setup() */
void setup() {
/* Initialise le port série */
Serial.begin(115200);
/* Initialise les broches */
pinMode(TRIGGER_PIN, OUTPUT);
digitalWrite(TRIGGER_PIN, LOW); // La broche TRIGGER doit être à LOW au repos
pinMode(ECHO_PIN, INPUT);
}
/** Fonction loop() */
void loop() {
/* 1. Lance une mesure de distance en envoyant une impulsion HIGH de 10µs sur la broche TRIGGER */
digitalWrite(TRIGGER_PIN, HIGH);
delayMicroseconds(10);
digitalWrite(TRIGGER_PIN, LOW);
/* 2. Mesure le temps entre l'envoi de l'impulsion ultrasonique et son écho (si il existe) */
long measure = pulseIn(ECHO_PIN, HIGH, MEASURE_TIMEOUT);
/* 3. Calcul la distance à partir du temps mesuré */
float distance_mm = measure / 2.0 * SOUND_SPEED;
long cm = distance_mm / 10;
/* Affiche les résultats en mm, cm et m */
Serial.print(F("Distance: "));
Serial.print(distance_mm);
Serial.print(F("mm ("));
Serial.print(cm);
Serial.print(F("cm, "));
Serial.print(distance_mm / 1000.0, 2);
Serial.println(F("m)"));
if (cm>250 && cm<300)
{
tone(7,523,150);
}
if (cm>200 && cm<250)
{
tone(7,659,150);
}
if (cm>150 && cm<200)
{
tone(7,784,150);
}
if (cm>100 && cm<150)
{
tone(7,988,150);
}
if (cm>30 && cm<100)
{
tone(7,1175,150);
}
/* Délai d'attente pour éviter d'afficher trop de résultats à la seconde */
delay(75);
}