Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ostad-ai/arduino-tutorial
Here, We work with the Arduino boards
https://github.com/ostad-ai/arduino-tutorial
arduino code keypad lcd led servo-motor slide-potentiometer slide-switch tutorial ultrasonic-range-finder
Last synced: about 2 months ago
JSON representation
Here, We work with the Arduino boards
- Host: GitHub
- URL: https://github.com/ostad-ai/arduino-tutorial
- Owner: ostad-ai
- License: mit
- Created: 2023-09-07T14:20:35.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2023-10-07T17:59:22.000Z (over 1 year ago)
- Last Synced: 2023-10-07T18:37:38.250Z (over 1 year ago)
- Topics: arduino, code, keypad, lcd, led, servo-motor, slide-potentiometer, slide-switch, tutorial, ultrasonic-range-finder
- Homepage:
- Size: 624 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Arduino Tutorial
1. **LED Blinking:** We use an LED (Light Emitting Diode), which is connected to the Arduino via a resistor. The resistor limits the current that flows through the LED to prevent it from burning by too much current.
- The **pinMode()** defines the pin of Arduino that is connected to the LED as **OUTPUT**, **INPUT**, or **INPUT_PULLUP**.
- Function **delay()** pauses the program for the amount of time in milliseconds.
- Function **digitalWrite()** sets the value of the given digital pin as HIGH or LOW.
LED Blinking: click to see the live demo., and get the code
2. **Slide switch to turn ON and OFF an LED:** We use a slide switch to turn an LED ON and OFF. As before, the LED is connected to the Arduino via a resistor.
- We define the pin of Arduino that is connencted to the common contact of the switch, as **INPUT_PULLUP**, which means that this pin is an input, and it is HIGH by default, if it is not connected to the GROUND.
Slide switch to toggle LED: click to see the live demo., and get the code
3. **Controlling the brightness of an LED with slide potentiometer:** A slide potentiometer is connected to an analog pin from which the value is taken to change the brightness of an LED connected to a PWM (Pulse Width Modulation) pin.
- **analogRead()** is a function that can read analog values from the analog pins A0, A1, A2, A3, A4, and A5. Such pins get the values in integer forms, ranging from 0 to 1023.
- **analgWrite()** writes an analog value in the pins denoted by ~ on the board. For Arduino uno, these pins are: 3, 5, 6, 9, 10, and 11. The analog value is created by PWM. To be more specific, the duty cycle of a rectangular wave is changed based on the desired analog value.
LED Brightness change with slide potentiometer: click to see the live demo., and get the code
4. **Playing a frequency on speaker with pushbutton:** A pushbutton is used to play a frequency on the speaker. By pressing or press-and-holding the pushbutton, the speaker gets a square wave, which we can hear it.
- **tone(pin,frequency) or tone(pin,frequency,duration)** is a function that creates a square wave having 50% duty cycle with the specified frequency in Hertz. If duration (in milliseconds) is given, it generates the square wave for the given duration.
- **noTone(pin)** stops the frequency generation on the given pin.
5. **By sliding the potentiometer, the angle of servo motor is changed:** A slide potentiometer is connected to arduino via an analog pin. Also a servo motor signal pin is connected to a PWM pin of arduino. We use the Servo library to control the angle of servo motor by sliding the potentiometer.
- **Servo myservo** is employed to create an object of Servo from Servo library, here named *myservo*.
- **myservo.attach(servo_pin)** attaches the servo motor with the specified pin, *servo_pin*, to the Servo object.
- **myservo.write(angle)** sets the angle of servo motor to the specified angle.
Setting servo motor angle by a slide potentiometer: click to see the live demo., and get the code
6. **Displaying text on LCD:** An LCD is connected to arduino-uno via the data format 4-bit, which means only 4-bit are used for data transfer. We connect d4-d7 to pins of arduni for data transfer. Also, E(Enable) and RS (Register Select) pins are connected to arduino.
- We use **LiquidCrystal** library for working with LCD. An lcd object is created using this library, which we name it *lcd*.
- **lcd.begin(16,2)** declares that the lcd has 16 characters in each row, and it has two rows.
- **lcd.setCursor(col,row)** sets the cursor at the given position.
- **lcd.print(text)** types the given text on the LCD.
Displaying text on the LCD: click to see the live demo., and get the code
7. **Typing characters on LCD with keypad:** A keypad is connected to arduino along an LCD. The keypad here has eight pins, four rows and four columns.
- For the LCD, We use **LiquidCrystal** library as explained in previous post.
- For the keypad, we use **Keypad** library, and thus creating a **Keypad object**,named *keypad* from this library.
- By using **keypad.getKey()** we get the key that has been pressed.
- Like previous post, we use **lcd.print(key)** to type the pressed key on the LCD.
Typing characters on LCD with keypad: click to see the live demo., and get the code
8. **Distance measurement with ultrasonic range finder:** An ultrasonic range finder is connected to the arduino. This range finder sends sound to the front and listens for the echo of the sound. To show the measured distance, we use an LCD, which is also connected to the arduino.
- AS previous post, for the LCD, **LiquidCrystal** library is employed.
- The trigger pin of the URF (Ultrasonic range finder) is set from LOW to HIGH for at least 10 microseconds to start the distance measurement.
- By using **pulseIn(echo_pin,HIGH)**, we measure the time that a HIGH pulse is detected in the pin echo_pin until this pulse goes to LOW. This measured time is twice the the time for the sound wave to hit the obstacle.
Distance measurement with ultrasonic range finder