/*************************************************************************** */
/* motores-sensor3.c Junio-2005 */
/*---------------------------------------------------------------------------*/
/* Ejemplo para el skybot */
/*---------------------------------------------------------------------------*/
/* Se lee el estado del sensor 3 y se activan los motores. Si lee blanco, */
/* el robot se para. Si lee negro avanza. */
/* Es un ejemplo de un comportamiento reactivo muy sencillo */
/*---------------------------------------------------------------------------*/
/* Andres Prieto-Moreno <andres@ifara.com> */
/* Juan Gonzalez <juan@iearobotics.com> */
/*---------------------------------------------------------------------------*/
/* LICENCIA GPL */
/*****************************************************************************/
//-- Especificar el pic a emplear
#define __16f877
#include "pic16f877.h"
//-- Definiciones de los sensores
#define SENSOR1 0x01
#define SENSOR2 0x20
#define SENSOR3 0x40
#define SENSOR4 0x80
//-- Definiciones para los motores. Estos valores definen
//-- los movimientos del robot
#define AVANZA 0x1C
#define ATRAS 0x16
#define IZQUIERDA 0x1E
#define DERECHA 0x14
#define STOP 0x00
//-- Indicar el sensor a utilizar. Por defecto esta puesto el 3, pero se
//-- puede poner cualquier otro: 1,2 o 4.
#define SENSOR SENSOR3
//----------------------------
//- Comienzo del programa
//----------------------------
void main(void)
{
//-- Configurar el puerto B para trabajar con el Skybot
//-- RB0, RB5, RB6 y RB7 como entradas
//-- RB1, RB2, RB3 y RB4 como salidas
TRISB=0xE1;
//-- Los motores del Skybot parados
PORTB=0x00;
//-- Bucle principal
while(1) {
//-- Sensor lee blanco?
if ((PORTB & SENSOR)==0)
PORTB=AVANZA; //-- si, avanzar
else
PORTB=STOP; //-- no, parar
}
}