Skip to main content

40. Light Tracker using Arduino

Hello everyone!
Today I will be teaching you about making a light tracker using Arduino. This idea was inspired by the Arduino Solar tracker. You would all know the fact that Sunflowers 'follow' the Sun. Similar to the Sunflower, my light tracker will follow the light.

Supplies

  • Arduino Uno/ Nano
  • USB Type A/ B cable (for Arduino Uno) or USB Type A to mini B cable (for Arduino Nano)
  • Solderless Breadboard - Mini
  • Servo Motor SG-90
  • LDR (x2)
  • Resistor (x2) - 10kΩ
  • Male-to-Male Jumper wire (x9) - 10cm
  • 2 pin Female-to-Female Jumper wire (x2) - 70cm
  • 3D printed/ Cardboard barrier (Please refer to the 'Setup' section)

Setup


Your setup must look somewhat similar to the one in the image above.

Connections

Servo Motor (SG-90)

  • S (Yellow/ Orange wire) - D9
  • (+) (Red wire)  - 5V
  • ( - ) (Black/ Brown wire) - Ground (GND)

LDR

  • First - A0
  • Second - A1
Connect one end of the LDR to 5V and the other to 10kΩ resistor. The other end of the resistor must be connected to ground. Connection to the port must be where the resistor and LDR are connected.

Coding

For this project, you will need to include the 'Servo' library by Michael Margolis in your sketch. If you are new to this library, and need reference to the functions, please feel free to follow the hyperlink in this section.
Create Servo object to control a servo and a variable named 'pos' to store the servo position. The initial position of the servo motor must be 90°, so assign the 'pos' variable to 90. Create global variables for your LDRs, and a variable named 'limit'. Assign the 'limit' variable to 2.
Within void setup( ), use the pinMode( ) function to configure the LDR pins as INPUT. Use attach( ) function to attach the Servo variable to a pin, and use write( ) function to set the position of the servo at 90°. Set a delay of one second before moving on to void loop( ).
Within void loop( ), create local variables to store the digital values of the two LDRs. You must use analogRead( ) in this case. Calculate the absolute difference between the two values by using the abs() function. If the absolute difference between the two values exceeds the 'limit' (2), the servo position must change. If the value of the first LDR is greater than that of the second, the value stored in the 'pos' variable must reduce. If the value of the second LDR is greater than that of the first, the value stored in the 'pos' variable must increase. 
If the value stored in the 'pos' variable exceeds 180, it must be reset to 180. Repeat the same if the value stored in 'pos' decreases below 0. Finally use write( ) function, to set the position of the servo to the value, now stored, in 'pos' variable. Set a delay of 50 microseconds.
If anyone has doubts with the coding, please don't hesitate to ask them in the comments below or send me an email at arduinoprojectsbyr@gmail.com.

Final Look

If anyone has questions, or suggestions, about this project, please feel free to comment below or send me an email at arduinoprojectsbyr@gmail.com.

Comments

Popular posts from this blog

51. Buzz wire game using Arduino

Hello everyone! This is my first Arduino project in 2020 and it is going to be a fun and simple project. You would have heard of the Buzz Wire, a steady hand game, and today you will be learning to make one using Arduino. Hardware components used in this project Arduino Nano USB Type A to mini B cable (for Arduino Nano) Solderless Breadboard - Mini and Full-size LEDs (x2) - Green and Red Resistors (x2) - 220 Ω  Active Buzzer module (KY-012) LCD display module with I2C interface - 16x2 Male-to-Male Jumper wires (x4) - 10cm Female-to-Male Jumper wires (x5) - 20 cm Jumpers (x5) - to reduce the usage of wires Copper wire  Tape (or any form of insulation)  Setup Your hardware setup must look somewhat similar to the ones in the images above. The beginning and end of the copper wire maze must be taped to prevent conductivity between the wire loop and maze. Connections LCD display module with I2C interface GND - Ground VCC - 5V SDA -...

71. Buzz Wire Game ( Version 2.0 ) using Arduino

Hey Everyone! I hope that everyone's safe during this pandemic. Today I am going to explain you about the second version of my Buzz wire game. People who are bored of staying indoors can find this game pretty interesting and fun to play.  If you are a beginner, you can start off with my first version of this project :  51. Buzz wire game using Arduino   Hardware components used in this project Arduino Uno Solderless Breadboard (x2) - Full/ Full+ LCD display module with I2C module - 16x2 Potentiometer - B20K Push-buttons (x3) Resistor - 220 Ω Active Buzzer module (KY-012) LED - Red Copper Wire - 19/ 20 gauge thick Male-to-Male Jumper wires - 10cm and 20cm Wire - Long enough to connect the loop of copper wire to ground Other tools required for this project Cutting pliers - To cut the right amount of copper wire Round-nose pliers - To bend the copper wire and make a maze and loop Hardware setup Connections Wire Maze - D2 Wire loop - Ground (GND) B20K Potentiometer S - A0 (+)...

86. RFID Health tag (Arduino and Python)

 Hey everyone, Sorry I have not uploaded in a while. Today, I will be sharing an interesting project with all of you. This RFID Health tag project is useful when it comes to keeping track of vaccinated individuals, their biodata and their health conditions and medications. For this project, you will be needing Arduino and Python. Read on further to see how I did this project. Hardware components used in this project Arduino Uno Solderless Breadboard - Half+ MRFC522 RFID reader RFID key tags (x5) Push-buttons (x2) Male-to-Male Jumper wires (x12) USB Type A/ B cable (for Arduino Uno) Software required Arduino IDE - latest version recommended Python 3.8 Schematic MFRC522 RFID reader SDA/ SS - D10 SCK - D13 MOSI - D11 MISO - D12 IRQ - Not connected GND - Ground RST/ RESET - D9 3.3V - 3.3V Push-buttons Submit button - D4 Retrieve button - D5 Coding Arduino For this project, you will be using the following libraries: MFRC522 by miguelbalboa -  https://github.com/miguelbalboa/rfid SP...