Line Following Robot -- multiple errors

Hello,

I have spent hours researching and trying to fix this but my knowledge with code just isn't quite there yet. The first file "LastHope..." is the working code for a basic line follower that i modified to include my motor shield library. I have tested this code and it works as it should. Once i tried to implement 2*16 LCD,button, and a buzzer that is where i ran into issues. I Followed a guide on instuctables (I can provide a link upon request not sure on rules) unfortunately the code (second file "Linus_Line...") provided with this build has multiple errors such as:

Linus_Line_Follower:13: error: 'BUTTON_PULLUP_INTERNAL' was not declared in this scope

 Button button = Button(2,BUTTON_PULLUP_INTERNAL); // pin 2 - button

                          ^

C:\\Arduino\Linus Line Follower\Linus_Line_Follower\Linus_Line_Follower.ino: In function 'void setup()':

Linus_Line_Follower:76: error: 'class Button' has no member named 'isPressed'

   while(!button.isPressed()){    

                 ^

C:\\Arduino\Linus Line Follower\Linus_Line_Follower\Linus_Line_Follower.ino: In function 'void loop()':

Linus_Line_Follower:123: error: 'class Button' has no member named 'isPressed'

   while(!button.isPressed()){

                 ^

I did manage to add this code to mine and eliminate the errors but the robot ended up being unresponsive. If anyone here could help out i would appreciate it very much.
As far as i can tell i have two options :

  1. incorporate code for calibration and music ie: button,lcd,buzzer into the working code
  2. eliminate errors for LINUS code and modify to work with my motor shield

If there are any formatting issues bare with me, and if i can provide anymore info just ask i will provide all that is needed.
Thanks in advance for any help

LastHope_Line_following_Robot.ino (2.42 KB)

Linus_Line_Follower.ino (10.1 KB)

you need to provide the libraries that you have. namely, the button and the qsr or something library

Do you need the files or the link to location or will this be enough?

#include <QTRSensors.h>
#include <AFMotor.h>
#include <LiquidCrystal.h>
#include <Button.h>

And the code from the guide is also using the #include <Wire.h> library but i believe that one isn't needed. But what do I know that is why I'm here.

#include <QTRSensors.h>
#include <Button.h>

Provide these 2 because they are not standard in the arduino library and I do not know what version you have. It would be better if you could just upload the files/libraries, however, if that is too complicated simply link us to the SAME download pages that you got the libraries from.

Let me know if that works, meanwhile ill try to find the website where i got them just in-case. i also included the motor shield one just in-case from what i read it is not a standard one.

Libraries.zip (32.2 KB)

Ps991:
simply link us to the SAME download pages that you got the libraries from.

+1, more often than not, you can view the source code at the library site. Also, if you post the library code it may lack documentation and explanations that are on the library site. Many libraries consist of multiple files, not practical to post.

guide for the bot where i believe i got all the libraries.

this is the sensor im using but like i said i believe i got the library from the first link

motor shield library

button library
http://playground.arduino.cc/Code/Button

if im missing anything let me know

for starters, notice how in Button.h there is no BUTTON_PULLUP_INTERNAL

This is what is defined...

#define PULLUP HIGH
#define PULLDOWN LOW

Although, isPressed() is a method of the Button class, so not sure why you are getting that error...I tried the library's example and it worked for me...

I see i double checked the library that was on github (the guide im following for the robot)
and that library has this

#define BUTTON_PULLUP HIGH
#define BUTTON_PULLUP_INTERNAL 2
#define BUTTON_PULLDOWN LOW

would it help to switch to that library or do i need to change code?

If you want to make it an input pullup, set a pin to an input, then simply type this

digitalWrite(pin, HIGH);

This will make the pin have internal pullup resistors on.

You should be fine using whichever library...

Ok, i thought i got it. I set button to pin 2 and pin 2 to input.

int pinButton = 2; // Button pin

void setup(){
  lcd.begin(16, 2);
  Serial.begin(9600);        // Initialize the serial communication
  pinMode(pinAudio, OUTPUT); // Define the Audio pin as an output

But there seems to be more errors now, i must not be understanding this code as much as i thought i did.

New Error:

C:\Arduino\Linus Line Follower\Linus_Line_Follower\Linus_Line_Follower.ino: In function 'void setup()':

Linus_Line_Follower:78: error: could not convert 'digitalWrite(2u, 1u)' from 'void' to 'bool'

   while(digitalWrite(2, HIGH);){    

                             ^

Linus_Line_Follower:78: error: expected ')' before ';' token

   while(digitalWrite(2, HIGH);){    

                              ^

Linus_Line_Follower:78: error: expected primary-expression before ')' token

   while(digitalWrite(2, HIGH);){    

                               ^

Linus_Line_Follower:78: error: expected ';' before ')' token

Linus_Line_Follower:99: error: 'qtr' was not declared in this scope

     qtr.calibrate();

     ^

C:\Users\Eddie\Documents\Arduino\Linus Line Follower\Linus_Line_Follower\Linus_Line_Follower.ino: In function 'void loop()':

Linus_Line_Follower:125: error: could not convert 'digitalWrite(2u, 1u)' from 'void' to 'bool'

   while(digitalWrite(2, HIGH);){

                             ^

Linus_Line_Follower:125: error: expected ')' before ';' token

   while(digitalWrite(2, HIGH);){

                              ^

Linus_Line_Follower:125: error: expected primary-expression before ')' token

   while(digitalWrite(2, HIGH);){

                               ^

Linus_Line_Follower:125: error: expected ';' before ')' token

Linus_Line_Follower:138: error: 'qtr' was not declared in this scope

     unsigned int position = qtr.readLine(sensors);

                             ^

And i still have no idea how to get this code to work with my shield like i did with the working code.

Thanks for all your help by the way it is much appreciated sorry i don't understand the code as well as i should.

while(digitalWrite(2, HIGH);){

This is wrong in 2 ways, the first is that you have a semicolon stuck in there when it shouldn't be, and the second is that digitalWrite() is a void returned function meaning that it does not return anything. So basically you are checking if nothing doesn't equal 0, which doesn't make sense. That's why you get these errors

error: expected ')' before ';' token
error: could not convert 'digitalWrite(2u, 1u)' from 'void' to 'bool'

So the real question is when you write this

while(digitalWrite(2, HIGH);){

what is it that you want to check?

That kind of makes sense but i don't know how to fix it. To answer your question I believe it is just a confirmation for multiple things throughout the calibration process. As i said before I'm just following this guide, and figured the code would be working before i started.

Guide: http://www.instructables.com/id/LINUSBot-Line-Follower-Robot/?ALLSTEPS

I guess ill mess around with it a little tomorrow and see what i can get from it.

Once i get the button working will it be easy to implement my library for my shield? if not all this will be for nothing.

You should be able to get it to work, however, we need updated code to give feedback. A good way to get things to work is to separate individual components and get them to work by themselves first. Then add that code to your existing code, you may hit some errors or bugs, and thats when you come back and post your questions. And as always, be detailed in your questions and statements, don't assume we know everything. :stuck_out_tongue:

Ps991:
If you want to make it an input pullup, set a pin to an input, then simply type this

digitalWrite(pin, HIGH);

This will make the pin have internal pullup resistors on.

Since Arduino 1.0.1 which predates your joining the forum by some years, the easier way of enabling pullups is with one line:

pinMode(myPin, INPUT_PULLUP);

See man page.

I know that, however, the pin is being initialized inside one of the libraries during an object creation.
When I said "set a pin to an input" I meant via the object creation, then type that to make it a pullup. But yes, you could also create the object, then use pinMode again.

"which predates your joining the forum by some years" <-- Was that a snarky way of saying "you should know better"?

Ps991:
"which predates your joining the forum by some years" <-- Was that a snarky way of saying "you should know better"?

Probably :slight_smile: Sorry....

(Note to self.... quite a few of my responses are taking a snarky tone lately. Must stop that.)

lol I was like that before too, had to tell myself to calm down. :stuck_out_tongue: