This shows you the differences between two versions of the page.
| Next revision | Previous revision | ||
| en:iot-open.eu:wp5:programming:digital_io [2023/06/25 17:46] – created ktokarz | en:iot-open.eu:wp5:programming:digital_io [2023/06/25 18:22] (current) – removed ktokarz | ||
|---|---|---|---|
| Line 1: | Line 1: | ||
| - | ==== Digital ports, reading inputs, outputting data === | ||
| - | Every microcontroller has a number of pins that can be used to connect external electronic elements. In examples shown in previous chapters LED was used. Such LED can be connected to chosen General Purpose Input Output (GPIO) pin and can be controlled by setting a HIGH or LOW state on the pin. Below some details of the set of functions that allow to manipulate GPIOs is shown. In the next chapter, analog signals will be considered. | ||
| - | |||
| - | == Digital I/O == | ||
| - | The digital inputs and outputs of microcontrollers allow for connecting different types of sensors and actuators to the board. Digital signals can take two values – //HIGH//(1) or //LOW//(0). These states correspond to high voltage (equal to the power supply voltage of the microcontroller), | ||
| - | |||
| - | <note important> | ||
| - | Notice that the voltage that the microcontroller is powered with can be different (usually lower) than the voltage provided directly to the board. For example, the ATmega microcontroller on the Arduino Uno board is powered with 5V while the board itself can be powered from an external source providing 7-12V. Other microcontrollers require different voltages e.g. Espressif 3,3V. | ||
| - | </ | ||
| - | |||
| - | **pinMode()** | ||
| - | |||
| - | The function // | ||
| - | |||
| - | The syntax of a function is the following: | ||
| - | <code c> | ||
| - | pinMode(pin, | ||
| - | </ | ||
| - | |||
| - | The parameter //pin// is the number of the pin. | ||
| - | |||
| - | The parameter //mode// can have three different values – //INPUT//, //OUTPUT//, // | ||
| - | |||
| - | **digitalWrite()** | ||
| - | |||
| - | The function // | ||
| - | |||
| - | The syntax of a function is the following: | ||
| - | <code c> | ||
| - | digitalWrite(pin, | ||
| - | </ | ||
| - | |||
| - | The parameter //pin// is the number of the pin. | ||
| - | The parameter //value// can take values //HIGH// or //LOW//. If the mode of the pin is set to the //OUTPUT//, the //HIGH// sets voltage to power supply voltage and //LOW// to 0 V. | ||
| - | |||
| - | It is also possible to use this function for pins that are set to have the INPUT mode. In this case, //HIGH// or //LOW// values enable or disable the internal pull-up resistor. | ||
| - | |||
| - | **digitalRead()** | ||
| - | |||
| - | The function // | ||
| - | |||
| - | The syntax of a function is the following: | ||
| - | <code c> | ||
| - | digitalRead(pin); | ||
| - | </ | ||
| - | |||
| - | The parameter //pin// is the number of the pin. | ||
| - | |||
| - | On the opposite of the functions viewed before, this one has the return type, and it can take a value of //HIGH// or //LOW//. | ||
| - | |||
| - | In the code below the button connected to pin 3 controls the LED connected to pin 4. | ||
| - | |||
| - | <code c> | ||
| - | #define BUTTON_pin 3 | ||
| - | #define LED_pin 4 | ||
| - | |||
| - | void setup() { | ||
| - | pinMode(LED_pin, | ||
| - | pinMode(BUTTON_pin, | ||
| - | } | ||
| - | |||
| - | bool state; | ||
| - | |||
| - | void loop() { | ||
| - | state = digitalRead(BUTTON_pin); | ||
| - | digitalWrite(LED_pin, | ||
| - | } | ||
| - | </ | ||
| - | |||
| - | **Check Yourself** | ||
| - | |||
| - | 1. To assign the Arduino pin operation mode, which function is used? | ||
| - | * Function // | ||
| - | * Function // | ||
| - | * Directive //# | ||
| - | |||
| - | 2. The digital output on the Arduino Uno board works as a power source with voltage? | ||
| - | |||
| - | * 5 V. | ||
| - | * 12 V. | ||
| - | * 3.3 V. | ||