id: 6lx7yWgnHoT5GHq3 createdBy: 15sg55K8KHkN dateCreated: 1689064662293 name: Arduino - Blink meta: logo: https://raw.githubusercontent.com/edrys-labs/lab-arduino-basics/main/media/logo.jpg description: >- Discover the exciting world of electronics with our Arduino blink tutorial! This beginner-friendly guide is designed for 5th graders and above, introducing students to the basics of programming and physical computing using an Arduino board. Follow step-by-step instructions to create your first LED blink project, learn to communicate with your computer using serial input and output, and solve a coding challenge to reinforce your understanding. Start your journey into the fascinating realm of coding and electronics today! selfAssign: true defaultNumberOfRooms: 0 id: 79sFHo6ONB1S25cTN7emXmOibQ2HNWb2G9X3Xn2x members: teacher: [] student: [] modules: - url: https://edrys-labs.github.io/module-markdown-it/index.html config: > ### Introduction to Arduino and Physical Computing **What is Arduino?** Arduino is a popular open-source platform used for building electronics projects. It consists of both a physical programmable circuit board (often referred to as a microcontroller) and a piece of software, or IDE (Integrated Development Environment), which runs on your computer. You use this software to write and upload computer code to the physical board. **What is Physical Computing?** Physical computing involves designing and building interactive physical systems through the use of software and hardware that can sense and respond to the world around them. With Arduino, you can read inputs – light on a sensor, a finger on a button, or a Twitter message – and turn it into an output – activating a motor, turning on an LED, publishing something online. You can tell your board what to do by sending a set of instructions to the microcontroller on the board. studentConfig: '' teacherConfig: >- ## Welcome for Teachers > This can be used as a base laboratory to create further and more elaborate labs with [edrys-Lite](https://edrys-labs.github.io). > You are currently in the Lobby. If there is a station available you can switch to it and try out the terminal. > Otherwise, if you are in teacher-mode you can share a lab by clicking onto `setting` >> `station` and then by clicking the presented link, > which is the same as the current link, but only with the word `station` instead of `classroom`. stationConfig: '' showInCustom: lobby width: full height: huge - url: https://edrys-labs.github.io/module-editor/index.html config: editorText: | /* Blink Turns an LED on for one second, then off for one second, repeatedly. Most Arduinos have an on-board LED you can control. On the UNO, MEGA and ZERO it is attached to digital pin 13, on MKR1000 on pin 6. LED_BUILTIN is set to the correct LED pin independent of which board is used. If you want to know what pin the on-board LED is connected to on your Arduino model, check the Technical Specs of your board at: https://www.arduino.cc/en/Main/Products This example code is in the public domain. https://www.arduino.cc/en/Tutorial/BuiltInExamples/Blink */ // the setup function runs once when you press reset or power the board void setup() { // initialize digital pin LED_BUILTIN as an output. pinMode(LED_BUILTIN, OUTPUT); // initialize serial output Serial.begin(9600); } // the loop function runs over and over again forever void loop() { digitalWrite(LED_BUILTIN, HIGH); // turn the LED on (HIGH is the voltage level) Serial.println("LED HIGH"); delay(1000); // wait for a second digitalWrite(LED_BUILTIN, LOW); // turn the LED off by making the voltage LOW Serial.println("LED LOW"); delay(1000); // wait for a second } runCommand: execute language: cpp theme: light showInCustom: station width: full height: medium - url: >- https://raw.githubusercontent.com/edrys-labs/module-markdown-it/2.0.0/index.html config: >- # Arduino Tutorial ## Step 1: Your First Project - The Blinking LED **Objective**: To make an LED blink on and off every second. 1. **Build the Circuit**: - Plug your Arduino board into your breadboard. - Connect an LED to pin 13 and a ground pin through a 220-ohm resistor (to protect the LED). 2. **Program Your Arduino**: - Open your Arduino IDE. - Copy and paste the following code into the IDE: ```cpp void setup() { pinMode(13, OUTPUT); // Set pin 13 as an OUTPUT } void loop() { digitalWrite(13, HIGH); // Turn the LED on delay(1000); // Wait for a second digitalWrite(13, LOW); // Turn the LED off delay(1000); // Wait for a second } ``` - Click on the "Run Code" button to send your code to the Arduino. 3. **See the Magic**: Once uploaded, the LED on your breadboard should start blinking. ## Step 2: Adding Serial Communication **Objective**: To control the LED blinking with a command from your computer. 1. **Modify Your Code**: - Add the following lines to enable serial communication: ```cpp void setup() { pinMode(13, OUTPUT); Serial.begin(9600); // Start serial communication at 9600 bps } void loop() { if (Serial.available() > 0) { int state = Serial.read() - '0'; // Read the incoming byte and subtract '0' to get the integer value digitalWrite(13, state); delay(1000); } } ``` 2. **Test Your Setup**: - Open the Serial Monitor in the Arduino IDE. - Type `1` to turn the LED on and `0` to turn it off. ## Step 3: Introducing and Fixing a Compile Error **Objective**: To learn how to troubleshoot and fix errors in your code. 1. **Introduce an Error**: - Change `Serial.begin(9600);` to `Serial.beggin(9600);` and try to upload it. 2. **Identify and Fix the Error**: - The Arduino IDE will show an error message indicating that `Serial.beggin` is not a member of 'Serial'. - Correct it to `Serial.begin(9600);` and re-upload the code. ### Wrap-Up Congratulations! You have successfully completed the Arduino blink tutorial, mastered basic serial communication, and learned to troubleshoot a programming error. Now, you're ready to explore more complex projects and dive deeper into the world of physical computing! studentConfig: '' teacherConfig: '' stationConfig: >- ## Instructions for Station-Sharing You are currently responsible for sharing a station of this lab. You have multiple options to share a or your terminal. Therefor we use the pyxtermjs - terminal server from: https://github.com/edrys-labs/module-pyxtermjs ### Using Docker If you haven't done it so far, install [docker](https://docs.docker.com/engine/install/). Or, follow one of the instruction-videos for your system: <details> <summary>Install Docker on Linux</summary> <iframe style="width: 100%; aspect-ratio: 16 / 9" src="https://www.youtube.com/embed/cqbh-RneBlk?si=juvUM5d2OSZ28WBv" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerpolicy="strict-origin-when-cross-origin" allowfullscreen></iframe> </details> <details> <summary>Install Docker on Windows</summary> <iframe style="width: 100%; aspect-ratio: 16 / 9" src="https://www.youtube.com/embed/WDEdRmTCSs8?si=X0agStn1akNcZLGu" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerpolicy="strict-origin-when-cross-origin" allowfullscreen></iframe> </details> <details> <summary>Install Docker on MacOS</summary> <iframe style="width: 100%; aspect-ratio: 16 / 9" src="https://www.youtube.com/embed/-EXlfSsP49A?si=OZ_l4_2hDKb6ULQ_" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerpolicy="strict-origin-when-cross-origin" allowfullscreen></iframe> </details> Then the only thing that is required is to run the following command: ```bash docker run -it -p 5000:5000 --device=/dev/ttyACM0:/dev/ttyACM0 crosslab/edrys_pyxtermjs_arduino:latest ``` This will download the pyxtermjs terminal-server from docker-hub and run it in a secure environment. ### Using Python You can also share your terminal directly via Python, visit the following project https://github.com/edrys-labs/module-pyxtermjs ... the easiest way is to perform the following steps: ``` bash # 1. clone the repository or download the folder manually git clone https://github.com/edrys-labs/module-pyxtermjs # 2. install all required sources pip3 install -r requirements.txt # 3. run the terminal-server python3 -m pyxtermjs --cors True --command bash --port 5000 ``` showInCustom: station width: full height: huge - url: https://edrys-labs.github.io/module-station-stream/index.html stationConfig: video: true audio: false showInCustom: station width: half height: medium - url: https://edrys-labs.github.io/module-pyxtermjs/index.html stationConfig: server: http://localhost:5000/pty execute: execute script: > echo $CODE | base64 --decode > Blink.ino arduino-cli sketch new Blink olddir=$(pwd) mv Blink.ino Blink cd Blink arduino-cli board attach -p /dev/ttyACM0 -b arduino:avr:uno cd $olddir arduino-cli compile Blink && arduino-cli upload -p /dev/ttyACM0 Blink && arduino-cli monitor -p /dev/ttyACM0 enable: teacher: true student: true showInCustom: station width: half height: medium