ultrasonido

Dependencies:   mbed mbed-rtos HCSR04

Revision:
1:5b7333529d77
Parent:
0:a2d6bebaf8ed
--- a/main.cpp	Thu Nov 19 14:23:27 2020 +0000
+++ b/main.cpp	Fri Nov 20 03:49:36 2020 +0000
@@ -1,39 +1,67 @@
 #include "mbed.h"
+#include "rtos.h"
 #include "HCSR04.h"
 
-//HCSR04 usensor(PTE1,PTE0);// (trig,echo)
+
 HCSR04 usensor(D15,D14);// (trig,echo)
+
 Serial pc(USBTX, USBRX); //comunicacion serial
-// Se encenderan Led's dependiendo de la distancia
-DigitalOut myled1(LED1);
-DigitalOut myled2(LED2);
-DigitalOut myled3(LED3);
+
+PwmOut servo(A2);
+DigitalOut led1(LED1);
+DigitalOut led2(LED2);
+
+Thread thread_servo;
+Thread thread_sensor;
+
+
+
+unsigned int distancia;//tomara el valor de la distancia
+
+void task_servo(){
+    while(true){
+        servo.pulsewidth_us(500);
+        Thread::wait(1000);
+        servo.pulsewidth_us(2000);
+        Thread::wait(1000);
+        }
+    }
 
-int distancia;//tomara el valor de la distancia
+void task_sensor(){
+    while(true){
+        distancia = usensor.distance(CM);
+        
+        if(distancia<10){
+            led1=0;
+            led2=1;
+            }
+            else if(distancia<20){
+                led1=1;
+                led2=0;
+                
+                     }
+             else{
+                led1=1;
+                led2=1;
+                } 
+        pc.printf("%u\n",distancia);
+        Thread::wait(100);
+        
+        }
+    }
 
 int main() {
+    
     pc.baud(9600);
-    while(1) {
-        distancia = usensor.distance(CM);//se toma la distancia en cm y se actua depediendo de esta
-        if(distancia<10){
-            
-            myled1=0;
-            myled2=1;
-            myled3=1;
-        }
-        else if(distancia<20){
-          
-            myled1=1;
-            myled2=0;
-            myled3=1;
-        }
-        else{
-          
-            myled1=1;
-            myled2=1;
-            myled3=0;
-        } pc.printf("distancia es (%d)\n\r",distancia);
-        wait(1);      
-    }
+    
+    thread_servo.start(task_servo);
+    thread_sensor.start(task_sensor);
+    
+    servo.period_ms(20);
+    
+    Thread thread_servo(osPriorityNormal);
+    Thread thread_sensor(osPriorityNormal);
+    
+    
 }