Mudanças entre as edições de "Garoando em linha"

De Garoa Hacker Clube
Ir para navegação Ir para pesquisar
Linha 301: Linha 301:
 
<code>
 
<code>
 
// Fonte: learn.adafruit.com/adafruit-motor-shield/using-dc-motors
 
// Fonte: learn.adafruit.com/adafruit-motor-shield/using-dc-motors
  +
 
 
#include <AFMotor.h>
 
#include <AFMotor.h>
 
 

Edição das 20h48min de 23 de agosto de 2013

Kit sendo desenvolvido para o Nós Robôs constituido de todos componentes necessários para um seguidor de linha básico, com um tutorial passo-a-passo.

A proposta é ser o mais didático possível e preparado para quem tem pouco ou nenhum conhecimento em Arduino, eletrônica ou robótica. Nesta página haverá conteúdo um pouco menos amigável, porém ideal para se estudar após compreender tudo contido no Passo-a-Passo.

Responsáveis

Haoji

Visão Geral

Kit garoando.jpg Chassi.JPG

Dimensões

Medidaspneu garoando.png Medidaschassi garoando.jpg

Hardware

Componentes do Kit

"*" Não incluso dentro do kit pois há vários disponíveis no Garoa

Montagem do Chassi

Montagem garoando.jpg

Há incluso no kit um pequeno manual de montagem que apresenta todos componentes básicos e um passo-a-passo de como montá-lo.

O mesmo pode ser acessado em formato PDF abaixo:

Clique aqui para baixar

Futuramente será incluído um manual mais amigável e didático, por enquanto está disponível apenas o fornecido pelo fabricante do chassi.

Motores

Motores garoando.jpg

Voltagem DC 3V DC 5V DC 6V
Corrente 100mA 100mA 120mA
Taxa de Redução 48:1
RPM (Com pneu) 100 190 240
Diametro do Pneu 66mm
Velocidade (m/minuto) 20 39 48
Peso do Motor 50g
Tamanho do Motor 70mm*22mm*18mm
Ruído <65dB

Sensor de Ultrasom HC-SR04

Hc-sr04-ultrasonic-sensor-500x500.jpg

Pinagem VCC Trig (Disparo) Echo (Recepção) GND
Voltagem DC 5V
Corrente (em repouso) < 2 mA
Saída Alto 5V / Baixo 0V
Ângulo < 15º
Distância 2 a 450 cm
Resolução 0,3 cm

Montagem do Arduino e Shield

Montagem dos Sensores

Software

Arduino IDE

Bibliotecas

Como instalar

Sensor de Ultrasom HC-SR04

Esta biblioteca torna obter leituras com o HC-SR04 muito mais fácil com código amigável.

HC-SR04medindo garoando.jpg

Foto de J.Rodrigo do Ardublog.

Onde baixar

A biblioteca está disponível no GitHub: https://github.com/haoji/Ultrasonic-HC-SR04

Clique aqui para baixar

Copie a pasta "Ultrasonic" para a pasta "libraries". Veja como Instalar se tiver dúvidas.

Alterando TimeOut Padrão

Por padrão a biblioteca limita o alcance do sensor a ~51cm utilizando um timeout de 3ms. O timeout limita o tempo de execução da função pulsein() para obter resultados mais precisos. A fórmula para se obter o timeout é a seguinte: centímetros * 58 = timeout

Substitua:

Ultrasonic ultrasonic(9,8); // (Trig PIN,Echo PIN)

Por:

Ultrasonic ultrasonic(9,8,3000); // (Trig PIN,Echo PIN, Timeout máximo em µs )

E modifique 3000 pelo valor em µs adequado obtido pela fórmula acima

Exemplo: Plug & Play

Inserir o sensor nos pinos digitais 7, 6, 5, 4 virado para o lado oposto ao Arduino.

Veja: https://github.com/elrodri/Ultrasonic-HC-SR04/wiki/Plug-&-Play

// Ultrasonic - Library for HR-SC04 Ultrasonic Ranging Module.
// Rev.4 (06/2012)
// J.Rodrigo ( www.jra.so )
// more info at www.ardublog.com

#include <Ultrasonic.h>

Ultrasonic ultrasonic(5,6); // (Trig PIN,Echo PIN)

void setup() {
  Serial.begin(9600);
  pinMode(4, OUTPUT); // VCC pin
  pinMode(7, OUTPUT); // GND ping
  digitalWrite(4, HIGH); // VCC +5V mode  
  digitalWrite(7, LOW);  // GND mode
}

void loop()
{
  Serial.print(ultrasonic.Ranging(CM)); // CM (centímetros) ou INC (inches - polegadas)
  Serial.println(" cm" );
  delay(100);
}

Exemplo: Exibir distância no console serial

// Ultrasonic - Library for HR-SC04 Ultrasonic Ranging Module.
// Rev.4 (06/2012)
// J.Rodrigo ( www.jra.so )
// more info at www.ardublog.com

#include <Ultrasonic.h>

Ultrasonic ultrasonic(9,8); // (Trig PIN,Echo PIN)

void setup() {
 Serial.begin(9600);
}

void loop()
{
 Serial.print(ultrasonic.Ranging(CM)); // CM (centímetros) ou INC (inches - polegadas)
 Serial.println(" cm" );
 delay(100);
}

Exemplo: Exibir distância em um display LCD

// Ultrasonic - Library for HR-SC04 Ultrasonic Ranging Module.
// Rev.4 (06/2012)
// J.Rodrigo ( www.jra.so )
// more info at www.ardublog.com

#include <Ultrasonic.h>
#include <LiquidCrystal.h>

LiquidCrystal lcd(12, 11, 5, 4, 3, 2); // LCD arduino library

Ultrasonic ultrasonic(9,8); // (Trig PIN,Echo PIN)

void setup() {
lcd.begin(16, 2);
}

void loop()
{
  lcd.clear();
  lcd.setCursor(0, 0);
  lcd.print(ultrasonic.Ranging(CM)); // CM (centímetros) ou INC (inches - polegadas)
  lcd.print("cm");
  delay(100);
}

Exemplo: Obter tempo em ms do disparo à recepção

// Ultrasonic - Library for HR-SC04 Ultrasonic Ranging Module.
// Rev.4 (06/2012)
// J.Rodrigo ( www.jra.so )
// more info at www.ardublog.com

#include <Ultrasonic.h>

Ultrasonic ultrasonic(9,8); // (Trig PIN,Echo PIN)

void setup() {
  Serial.begin(9600); 
}

void loop()
{
  Serial.print(ultrasonic.Timing());
  Serial.println(" ms" ); // milisegundos
  delay(100);
}

Exemplo: Utilizar mais de um sensor em conjunto

// Ultrasonic - Library for HR-SC04 Ultrasonic Ranging Module.
// Rev.4 (06/2012)
// J.Rodrigo ( www.jra.so )
// more info at www.ardublog.com

#include <Ultrasonic.h>

Ultrasonic ultraleft(9,8);   // (Trig PIN,Echo PIN)
Ultrasonic ultraright(6,7);  // (Trig PIN,Echo PIN)

void setup() {
  Serial.begin(9600); 
}

void loop()
{
  Serial.print("Left: ");
  Serial.print(ultraleft.Ranging(CM)); // CM (centímetros) ou INC (inches - polegadas)
  Serial.print(" cm     " );
  delay(50);
  Serial.print("Right: ");
  Serial.print(ultraright.Ranging(CM)); // CM (centímetros) ou INC (inches - polegadas)
  Serial.println(" cm" );
  delay(50);
}

Motor Drive Shield L293D

Onde baixar

A biblioteca está disponível no GitHub: https://github.com/haoji/Adafruit-Motor-Shield-library

Clique aqui para baixar

Renomeie a pasta baixada para "AFMotor" e a mova para a pasta "libraries". Veja como Instalar se tiver dúvidas.

Exemplo: Controlando um motor DC

// Fonte: learn.adafruit.com/adafruit-motor-shield/using-dc-motors

#include <AFMotor.h>
 
AF_DCMotor motor(2, MOTOR12_64KHZ); // cria motor #2, 64KHz pwm
 
void setup() {
  Serial.begin(9600);           
  Serial.println("Testando motor!");
  
  motor.setSpeed(200);     // define a velocidade para 200/255
}
 
void loop() {
  Serial.print("tick");
  
  motor.run(FORWARD);      // girar para a frente
  delay(1000);
 
  Serial.print("tock");
  motor.run(BACKWARD);     // girar para trás
  delay(1000);
  
  Serial.print("tack");
  motor.run(RELEASE);      // parado
  delay(1000);
}

Sketch

Passo-a-Passo

Referências