Já pensou em montar o seu próprio robô autônomo, mas acha algo muito complicado e caro? Este tutorial vai mostrar que essa tarefa não é nenhum bicho de sete cabeças. Desenvolvemos um projeto que simplifica ao máximo os conceitos de software e hardware, possibilitando que qualquer pessoa seja capaz de fazê-lo por um custo bastante reduzido.
Antes de começarmos, nós temos um projeto de Robô Controlado por App aqui no blog, caso tenha ficado curioso clique aqui para conhecer esse projeto que é quase um irmão deste tutorial!
Usaremos um kit de chassi básico para construir um robô capaz de se livrar de obstáculos. A eletrônica necessária será montada numa pequena protoboard, sem a necessidade de uma placa de circuito impresso. Para reduzirmos o tamanho do projeto, utilizaremos o Arduino Nano em conjunto com o sensor ultrassônico HC-SR04 e Módulo Driver Ponte H L298N para controle dos motores DC.
O grande barato é que utilizaremos um código reduzido e acessível para iniciantes no mundo da eletrônica embarcada. Além de pensarmos numa maneira de utilizar o mínimo possível de componentes. Sejam bem vindos e vamos começar a diversão.
Montagem do Projeto e Detalhamento de Hardware
Componentes Utilizados:
- Arduino Nano;
- 1x Regulador de Tensão 7805;
- 1x Diodo Retificador 1N4007;
- 1x Capacitor Eletrolítico 10uF;
- 1x Bateria 9V;
- 1x Adaptador de Bateria 9V;
- 1x Kit Chassi 2WD Robô para Arduino;
- 1x sensor Ultrassônico HC-SR04;
- Módulo Driver Ponte H L298N;
- 1x chave seletora;
- Protoboard 400 pontos;
- Jumpers Macho/Fêmea;
- Jumpers Macho/Macho;
- 4x Fio flexível (12cm);
Você pode ver todos os componentes utilizados neste tutorial na lista acima, ou você pode comprar tudo junto no Kit Start Robô Autônomo. Temos também um cupom que vale 10% de desconto na compra do Kit Start Robô Autônomo ou qualquer outro produto, para conseguir o desconto basta utilizar o seguinte cupom:
BEMVINDO
Agora sem mais delongas vamos iniciar a parte técnica do tutorial 🙂
A) Preparativos Iniciais:
Precisamos preparar alguns detalhes antes de iniciar o projeto. Os motores DC não vem com os fios soldados. Para isso, é necessário soldar fios flexíveis de aproximadamente 12cm conforme figura abaixo.
Outro detalhe que facilitará muito a nossa vida é complementar os fios do adaptador da bateria de 9V com jumpers. O objetivo é possibilitar que a bateria seja conectada facilmente na protoboard. A figura abaixo mostra o efeito desejado. Moleza né?
B) Montagem do Chassi:
Agora é hora de montar o chassi do seu robô. A foto abaixo mostra um chassi redondo 2WD apenas com a base montada (sem o segundo andar). Aconselhamos usar para este projeto o chassi mais simples e barato possível. Pois teremos poucos componentes e o espaço utilizado será muito reduzido.
C) Fonte de Energia:
Utilizaremos uma bateria de 9V comum. Porém, nada impede que você use qualquer outra forma de energia que alcance tal valor.
Agora que sabemos que utilizaremos 9V como fonte, temos um desafio. O Arduino Nano precisa de 5V para funcionar e não podemos ultrapassar esse valor para não danificá-lo. Para isso, apresentaremos o conceito de circuito regulador de tensão.
Um circuito regulador de tensão é capaz de reduzir e regular uma tensão de entrada para uma tensão de saída desejada. Utilizaremos o famoso CI 7805 que disponibilizará 5V em sua saída e servirá perfeitamente para alimentar o Arduino. A figura abaixo propõe um circuito muito simples que servirá perfeitamente para o nosso projeto.
Outro desafio é isolar o circuito de alimentação dos motores e o circuito que alimenta o Arduino. Não entraremos em detalhes sobre esse tópico, mas basicamente é necessário saber que motores são cargas indutivas e podem retornar ruídos que podem afetar o funcionamento do Arduino. Sem entrar no mérito, usaremos um diodo na saída da bateria que alimentará os motores para evitar que qualquer tipo de corrente reversa atinja o regulador de tensão de 5V.
Assim, teremos uma divisão da energia fornecida pela bateria, onde isolaremos 5V para o circuito lógico e aproximadamente 8,3V para os motores (8,3V é o resultado de 9V da bateria com uma queda de 0,7V do diodo).
A figura abaixo mostra a montagem da fonte com o acréscimo de um interruptor para ligarmos e desligarmos o robô. Notem que tudo fica na protoboard e facilita muito a montagem do robô.
D) Montagem do Arduino Nano:
Essa etapa é muito simples. Devemos colocar o Arduino na protoboard e conectar a saída regulada de 5V no pino Vin do Arduino e o GND da fonte ao GND do Arduino, como pode ser visto na imagem abaixo:
E) Montagem do Sensor Ultrassônico:
Não iremos entrar no detalhe do funcionamento do sensor ultrassônico, pois já temos um tutorial exclusivo para este sensor: Medindo distâncias com o sensor ultrassônico, mas basicamente trata-se de um sensor que possui um emissor e receptor de ondas ultrassônicas de 40KHz. O mesmo emite a onda e a partir do tempo de ida e volta do sinal o mesmo calcula a distância de um obstáculo.
Apenas para título de conhecimento, a equação que o código da biblioteca do sensor utilizará para cálculo da distância ao obstáculo é simples. A distância (d) é obtida a partir da velocidade do som (v = 340m/s) multiplicado pelo tempo (t) de recepção do sinal dividido por 2 por conta da onda ir até o obstáculo e voltar.
d = (v * t)/2
Os pinos do Sensor ultrassônico HC-SR04 são:
-
VCC: Alimentação do sensor (5V);
-
GND: GND do sensor;
-
Trigger: Gatilho para disparo dos pulsos ultrassônicos. O Trigger é controlado pelo Arduino;
-
Echo: Dispara um pulso cuja largura de tempo em alta representa o tempo para retorno da onda recebida pelo sensor. O Arduino utilizará este sinal para realizar o cálculo da distância.
Para o nosso projeto ligaremos devidamente o VCC e GND aos pinos do Arduino Nano e o Trigger e Echo do sensor aos pinos digitais D4 e D5 do Arduino Nano conforme figura abaixo:
F) Montagem do Módulo Driver Ponte H L298N
Utilizaremos o Modulo Ponte H L298N para controlar não somente o sentido de rotação dos motores DC, como também sua velocidade.
-
MOTOR A (OUT1 e OUT2) e MOTOR B (OUT3 e OUT4): São os conectores para ligarmos no Motor A e no Motor B;
-
ATIVA MA (ENA) e ATIVA MB (ENB): Para o nosso projeto, devemos retirar os jumpers destes pinos, pois iremos controlar a velocidade dos motores com o Arduino. Caso não fossemos alterar a velocidade, deveríamos manter os jumpers;
-
ATIVA 5V: Devemos manter este jumper, pois iremos utilizar alimentação de aproximadamente 8V e o mesmo ativa um regulador de tensão interno do módulo que garante os 5V de alimentação para o circuito;
-
6-35V e GND: Conectaremos a fonte dos motores nestes terminais, VCC e GND;
-
ENTRADA (IN1, IN2, IN3 e IN4): Pinos responsáveis pelo sentido de rotação do Motor A (IN1 e IN2) e Motor B (IN3 e IN4). Abaixo segue a tabela para entendermos a configuração necessária.
STATUS MOTOR |
IN1 (ou IN3) |
IN2 (ou IN4) |
Rotação Sentido Horário |
5V |
GND |
Rotação Sentido Anti-Horário |
GND |
5V |
Ponto Morto |
GND |
GND |
Freio |
5V |
5V |
Agora que entendemos, resumidamente, como funciona o Módulo L298N, vamos iniciar sua conexão. Primeiramente, devemos conectar os motores nos conectores OUT1/OUT2 e OUT3 e OUT4.
Próximo passo é ligar a alimentação de energia nos conectores 6-35V e GND, conforme figura abaixo:
Iremos conectar os pinos IN1, IN2, IN3 e IN4 do Módulo aos pinos D6, D7, D8 e D9 do Arduino respectivamente. Finalmente, conectaremos os pinos ENA e ENB do Módulo aos pinos PWM D10 e D11 do Arduino respectivamente. Pronto! Tudo conectado!
A montagem final do projeto pode ser vista na imagem abaixo:
Mergulhando no projeto
Software
1 – Lógica de Decisão de desvio do Obstáculo
O objetivo é fazer a menor quantidade possível de movimento para simplificar o código e economizar o máximo de bateria. Ao se deparar com um obstáculo a menos de 20cm de distância frontal ao robô, o mesmo irá parar e desviar aproximadamente 90 graus à esquerda e verificará se há novo obstáculo, caso tenha, irá virar novamente à esquerda e caso contrário deve seguir em frente.
2 – Desenvolvendo o Código
A primeira coisa a se fazer é configurar o seu Arduinno Nano no Windows, siga os passos deste tutorial. ATENÇÃO: caso você não faça a configuração do Arduino Nano como descrito no tutorial, o Windows não irá reconher a sua placa Nano e assim não será possível fazer o upload do código para o Arduino Nano.
O código final do projeto pode ser visto abaixo:
#include <Ultrasonic.h> #define TRIGGER_PIN 4 #define ECHO_PIN 5 Ultrasonic ultrasonic(TRIGGER_PIN, ECHO_PIN); #define IN1 6 #define IN2 7 #define IN3 8 #define IN4 9 #define ENA 10 #define ENB 11 void setup() { pinMode(IN1,OUTPUT); pinMode(IN2,OUTPUT); pinMode(IN3,OUTPUT); pinMode(IN4,OUTPUT); pinMode(ENA,OUTPUT); pinMode(ENB,OUTPUT); analogWrite(ENA,120); analogWrite(ENB,120); delay(1000); } //end setup void loop() { robo_frente(); float dist_cm = distancia(); if(dist_cm < 20) { decisao(); } delay(100); } float distancia() { float cmMsec; long microsec = ultrasonic.timing(); cmMsec = ultrasonic.convert(microsec, Ultrasonic::CM); return(cmMsec); delay(10); } void robo_frente() { digitalWrite(IN1,HIGH); digitalWrite(IN2,LOW); digitalWrite(IN3,HIGH); digitalWrite(IN4,LOW); } void robo_esquerda() { digitalWrite(IN1,HIGH); digitalWrite(IN2,LOW); digitalWrite(IN3,LOW); digitalWrite(IN4,HIGH); } void robo_parado() { digitalWrite(IN1,LOW); digitalWrite(IN2,LOW); digitalWrite(IN3,LOW); digitalWrite(IN4,LOW); } void decisao() { robo_parado(); delay(500); robo_esquerda(); delay(400); robo_parado(); delay(500); }
3 – Detalhes do Código
- Instalando a Biblioteca do Sensor Ultrassônico
-
Realize o download do arquivo “Ultrassonic.zip”
-
Abra a IDE do Arduino, clique em “Sketch” > “Incluir Biblioteca” > “Adicionar Biblioteca .ZIP” e selecione o arquivo “Ultrassonic.zip”.
-
Pronto, agora você já é capaz de visualizar os exemplos do código clicando em “Arquivo” > “Exemplos” > (Exemplos de Bibliotecas Personalizadas) “Ultrasonic-master” > “UltrasonicDemo”
- Detalhamento do Código
Primeiramente, precisamos carregar a biblioteca do sensor e definir os pinos que serão utilizados como Trigger e Echo:
#define IN1 6 //Pinos motor A (Direita) #define IN2 7 //Pinos motor A (Direita) #define IN3 8 //Pinos motor B (Esquerda) #define IN4 9 //Pinos motor B (Esquerda)
O próximo passo é definir os pinos 10 e 11 do Arduino para controle de velocidade dos motores. Novamente utilizaremos os mesmos nomes dos respectivos pinos do Módulo L298N (ENA para motor A e ENB para o motor B).
#define ENA 10 //Pino velocidade motor A (Enable A) #define ENB 11 //Pino velocidade motor B (Enable B)
A função de inicialização irá declarar os pinos IN1, IN2, IN3, IN4, ENA e ENB como pinos de saída.
void setup() { pinMode(IN1,OUTPUT); //Saída para motor A pinMode(IN2,OUTPUT); //Saída para motor A pinMode(IN3,OUTPUT); //Saída para motor B pinMode(IN4,OUTPUT); //Saída para motor B pinMode(ENA,OUTPUT); //Controle velocidade motor A pinMode(ENB,OUTPUT); //Controle velocidade motor B
Estamos utilizando um controle de pulsos PWM para controlar a velocidade dos motores. É como se ligássemos e desligássemos muito rapidamente (alta freqüência) os motores. A relação entre o tempo que ele fica ligado em relação ao tempo que fica desligado define a tensão que estamos entregando ao motor e conseqüentemente é definindo a velocidade do mesmo.
A resolução do PWM do Arduino é de 8bits, podendo assumir valores de 0 (velocidade zero) a 255 (velocidade máxima).
Nesse ponto do projeto deve-se empiricamente regular a velocidade dos motores de forma distinta para compensar as diferenças de fabricação que podem fazer com que possuam velocidades diferentes para a mesma tensão aplicada, garantindo que o robô andará em linha reta quando desejado:
analogWrite(ENA,110); //Controle PWM do motor A (0 a 255) analogWrite(ENB,110); //Controle PWM do motor A (0 a 255) delay(1000); //Aguarda 1s antes de iniciar } //end setup
No loop principal iremos inicialmente “chamar” a função responsável por fazer o robô andar para a frente:
void loop() //loop principal { robo_frente(); //Robô inicia andando para frente
Iremos declarar a variável “dist_cm” do tipo “float” que armazenará o valor retornado pela função que calcula a distância do robô ao obstáculo:
float dist_cm = distancia(); //Declara variável que armazena a distância do obstáculo
Com a função IF, iremos acionar a função decisao() caso o obstáculo esteja numa distância menor do que 20 cm. Sinta-se a vontade para alterar este parâmetro:
if(dist_cm < 20) //distância menor que 20cm? { decisao(); } //end if delay(100); } //end loop
Agora é hora de definir as funções auxiliares. São elas que foram utilizadas no loop principal. A função distancia() retornará o valor em cm da distância do robô ao obstáculo. Não se preocupe com o código, pois o mesmo é o padrão da biblioteca do sensor ultrassônico:
float distancia() //função que mede a distância em cm { float cmMsec; //declara a variável tipo float cmMsec //Associa à variável tipo long microsec o tempo em microsegundos long microsec = ultrasonic.timing(); //função da biblioteca para converter a distância em cm e associá-la a cmMsec cmMsec = ultrasonic.convert(microsec, Ultrasonic::CM); return(cmMsec); // retorna o valor em cm para a função delay(10); } //end função
Função auxiliar para andar para frente, definindo os valores das variáveis IN1, IN2, IN3 e IN4:
void robo_frente() //função para mover o robô para frente { digitalWrite(IN1,HIGH); digitalWrite(IN2,LOW); digitalWrite(IN3,HIGH); digitalWrite(IN4,LOW); } //end função
Função auxiliar para andar para esquerda, definindo os valores das variáveis IN1, IN2, IN3 e IN4:
void robo_esquerda() //função para mover o robô para esquerda { digitalWrite(IN1,HIGH); digitalWrite(IN2,LOW); digitalWrite(IN3,LOW); digitalWrite(IN4,HIGH); } //end função
Função auxiliar para parar o robô, definindo os valores das variáveis IN1, IN2, IN3 e IN4:
void robo_parado() //função para parar o robô { digitalWrite(IN1,LOW); digitalWrite(IN2,LOW); digitalWrite(IN3,LOW); digitalWrite(IN4,LOW); } //end função
A função auxiliar decisao() segue o fluxo que definimos para que o robô ultrapasse o obstáculo. No nosso projeto, para simplificar, ele sempre pára e vira para a esquerda e caso não tenha obstáculo, continua em frente:
void decisao() //função para decidir a ação do robô { robo_parado(); delay(500); robo_esquerda(); //esse tempo precisa ser avaliado para que o robô vire por volta de 90 graus delay(400); robo_parado(); delay(500); } //end função
Conclusão
O objetivo de simplificar o projeto foi mostrar que você é capaz de montar o seu próprio robô e certamente já deve estar pensando em melhorá-lo. Fique a vontade, que tal alterar o modelo de decisão do robô ao se deparar com um obstáculo?
Você perceberá que, para obter melhores resultados, o robô precisará de mais sensores. Por exemplo, apenas com o sensor ultrassônico você pode ter problemas com colisão em objetos com ângulo próximo a 45 graus do robô. Que tal incluirmos bumpers de colisão na parte frontal do robô. Bumpers de colisão são chaves (interruptores) que ao serem tocados podem ser usados para alterar a decisão de percurso do robô. Enfim, são inúmeras idéias possíveis e espero ter aberto esse mundo para a sua imaginação. Abraços e boa sorte neste desafio.
Referências
McRoberts, Michael Arduino básico / Michael McRoberts; [tradução Rafael Zanolli]. — São Paulo : Novatec Editora, 2011.
Datasheet: Sensor ultrassônico HC-SR04
Datasheet: Chip ST L298N
Escrevi a programação e fui compilar, mas está dando erro logo na primeira linha, vocês poderiam dar uma olhada ?? Pois tentei arrumar mas não consegui 🙁
Oi Jhonatan, a primeira linha é referente a biblioteca do sensor Ultrassônico. No tutorial tem o passo a passa para instalação da biblioteca (item 3.1). Você conferiu se a instalação da mesma foi realizada corretamente? Abs
Funcionou perfeitamente agora !! Muito obrigado.
Oi Jhonatan, legal, qualquer coisa ppde perguntar! Abraços
Olá, lembrando que para competições utilizar baterias 9v é horrível, o robô não aguenta muito tempo andando pois a amperagem é super baixa, aconselho a utilizar pilhas AA de lítio ou baterias do tipo LiPO para melhor resultados.
No mais muito boa sua postagem.
Oi Allef, exato. Porém o nosso objetivo é fazer um projeto básico e acessível a todos! E para os iniciantes terem contato com a tecnologia! Certamente, projetos mais elaborados exigem uma bateria melhor e mais cara. Abraços
Ola,sou aluno e minha sala esta fazendo este projeto em conjunto com nosso professor para nossa feira de ciências que é sobre robótica.Mas estamos enfrentando um problema,esse problema ocorre quando vamos conectar o Arduíno Nano no computador(Windows 10),quando conecta passa energia mas ele não é reconhecido pelo programa (Arduíno 1.8).Por Favor você poderia nos ajudar.Desde já agradeço.
Oi Carlos, desculpe-me a demora na resposta! Tente o seguinte procedimento: No menu “Ferramentas”, selecione: “Placa: Arduino Nano”, “Processador: ATmega328P (Old Bootloader)” e a “Porta” que aparecer o seu Arduino conectado.
Alex, muito bom o conteúdo, montei meu carrinho perfeito, só que o bichinho só anda em circulo, um motor anda mais que o outro, tem como corrigir isso?
Olá Rodrigo!
Tive um problema igual a este recentemente, e resolvi trocando a bateria, estava usando uma bateria chinessa e troquei por uma Duracell, e funcionou perfeitamente.
E alguns dias atrás, o projeto já tinha alguns meses que estava funcionando, o problema voltou, e troquei a Duracell por uma nova Duracell e o problema foi resolvido
novamente, quando a bateria está fraca, apenas um motor consegue ser energizado, e por isso o veículo anda em círculos.
Abraço.
Muito obrigada, consegui comprar o kit com desconto é chegou em menos de 1 semana. Muito feliz
Olá Geovana!
Que bom que conseguiu comprar com desconto e que recebeu rapidamente! Agradecemos pelo apoio!
Veja também o nosso tutorial sobre o veículo controlado por App, já tem o kit deste tutorial sendo vendido lá na
Arduino Omega(https://www.arduinomega.com.br/kit-start-robo-controlado-por-app), mas já que você já tem o kit do veículo
autônomo, você só precisaria comprar um módulo bluetooth (https://www.arduinomega.com.br/modulo-bluetooth-rs232-hc-06-padrao-slave)
para o montar o veículo controlado por App.
Abraço e continue acompanhando o nosso blog!
Não está chegando energia nos motores, oq eu faço?
Olá Geovana tudo bem? O primeiro passo é conferir se o circuito está sendo energizado, se a bateria está realmente alimentando o circuito. Depois confira as ligações na Ponte H, na parte de trás, onde é feita a conexão do terra (GND) e o VCC, confira se está chegando energia nesta parte do circuito, a ponte H tem um led indicador, verifique se ele está acesso.
Prezados,
estou iniciando agora em Arduino, não tenho noção nenhuma.
O que uso para proceder a compilação do programa e como envio do PC para o arduino?
Algum tutorial / video explicativo?
Olá Márcio tudo bem? Te recomendo o canal do Brincando com Ideias: https://www.youtube.com/watch?v=rCILKZPG0Kg
Lá você irá ter uma boa noção sobre este tipo de dúvida, que é difícil de explicar via texto, em vídeo é bem mais simples, por isso indico a você o canal do Brincando com Ideias.
Não entendi onde realmente se encaixa o diodo retificador. Ficou um pouco confuso no esquema.
O interruptor tem 3 pinos que vão em E3, E4, e E5. No Esquema parece que uma das pernas do diodo entra em E4. É isso? Se sim, o pino do meio do interruptor não pode entrar em E4, certo?
Olá Ricardo tudo bem? Sim o interruptor tem 3 pinos, e o diodo é conectado em série no pino do meio, é como se você fosse conectar um jumper no pino do meio, então você deve fazer a ligação do diodo no primeiro ponto(buraco) da protoboard após o pino do meio, veja na imagem real do projeto:
Espero ter esclarecido a sua dúvida. Abraço.
Ola
copiei o programa e na hora de compilar esta dando erro.
long microsec = ultrasonic.timing();nessa linha.Com a menssagem
nenhuma função correspondente para chamada para ´ultrasonic::timing(int)`
delay(10);
Olá Marcelo tudo bem? Você seguiu os passos descritos na sessão 3 intitulada “Detalhes do código”?
Veja neste print abaixo:
É só adicionar a biblioteca como descrito nessa parte, que o seu código vai funcionar!
Abraço!
Olá Renan Resende. Fiz conforme sua orientação ao Marcelo. Baixei o arquivo da bilblioteca “Ultrassonic.zip” e instalei-o conforme orientado. Ocorre que o erro persiste. Também não encontro em “Arquivo-Exemplos”, a biblioteca “ultrasonic-master” ou “ultrasonic-demo”.
A mensagem de erro e:
“exit status 1
‘unsigned int Ultrasonic::timing()’ is private within this context”
O que pode estar dando errado? Por favor.
Olá Domingos, se você não encontrou os exemplos da biblioteca ultrasonic quer dizer que não conseguiu incluir a biblioteca, veja um exemplo em vídeo do processo de inclusão de bibliotecas: https://www.youtube.com/watch?v=6_I_F3y0doE
Espero ter ajudado. Abraço.
Olá Renan e Alex.
Obrigado pela postagem e pelas ajudas.
Estou com a mesma dificuldade do Domingos.
Segui o passo 3.1 da postagem.
Vi todo o vídeo recomendado pelo Renan e já tinha feito exatamente o que ele recomenda. Inclusive o nome da biblioteca aparece em laranja…
Vejam se conseguem me ajudar com esse erro:
Obrigado.
Continua dando o seguinte erro:
C:\Users\User\Documents\Arduino\robo_autonomo_s67\robo_autonomo_s67.ino: In function ‘float distancia()’:
robo_autonomo_s67:36:37: error: ‘unsigned int Ultrasonic::timing()’ is private within this context
long microsec = ultrasonic.timing();
^
In file included from C:\Users\User\Documents\Arduino\robo_autonomo_s67\robo_autonomo_s67.ino:1:0:
C:\Users\User\Documents\Arduino\libraries\Ultrasonic-3.0.0\src/Ultrasonic.h:43:18: note: declared private here
unsigned int timing();
^~~~~~
robo_autonomo_s67:37:23: error: ‘class Ultrasonic’ has no member named ‘convert’
cmMsec = ultrasonic.convert(microsec, Ultrasonic::CM);
^~~~~~~
In file included from C:\Users\User\Documents\Arduino\robo_autonomo_s67\robo_autonomo_s67.ino:1:0:
C:\Users\User\Documents\Arduino\libraries\Ultrasonic-3.0.0\src/Ultrasonic.h:26:12: error: expected unqualified-id before numeric constant
#define CM 28
^
C:\Users\User\Documents\Arduino\robo_autonomo_s67\robo_autonomo_s67.ino:37:53: note: in expansion of macro ‘CM’
cmMsec = ultrasonic.convert(microsec, Ultrasonic::CM);
^~
exit status 1
‘unsigned int Ultrasonic::timing()’ is private within this context
Olá Rodolfo confira se a primeira linha do seu código é: #include;
Parece que está faltando o include da biblioteca.
Abraço.
Também tive esse problema e identifiquei que a biblioteca ultrasonic.h do link do artigo (https://downloads.arduino.cc/libraries/github.com/ErickSimoes/Ultrasonic-3.0.0.zip) não tem a variável timing como pública, o que está causando o problema.
Consegui resolver baixando a biblioteca ultrasonic disponível no link https://github.com/filipeflop/Ultrasonic/archive/refs/heads/master.zip
Passei horas revisando o projeto e está tudo ok, mas o robô não sai do lugar. Poderiam disponibilizar como fica o código final com a o código do sensor adicionado? A base do veículo de acrílico veio bem diferente da mostrada na foto, maior, inclusive eu até consegui montar o veículo com os motores invertidos. A foto real do veículo com a ligação dos motores no Módulo ponte H possui uma ligação que está invertida da proposta no esquema, foi proposital? Funcionou?
Já montei outras coisas com o Arduino, mas realmente este está mais complicado.
Olá Roberto tudo bem?
O código exibido no tutorial está completo, o sensor é acionado na função “float distancia”, e esta função é chamada em void loop, se você acessar o nosso Github nete link: https://github.com/omegacomponenteseletronicos/arduino-robo-autonomo/blob/master/robo_autonomo.ino verá que a função distancia é chamada na linha 29 do código.
A base do veículo no tutorial é menor, nós estamos enviando uma base maior atualmente, atendendo a pedidos dos clientes, mas isso não muda em nada o código ou a montagem do esquema elétrico.
A ligação da Ponhe H nos motores segue a tabela mostrada no tutorial, onde é explicado com quais ligações o motor gira para o lado horário ou anti-horário, resumidamente, você deve ligar o terra (fio preto) do motor 1 em out1, e o vcc em out2, e para o motor 2 o terra é ligado em out3 e o vcc em out4, a imagem ilustrativa da Ponte H nem sempre corresponde as posições corretas dos pinos out1, out2, out3 e out4, por isso você fico com a impressão que está invertido, pois na sua Ponte H, out1 pode ser o pino de cima e out2 o pino de baixo, por exemplo.
Conferira também se a sua bateria de 9v está com uma boa carga, essas baterias chinesas são decepcionante, a maioria dos problemas que os leitores tem ao montar o projeto é com a bateria de 9v, confira também se a Ponte H está recebendo energia, ela tem um led indicador, se este led não estiver ascendo, isto indica que a ponte H não está recebendo energia.
Espero ter te ajudado Roberto! Abraço!
Olá Renan, tudo bem?
Você conseguiu me ajudar sim, o código estava bem assim mesmo. O motivo do não funcionamento pode ser realmente a Bateria que troquei, bem como a adaptação do Arduino na Protoboard, percebi que os contatos não estavam precisos e bem conectados, mas com a ajuda dos jumpers eu consegui finalmente ligar tudo e fazer funcionar. Dessa forma, consegui ajustar a direção das conexões no módulo para fazer o robô funcionar de forma correta. Assim, tudo bem por aqui e muitíssimo obrigado!
Que bom que deu tudo certo Roberto!
Depois tira uma foto da sua montagem e marca a gente lá no Instagram: @arduinoomega ou https://www.instagram.com/arduinoomega, e indica o tutorial para os amigos também 🙂
Abraço!
Olá, estou tendo o seguinte erro:
“error: ‘unsigned int Ultrasonic::timing()’ is private within this context”
A função timing(` é privada, eu não posso chamá-la a partir de main.cpp. No entanto, a ultrasonic.read() é acessível, mas não estou obtendo o resultado esperado.
OBS: Sim, a biblioteca está adicionada.
Olá Rubem, como você disse que adicionou a biblioteca, confira se o seu código tem o include na primeira linha, deste jeito: #include;
Abraço.
Olá Renan,
Fiz o download da biblioteca indicada no link e no arquivo Ultrasonic.h conseguimos ver claramente que “timing” é uma funcao privada conforme trecho abaixo. Além disso, a funcao convert não está declarada. Será que a biblioteca foi atualizada? Você tem o link para a versao compativel com seu código?
Trecho do arquivo
class Ultrasonic {
public:
Ultrasonic(uint8_t sigPin) : Ultrasonic(sigPin, sigPin) {};
Ultrasonic(uint8_t trigPin, uint8_t echoPin, unsigned long timeOut = 20000UL);
unsigned int read(uint8_t und = CM);
unsigned int distanceRead(uint8_t und = CM) __attribute__ ((deprecated (“This method is deprecated, use read() instead.”)));
void setTimeout(unsigned long timeOut) {timeout = timeOut;}
void setMaxDistance(unsigned long dist) {timeout = dist*CM*2;}
private:
uint8_t trig;
uint8_t echo;
boolean threePins = false;
unsigned long previousMicros;
unsigned long timeout;
unsigned int timing();
};
Fim do Trecho do arquivo
Referencia: https://github.com/ErickSimoes/Ultrasonic/blob/master/src/Ultrasonic.h
Olá, você pode fazer o download da versão compatível neste link: https://blog.arduinoomega.com/bibliotecas/Ultrasonic-master.zip
Abraço!
Olá, estou tendo dificuldades em copilar o programa também, você consegue me ajudar?
Nessa linha de programação long microsec = ultrasonic.timing(); e o esso é o seguinte, exit status 1
‘unsigned int Ultrasonic::timing()’ is private within this context
Já instalei a biblioteca e fiz o passo a passo incluindo o ultrasonic demo e o include no início também e mesmo assim não copila.
Att,
Vanin, Santos
Olá, use a biblioteca deste link: https://blog.arduinoomega.com/bibliotecas/Ultrasonic-master.zip
Qualquer dúvida estamos a dispoisição!
COMPREI ESSE ROBO DE VCS MESMO DEPOIS DE INSTALAR A BIBLIOTECA AINDA ESTA DANDO ERRO NO COGIGO bem em
long microsec = ultrasonic.timing();
cmMsec = ultrasonic.convert(microsec, Ultrasonic::CM);
qual seria a causa
ja tentei nas vers 1.8.9 ,1.8.12 e a 2.0.3
Olá, use a biblioteca deste link: https://blog.arduinoomega.com/bibliotecas/Ultrasonic-master.zip
Qualquer dúvida estamos a disposição!
Pode-me dize qual é o Arduíno(versão) que usou e onde eu vou para instalar?
Obrigado e desculpe o incomodo.
Olá, foi usado o Arduino Nano, você pode ver instruções de instalação neste link: https://blog.arduinoomega.com/bibliotecas/Arduino_Nano_CH340.pdf