Arduino Projekt: Pulsierende LED: Unterschied zwischen den Versionen
(57 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt) | |||
Zeile 6: | Zeile 6: | ||
Um das Projekt '''"Pulsierende LED"''' durchzuführen, wird der folgende Ablauf empfohlen einzuhalten: | Um das Projekt '''"Pulsierende LED"''' durchzuführen, wird der folgende Ablauf empfohlen einzuhalten: | ||
# Betrachte das [https://wiki.hshl.de/wiki/index.php/Datei:PulsierendeLED_350px.gif '''Video ( | # Betrachte das [https://wiki.hshl.de/wiki/index.php/Datei:PulsierendeLED_350px.gif '''Video (siehe Abbildung 1)'''], das eine pulsierende LED zeigt, und lesen dir die [https://wiki.hshl.de/wiki/index.php/Arduino_Projekt:_Pulsierende_LED#Aufgabenstellung '''Aufgabenstellung'''] sorgfältig durch. | ||
# Es wird empfohlen, dass Personen ohne vorherige Programmierkenntnisse zunächst [https://wiki.hshl.de/wiki/index.php/Arduino_Projekt:_Pulsierende_LED#Programmieren_lernen '''"Blockly-Spiele"'''] absolvieren. | # Es wird empfohlen, dass Personen ohne vorherige Programmierkenntnisse zunächst [https://wiki.hshl.de/wiki/index.php/Arduino_Projekt:_Pulsierende_LED#Programmieren_lernen '''"Blockly-Spiele"'''] absolvieren. | ||
# Es wird Personen, die das Spiel "Blockly-Spiele" als zu einfach empfinden, empfohlen, stattdessen direkt mit [https://wiki.hshl.de/wiki/index.php/Arduino_Projekt:_Pulsierende_LED#Programmieren_lernen '''"Karel-Spiele"'''] zu starten. | # Es wird Personen, die das Spiel "Blockly-Spiele" als zu einfach empfinden, empfohlen, stattdessen direkt mit [https://wiki.hshl.de/wiki/index.php/Arduino_Projekt:_Pulsierende_LED#Programmieren_lernen '''"Karel-Spiele"'''] zu starten. | ||
Zeile 20: | Zeile 20: | ||
Dieser Vorgang wird in der Fachsprache als "Faden" bezeichnet.<br> | Dieser Vorgang wird in der Fachsprache als "Faden" bezeichnet.<br> | ||
⇒ Für den Fall, dass kein Arduino zur Verfügung steht | ⇒ Für den Fall, dass '''kein Arduino''' zur Verfügung steht oder '''Materialien''' nicht vorhanden sind. Kann dieser '''webbasierter Arduino Emulator''' verwendet werden. [https://wokwi.com/projects/new/arduino-uno [klicken]] | ||
== Programmieren lernen== | == Programmieren lernen== | ||
Zeile 27: | Zeile 27: | ||
* Teilnehmer, die bereits über grundlegende Kenntnisse verfügen, haben die Möglichkeit, die '''Blockly-Spiele''' zu überspringen und direkt mit dem Spiel '''Karel''' zu beginnen. | * Teilnehmer, die bereits über grundlegende Kenntnisse verfügen, haben die Möglichkeit, die '''Blockly-Spiele''' zu überspringen und direkt mit dem Spiel '''Karel''' zu beginnen. | ||
# [[Programmierung mit Blockly-Spiele| '''[Blockly-Spiele]''']] | # Klicke ⇒ [[Programmierung mit Blockly-Spiele| '''[Blockly-Spiele]''']] | ||
# [[Programmierung mit Karel|'''[Karel-Spiel]''']] | # Klicke ⇒ [[Programmierung mit Karel|'''[Karel-Spiel]''']] | ||
== Benötigte Materialien == | == Benötigte Materialien == | ||
Zeile 46: | Zeile 46: | ||
|<big><big>⑤</big></big> || 1 || LED ||[[Datei:R20-F-1-1.jpg|ohne|100px|]] | |<big><big>⑤</big></big> || 1 || LED ||[[Datei:R20-F-1-1.jpg|ohne|100px|]] | ||
|- | |- | ||
|<big><big>⑥</big></big> || 1 || Widerstand 120 Ω||[[Datei:Widerstaende.jpg|ohne|100px|]] | |<big><big>⑥</big></big> || 1 ||Minimum [Widerstand 120 Ω] oder größer||[[Datei:Widerstaende.jpg|ohne|100px|]] | ||
|- | |- | ||
|} | |} | ||
Zeile 54: | Zeile 54: | ||
[[Datei:Anode Kathode.png |thumb|rigth|150px|Abb. 2: LED]] | [[Datei:Anode Kathode.png |thumb|rigth|150px|Abb. 2: LED]] | ||
* Die [[LED (Light Emitting Diode)]] hat zwei Anschlüsse: einen positiven Anschluss (+) und einen negativen Anschluss (-). | * Die [[LED (Light Emitting Diode)]] hat zwei Anschlüsse: einen positiven Anschluss (+) und einen negativen Anschluss (-). | ||
* Der positive Anschluss wird als Anode bezeichnet und der negative Anschluss als Kathode | * Der positive Anschluss wird als Anode bezeichnet und der negative Anschluss als Kathode (siehe Abbildung 2). | ||
* Wenn die LED richtig angeschlossen ist und eine ausreichende Spannung anliegt, leuchtet sie auf. | * Wenn die LED richtig angeschlossen ist und eine ausreichende Spannung anliegt, leuchtet sie auf. | ||
* Wenn nicht, kann es sein, dass + und - vertauscht wurde. | * Wenn nicht, kann es sein, dass + und - vertauscht wurde. | ||
Zeile 67: | Zeile 67: | ||
* Dafür wird eine [[Pulsweitenmodulation (PWM)]] Schnittstelle benötigt, denn bei den anderen Schnittstellen ist der Wert nicht anpassbar. | * Dafür wird eine [[Pulsweitenmodulation (PWM)]] Schnittstelle benötigt, denn bei den anderen Schnittstellen ist der Wert nicht anpassbar. | ||
** Die PWM Schnittstellen sind ganz einfach zu erkennen an diesem Zeichen (~) | ** Die PWM Schnittstellen sind ganz einfach zu erkennen an diesem Zeichen (~) | ||
** Das Zeichen ist auf dem Arduino bei den digitalen Zahlen zu finden | ** Das Zeichen ist auf dem Arduino bei den digitalen Zahlen zu finden (siehe Abbildung 3). | ||
===Steckbrett=== | ===Steckbrett=== | ||
Zeile 85: | Zeile 85: | ||
** Zwischen ['''a bis e'''] und ['''f bis j'''] und ['''1 bis 30''']<br><br> | ** Zwischen ['''a bis e'''] und ['''f bis j'''] und ['''1 bis 30''']<br><br> | ||
Achte auf die Vertikalen und Horizontalen Reihen | Achte auf die Vertikalen und Horizontalen Reihen (siehe Abbildung 3). | ||
# Ground ('''Schwarzes Kabel''') in einer Reihe mit der linken Seite vom Widerstand. | # Ground ('''Schwarzes Kabel''') in einer Reihe mit der linken Seite vom Widerstand. | ||
# Linke Seite vom Widerstand, mit der Kathode in Reihe. | # Linke Seite vom Widerstand, mit der Kathode in Reihe. | ||
Zeile 94: | Zeile 94: | ||
===Benötigtes Programm=== | ===Benötigtes Programm=== | ||
Lade die aktuellste Version der '''Arduino IDE''' herunter. [https://www.arduino.cc/en/software/ [klicken]]<br> | Lade die aktuellste Version der '''Arduino IDE''' herunter. [https://www.arduino.cc/en/software/ [klicken]]<br> | ||
Beachte, die richtige Version für deinen PC auszuwählen | Beachte, die richtige Version für deinen PC auszuwählen (siehe Abbildung 4). | ||
<br> | <br> | ||
[[Datei:ArduinoIDE_download.png|500px|miniatur|center|Abb. 4: ArduinoIDE]] | [[Datei:ArduinoIDE_download.png|500px|miniatur|center|Abb. 4: ArduinoIDE]] | ||
Zeile 100: | Zeile 100: | ||
---- | ---- | ||
===Erstellen der Arduino Datei=== | ===Erstellen der Arduino Datei=== | ||
Starten das Programm '''Arduino IDE'''.<br> | Starten das Programm '''Arduino IDE'''.<br> | ||
Zeile 128: | Zeile 129: | ||
[[Datei:Port.png|500px]] | [[Datei:Port.png|500px]] | ||
|} | |} | ||
---- | |||
=== Aktionsfelder in der Arduino IDE === | |||
[[Datei:Arduino_Start.png|300px]]<br> | |||
'''Abb. 5''': Arduino IDE Erklärung <br> | |||
{| class="wikitable" | |||
|+ style = "text-align: left"| Tabelle 2: Aktionsfelder | |||
|- | |||
| Gelb || Programmcode auf Fehler überprüfen | |||
|- | |||
| Rot || Starten/Hochladen vom Programmcode | |||
|- | |||
| Blau || Neues Fenster öffnen | |||
|- | |||
| Grün|| Öffnen von Beispielen oder eigenem Programmcode | |||
|- | |||
| Lila || Speichern vom Programmcode | |||
|} | |||
⇒ Um das Programm zu beenden, muss der Arduino ausgeschaltet werden. | |||
---- | ---- | ||
===Wichtig für die Programmierung=== | ===Wichtig für die Programmierung=== | ||
Es ist wichtig, die '''Programmierrichtlinien''' beim Verfassen des Programmcodes zu beachten und einzuhalten.<br> | Es ist wichtig, die '''Programmierrichtlinien''' beim Verfassen des Programmcodes zu beachten und einzuhalten.<br> | ||
Zeile 165: | Zeile 185: | ||
{| class="wikitable" | {| class="wikitable" | ||
|+ style = "text-align: left"| Tabelle | |+ style = "text-align: left"| Tabelle 3: Erklärung Initialisierung | ||
|- | |- | ||
| '''Name''' || Es besteht die Möglichkeit, einen beliebigen Namen zu wählen. Achte auf die korrekte Schreibweise. Im folgenden Beispiel wird der Name '''LED_PIN''' verwendet. | | '''Name''' || Es besteht die Möglichkeit, einen beliebigen Namen zu wählen. Achte auf die korrekte Schreibweise. Im folgenden Beispiel wird der Name '''LED_PIN''' verwendet. | ||
Zeile 198: | Zeile 218: | ||
{| class="wikitable" | {| class="wikitable" | ||
|+ style = "text-align: left"| Tabelle | |+ style = "text-align: left"| Tabelle 4: Erklärung OUTPUT | INPUT | ||
|- | |- | ||
| '''OUTPUT''' || Definiert den Pin am Arduino als Ausgang. | | '''OUTPUT''' || Definiert den Pin am Arduino als Ausgang. | ||
Zeile 230: | Zeile 250: | ||
In den nächsten Schritten, soll dem Arduino-Programm erklärt werden, wie hell die LED leuchten soll.<br> | In den nächsten Schritten, soll dem Arduino-Programm erklärt werden, wie hell die LED leuchten soll.<br> | ||
Zuerst muss wieder ein Name erstellt werden, so ähnlich wie bei dem Namen der LED. | Zuerst muss wieder ein Name erstellt werden, so ähnlich wie bei dem Namen der LED. | ||
* In diesem Beispiel wird der Variable der '''[Name: | * In diesem Beispiel wird der Variable der '''[Name: helligkeit]''' zugewiesen. | ||
* Weil derzeit kein Wert für die Helligkeit benötigt wird, wird ihr vorübergehend der Wert '''[ | * Weil derzeit kein Wert für die Helligkeit benötigt wird, wird ihr vorübergehend der Wert '''[helligkeit = 0]''' zugewiesen. | ||
* Achte darauf, den richtigen [https://wiki.hshl.de/wiki/index.php/Grundkenntnisse_Programmierung_(Pulsierende_LED)#Datentypen '''Datentypen'''] und die richtige Namensgebung gemäß den [https://wiki.hshl.de/wiki/index.php/Programmierrichtlinien_Einsteiger '''Programmierrichtlinien'''] zu verwenden. | * Achte darauf, den richtigen [https://wiki.hshl.de/wiki/index.php/Grundkenntnisse_Programmierung_(Pulsierende_LED)#Datentypen '''Datentypen'''] und die richtige Namensgebung gemäß den [https://wiki.hshl.de/wiki/index.php/Programmierrichtlinien_Einsteiger '''Programmierrichtlinien'''] zu verwenden. | ||
Dieser Code wird ebenfalls über den Abschnitt [https://wiki.hshl.de/wiki/index.php/Grundkenntnisse_Programmierung_(Pulsierende_LED)#Void_loop_und_void_setup <code>'''void setup()'''</code>] geschrieben.<br> | Dieser Code wird ebenfalls über den Abschnitt [https://wiki.hshl.de/wiki/index.php/Grundkenntnisse_Programmierung_(Pulsierende_LED)#Void_loop_und_void_setup <code>'''void setup()'''</code>] geschrieben.<br> | ||
Zeile 241: | Zeile 261: | ||
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small"> | <syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small"> | ||
const byte LED_PIN = 9; // Das Wort „LED_PIN“ steht jetzt für den Wert 9 | const byte LED_PIN = 9; // Das Wort „LED_PIN“ steht jetzt für den Wert 9 | ||
byte | byte helligkeit = 0; // ⇐ Das Wort „helligkeit“ steht nun für den Wert, der ausgegeben wird | ||
void setup() | void setup() | ||
{ | { | ||
Zeile 265: | Zeile 285: | ||
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small"> | <syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small"> | ||
const byte LED_PIN = 9; //Das Wort „LED_PIN“ steht jetzt für den Wert 9 | const byte LED_PIN = 9; //Das Wort „LED_PIN“ steht jetzt für den Wert 9 | ||
byte | byte helligkeit = 0; // Das Wort „Helligkeit“ steht nun für den Wert, der ausgegeben wird | ||
void setup() | void setup() | ||
{ | { | ||
Zeile 272: | Zeile 292: | ||
void loop() | void loop() | ||
{ | { | ||
analogWrite(LED_PIN, | analogWrite(LED_PIN, helligkeit); // ⇐ (Die Helligkeit wird später erhöht) | ||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Zeile 278: | Zeile 298: | ||
---- | ---- | ||
==== Rechenfunktion Helligkeit==== | ==== Rechenfunktion Helligkeit==== | ||
Das Ziel des Projekts besteht darin, die LED '''faden''' zu lassen, wofür eine [https://wiki.hshl.de/wiki/index.php/Grundkenntnisse_Programmierung_(Pulsierende_LED)#Mathematische_Funktionen '''Rechenfunktion'''] und eine [https://wiki.hshl.de/wiki/index.php/Grundkenntnisse_Programmierung_(Pulsierende_LED)#if-Bedingung '''if-Bedingung'''] erforderlich sind.<br> | Das Ziel des Projekts besteht darin, die LED '''faden''' zu lassen, wofür eine [https://wiki.hshl.de/wiki/index.php/Grundkenntnisse_Programmierung_(Pulsierende_LED)#Mathematische_Funktionen '''Rechenfunktion'''] und eine [https://wiki.hshl.de/wiki/index.php/Grundkenntnisse_Programmierung_(Pulsierende_LED)#if-Bedingung '''if-Bedingung'''] erforderlich sind.<br> | ||
Zeile 292: | Zeile 313: | ||
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small"> | <syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small"> | ||
const byte LED_PIN = 9; //Das Wort „LED_PIN“ steht jetzt für den Wert 9 | const byte LED_PIN = 9; //Das Wort „LED_PIN“ steht jetzt für den Wert 9 | ||
byte | byte helligkeit = 0; // Das Wort „Helligkeit“ steht nun für den Wert, der ausgegeben wird | ||
byte FADE_SCHRITT = 5; //⇐ Bestimmt die Geschwindigkeit des „Fadens“ | byte FADE_SCHRITT = 5; //⇐ Bestimmt die Geschwindigkeit des „Fadens“ | ||
void setup() | void setup() | ||
Zeile 300: | Zeile 321: | ||
void loop() | void loop() | ||
{ | { | ||
analogWrite(LED_PIN, | analogWrite(LED_PIN, helligkeit); | ||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Zeile 309: | Zeile 330: | ||
* '''Beispiel: ''' <code>'''Ergebnis = Ergebnis + Addition;'''</code> | * '''Beispiel: ''' <code>'''Ergebnis = Ergebnis + Addition;'''</code> | ||
* Zudem wird nach eine kurze Pause [https://wiki.hshl.de/wiki/index.php/Grundkenntnisse_Programmierung_(Pulsierende_LED)#delay() [delay]] von 25ms eingefügt, um die Leuchtstufen länger anzuzeigen. | * Zudem wird nach eine kurze Pause [https://wiki.hshl.de/wiki/index.php/Grundkenntnisse_Programmierung_(Pulsierende_LED)#delay() [delay]] von 25ms eingefügt, um die Leuchtstufen länger anzuzeigen. | ||
Dieser Code muss unter dem Code <code>'''analogWrite(LED_PIN, | Dieser Code muss unter dem Code <code>'''analogWrite(LED_PIN,helligkeit);'''</code> geschrieben werden. | ||
['''Quelltext 6: ''' <code>LED.ino</code>] | ['''Quelltext 6: ''' <code>LED.ino</code>] | ||
Zeile 318: | Zeile 339: | ||
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small"> | <syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small"> | ||
const byte LED_PIN = 9; //Das Wort „LED_PIN“ steht jetzt für den Wert 9 | const byte LED_PIN = 9; //Das Wort „LED_PIN“ steht jetzt für den Wert 9 | ||
byte | byte helligkeit = 0; // Das Wort „Helligkeit“ steht nun für den Wert, der ausgegeben wird | ||
byte FADE_SCHRITT = 5; // Bestimmt die Geschwindigkeit des „Fadens“ | byte FADE_SCHRITT = 5; // Bestimmt die Geschwindigkeit des „Fadens“ | ||
void setup() | void setup() | ||
Zeile 326: | Zeile 347: | ||
void loop() | void loop() | ||
{ | { | ||
analogWrite(LED_PIN, | analogWrite(LED_PIN, helligkeit); | ||
helligkeit =helligkeit + FADE_SCHRITT; // ⇐ Wert für die PWM-Ausgabe verändert | |||
delay(25); // ⇐ Wartet 25ms, damit die Helligkeit länger angezeigt wird | delay(25); // ⇐ Wartet 25ms, damit die Helligkeit länger angezeigt wird | ||
} | } | ||
Zeile 334: | Zeile 355: | ||
---- | ---- | ||
==== if-Bedingung Helligkeit==== | ==== if-Bedingung Helligkeit==== | ||
Abschließend muss eine [https://wiki.hshl.de/wiki/index.php/Grundkenntnisse_Programmierung_(Pulsierende_LED)#if-Bedingung '''if-Bedingung'''] erstellt werden, um die Helligkeit wieder herunterzuzählen. | Abschließend muss eine [https://wiki.hshl.de/wiki/index.php/Grundkenntnisse_Programmierung_(Pulsierende_LED)#if-Bedingung '''if-Bedingung'''] erstellt werden, um die Helligkeit wieder herunterzuzählen. | ||
Zeile 352: | Zeile 374: | ||
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small"> | <syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small"> | ||
const byte LED_PIN = 9; //Das Wort „LED_PIN“ steht jetzt für den Wert 9 | const byte LED_PIN = 9; //Das Wort „LED_PIN“ steht jetzt für den Wert 9 | ||
byte | byte helligkeit = 0; // Das Wort „Helligkeit“ steht nun für den Wert, der ausgegeben wird | ||
byte FADE_SCHRITT = 5; // Bestimmt die Geschwindigkeit des „Fadens“ | byte FADE_SCHRITT = 5; // Bestimmt die Geschwindigkeit des „Fadens“ | ||
void setup() | void setup() | ||
Zeile 360: | Zeile 382: | ||
void loop() | void loop() | ||
{ | { | ||
analogWrite(LED_PIN, | analogWrite(LED_PIN, helligkeit); | ||
helligkeit= helligkeit + FADE_SCHRITT; | |||
delay(25); // 25 Sekunden Pause zwischen dem Hochzählen | delay(25); // 25 Sekunden Pause zwischen dem Hochzählen | ||
if( | if(helligkeit== 0 || helligkeit== 255) // ⇐ if-Bedingung | ||
{ | { | ||
FADE_SCHRITT = -FADE_SCHRITT; // Zahl negieren, sodass subtrahiert wird | FADE_SCHRITT = -FADE_SCHRITT; // Zahl negieren, sodass subtrahiert wird | ||
Zeile 384: | Zeile 406: | ||
/* Variablen deklarieren */ | /* Variablen deklarieren */ | ||
byte | byte helligkeit = 0; // Das Wort „Helligkeit“ steht nun für den Wert, der bei der PWM ausgegeben wird | ||
Zeile 394: | Zeile 416: | ||
void loop() | void loop() | ||
{ | { | ||
analogWrite(LED_PIN, | analogWrite(LED_PIN, helligkeit); // LED (Pin9) die PWM Ausgabe aktiviert | ||
helligkeit = helligkeit + FADE_SCHRITT; // Wert für die PWM-Ausgabe verändert | |||
delay(25); // Helligkeit beibehalten | delay(25); // Helligkeit beibehalten | ||
if ( | if (helligkeit == 0 || helligkeit == 255) // Wenn Helligkeit 0 ODER 255 erreicht wird die Schleife ausgeführt | ||
{ | { | ||
FADE_SCHRITT = -FADE_SCHRITT ; // Wechselt den Wert für die „Fadeschritte“ von positiv zu negativ | FADE_SCHRITT = -FADE_SCHRITT ; // Wechselt den Wert für die „Fadeschritte“ von positiv zu negativ | ||
Zeile 406: | Zeile 428: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
|} | |} | ||
[https://funduino.de/nr-4-pulsierende-led Quelle] | |||
<br> | <br> | ||
---- | ---- | ||
'''→ zurück zum Hauptartikel: [[Konzipierung_und_Evaluierung_von_Arduino-Projekten_verschiedener_Schwierigkeitsgrade_für_die_Lehre | BA: Arduino-Projekte für die Lehre]]''' | '''→ zurück zum Hauptartikel: [[Konzipierung_und_Evaluierung_von_Arduino-Projekten_verschiedener_Schwierigkeitsgrade_für_die_Lehre | BA: Arduino-Projekte für die Lehre]]''' |
Aktuelle Version vom 12. September 2023, 07:01 Uhr
Autor: Justin Frommberger
Ablaufplan
Um das Projekt "Pulsierende LED" durchzuführen, wird der folgende Ablauf empfohlen einzuhalten:
- Betrachte das Video (siehe Abbildung 1), das eine pulsierende LED zeigt, und lesen dir die Aufgabenstellung sorgfältig durch.
- Es wird empfohlen, dass Personen ohne vorherige Programmierkenntnisse zunächst "Blockly-Spiele" absolvieren.
- Es wird Personen, die das Spiel "Blockly-Spiele" als zu einfach empfinden, empfohlen, stattdessen direkt mit "Karel-Spiele" zu starten.
- Nach Abschluss der Spiele ist es erforderlich, eine Überprüfung der Materialliste durchzuführen, um sicherzustellen, dass alle erforderlichen Materialien vorhanden sind.
- Lese dir das "Vorab wichtig zu wissen" durch.
- Fahre mit Abbildung 3 fort und baue die Schaltung des Projekts nach.
- Vor der Programmierung ist es wichtig, das benötigte Programm gemäß den Angaben unter "Benötigtes Programm" herunterzuladen.
- Abschließend wird eine Anleitung zur Programmierung präsentiert.
- Um die Aufgaben zu vereinfachen, wird empfohlen, den Code in der gleichen Position wie in der Lösung zu platzieren.
Aufgabenstellung
Das Ziel dieses Projekts besteht darin, eine LED durch pulsierende Helligkeitsänderungen effektvoll zum Leuchten zu bringen.
Dieser Vorgang wird in der Fachsprache als "Faden" bezeichnet.
⇒ Für den Fall, dass kein Arduino zur Verfügung steht oder Materialien nicht vorhanden sind. Kann dieser webbasierter Arduino Emulator verwendet werden. [klicken]
Programmieren lernen
Um Personen ohne Vorkenntnisse im Bereich der Programmierung angemessen einzubeziehen, sollten vorab beide der nachfolgenden Spiele durchgeführt werden.
- Ohne Vorkenntnisse bedeutet, dass man keinerlei Kenntnisse zum Thema Programmierung besitzt.
- Teilnehmer, die bereits über grundlegende Kenntnisse verfügen, haben die Möglichkeit, die Blockly-Spiele zu überspringen und direkt mit dem Spiel Karel zu beginnen.
- Klicke ⇒ [Blockly-Spiele]
- Klicke ⇒ [Karel-Spiel]
Benötigte Materialien
Nr. | Anz. | Beschreibung | Bild |
---|---|---|---|
① | 1 | Funduino Arduino UNO R3 | |
② | 1 | Typ 2 | |
③ | 2 | Jumper Kabel, männlich/männlich | |
④ | 1 | Steckbrett | |
⑤ | 1 | LED | |
⑥ | 1 | Minimum [Widerstand 120 Ω] oder größer |
Vorab wichtig zu wissen!
LED
- Die LED (Light Emitting Diode) hat zwei Anschlüsse: einen positiven Anschluss (+) und einen negativen Anschluss (-).
- Der positive Anschluss wird als Anode bezeichnet und der negative Anschluss als Kathode (siehe Abbildung 2).
- Wenn die LED richtig angeschlossen ist und eine ausreichende Spannung anliegt, leuchtet sie auf.
- Wenn nicht, kann es sein, dass + und - vertauscht wurde.
- In diesem Fall muss die LED umgedreht werden, da dies potenziell zu Schäden führen kann.
- In diesem Fall muss die LED umgedreht werden, da dies potenziell zu Schäden führen kann.
Beachte, dass LEDs eine begrenzte Vorwärtsspannung haben und eine geeignete Vorwiderstand benötigen.
- Um den Stromfluss zu begrenzen und Schäden durch Überstrom zu vermeiden.
Arduino Uno R3
Der Arduino besitzt unterschiedliche Schnittstellen. Da dieser ein digitaler Mikrocontroller ist, kann er nur 5 Volt ausgeben oder annehmen.
Bei einer konstanten 5 V Spannung ist die LED immer gleich hell. So ist das Ziel, die Spannung zur LED zu reduzieren.
- Dafür wird eine Pulsweitenmodulation (PWM) Schnittstelle benötigt, denn bei den anderen Schnittstellen ist der Wert nicht anpassbar.
- Die PWM Schnittstellen sind ganz einfach zu erkennen an diesem Zeichen (~)
- Das Zeichen ist auf dem Arduino bei den digitalen Zahlen zu finden (siehe Abbildung 3).
Steckbrett
Erklärung zum Arbeiten mit einem Steckbrett. [klicken]
Widerstand
Der Vorwiderstand wird verwendet, um den Fluss des elektrischen Stromes zu verkleinern.
- Um die Größe der Widerstände zu bestimmen, kann man anhand ihres Farbcodes erkennen.
- Eine hilfreiche Internetseite steht zur Verfügung, um die genaue Größe zu ermitteln. [klicken]
Aufbau Schaltung
In Abbildung 3 wird die Schaltung für das Projekt "Pulsierende LED" dargestellt.
Bevor mit der Programmierung begonnen werden kann, muss die Schaltung des Projekts aufgebaut werden.
- Beim Aufbau der Schaltung ist es egal, wo diese auf dem Steckbrett platziert wird.
- Zwischen [a bis e] und [f bis j] und [1 bis 30]
- Zwischen [a bis e] und [f bis j] und [1 bis 30]
Achte auf die Vertikalen und Horizontalen Reihen (siehe Abbildung 3).
- Ground (Schwarzes Kabel) in einer Reihe mit der linken Seite vom Widerstand.
- Linke Seite vom Widerstand, mit der Kathode in Reihe.
- Anode in Reihe mit Pin 9 ( Rotes Kabel ).
Programmierung
Benötigtes Programm
Lade die aktuellste Version der Arduino IDE herunter. [klicken]
Beachte, die richtige Version für deinen PC auszuwählen (siehe Abbildung 4).
Erstellen der Arduino Datei
Starten das Programm Arduino IDE.
Sobald das Programm gestartet ist, soll ein neues Projekt geöffnet und anschließend abgespeichert werden.
Stelle sicher, dass dein Arduino über ein Kabel mit dem Computer verbunden ist.
- Wichtig: Unter jeder Anleitung ist ein Beispiel vorhanden, das durch Klicken auf "Ausklappen" sichtbar wird.
Neues Projekt & Speichern |
⇒ Überprüfe, ob das richtige Board ausgewählt wurde.
Board check |
⇒ Überprüfe, ob der richtige Port ausgewählt wurde.
- Die Port-Nummer ist für jede Schnittstelle anders. Beachte den Namen, der in Klammern angegeben ist (Arduino Uno).
Port check |
Aktionsfelder in der Arduino IDE
Gelb | Programmcode auf Fehler überprüfen |
Rot | Starten/Hochladen vom Programmcode |
Blau | Neues Fenster öffnen |
Grün | Öffnen von Beispielen oder eigenem Programmcode |
Lila | Speichern vom Programmcode |
⇒ Um das Programm zu beenden, muss der Arduino ausgeschaltet werden.
Wichtig für die Programmierung
Es ist wichtig, die Programmierrichtlinien beim Verfassen des Programmcodes zu beachten und einzuhalten.
[Programmierrichtlinien]
Die Grundkenntnisse dienen als Nachschlagewerk, um während der Programmierung einen Code zu überprüfen.
[Grundkenntnisse pulsierende LED]
Start der Programmierung
Wichtig vorab:
- Überprüfe die Lösungen sorgfältig und stelle sicher, dass dein Code genau wie im Beispiel angeordnet ist.
- Beachte die Klammer vor, hinter oder nach jedem Wort. Diese sind sehr wichtig in der Programmierung.
- Dein Code muss wie im Beispiel: Quelltext 1:
Start.ino
aussehen.
[Quelltext 1: Start.ino
]
void setup()
{
}
void loop()
{
}
Initialisierung (Zuweisung)
Im ersten Schritt der Programmierung soll der LED in der Arduino IDE mit ihrem Namen und Datentyp versehen werden.
Um das Verständnis zu verbessern, wird empfohlen, sich mit den Grundkenntnissen der [Initialisierung] und [Datentypen] vertraut zu machen.
- Durch die Verwendung des Codes
const byte NAME = Zahl;
wird der LED ein spezifischer Name und Datentyp zugewiesen. - Deine Aufgabe ist, den Code einzufügen und Name und Zahl zu ihren Werten auszutauschen.
Schreiben den Code über, dem void setup()
. Beachte, dass jedes Zeichen übernommen werden muss.
Name | Es besteht die Möglichkeit, einen beliebigen Namen zu wählen. Achte auf die korrekte Schreibweise. Im folgenden Beispiel wird der Name LED_PIN verwendet. |
Zahl | Die Zahl ergibt sich aus der Position, an der das Kabel mit der LED verbunden ist. In diesem Beispiel ist es die Zahl 9 (siehe Schaltung). |
const byte | Beutetet, dass die Zahl konstant bleibt und im Bereich 0 und 255 liegt |
[Quelltext 1: LED.ino
]
Lösung |
const byte LED_PIN = 9; // ⇐ Das Wort „LED_PIN“ steht jetzt für den Wert 9
void setup()
{
}
void loop()
{
}
|
LED INPUT oder OUTPUT
Nun muss entschieden werden, ob eine LED ein INPUT oder OUTPUT-Befehl verwenden muss.
Hierfür wird der Code pinMode(LED_PIN,OUTPUT);
oder pinMode(LED_PIN,INPUT);
verwendet.
OUTPUT | Definiert den Pin am Arduino als Ausgang. |
INPUT | Definiert den Pin am Arduino als Eingang. |
Weil der Arduino die LED mit Strom versorgt, ergibt sich die Notwendigkeit eines OUTPUTs.
Der Befehl wird ins void setup()
geschrieben.
[Quelltext 2: LED.ino
]
Lösung |
const byte LED_PIN = 9; // Das Wort „LED_PIN“ steht jetzt für den Wert 9
void setup()
{
pinMode(LED_PIN, OUTPUT); // ⇐ Definiert den Pin als Ausgang
}
void loop()
{
}
|
LED Helligkeit anpassen
In den nächsten Schritten, soll dem Arduino-Programm erklärt werden, wie hell die LED leuchten soll.
Zuerst muss wieder ein Name erstellt werden, so ähnlich wie bei dem Namen der LED.
- In diesem Beispiel wird der Variable der [Name: helligkeit] zugewiesen.
- Weil derzeit kein Wert für die Helligkeit benötigt wird, wird ihr vorübergehend der Wert [helligkeit = 0] zugewiesen.
- Achte darauf, den richtigen Datentypen und die richtige Namensgebung gemäß den Programmierrichtlinien zu verwenden.
Dieser Code wird ebenfalls über den Abschnitt void setup()
geschrieben.
[Quelltext 3: LED.ino
]
Lösung |
const byte LED_PIN = 9; // Das Wort „LED_PIN“ steht jetzt für den Wert 9
byte helligkeit = 0; // ⇐ Das Wort „helligkeit“ steht nun für den Wert, der ausgegeben wird
void setup()
{
pinMode(LED_PIN, OUTPUT); // Definiert den Pin als Ausgang
}
void loop()
{
}
|
Um die LED zum Leuchten zu bringen, muss der Helligkeitswert der LED zugewiesen werden.
- Mit dem Befehl
analogWrite(LED_PIN, Helligkeit)
ist dies möglich. - Bei Fragen, siehe Grundkenntnisse Programmierung
analogWrite()
.
Dieser Code wird in die Klammern vom void loop()
geschrieben.
[Quelltext 4: LED.ino
]
Lösung |
const byte LED_PIN = 9; //Das Wort „LED_PIN“ steht jetzt für den Wert 9
byte helligkeit = 0; // Das Wort „Helligkeit“ steht nun für den Wert, der ausgegeben wird
void setup()
{
pinMode(LED_PIN, OUTPUT); // Definiert den Pin als Ausgang
}
void loop()
{
analogWrite(LED_PIN, helligkeit); // ⇐ (Die Helligkeit wird später erhöht)
}
|
Rechenfunktion Helligkeit
Das Ziel des Projekts besteht darin, die LED faden zu lassen, wofür eine Rechenfunktion und eine if-Bedingung erforderlich sind.
Derzeit ist der Helligkeitswert im Programm auf 0 eingestellt, dieser Wert muss angepasst werden, um die LED unterschiedlich hell leuchten zu lassen.
- Um dies zu erreichen, bedarf es Programmiercode, die die Variable "Helligkeit" von 0 hochzählt und anschließend wieder herunterzählt.
- Hierfür wird eine Variable mit dem Namen
byte FADE_SCHRITT = 5;
benötigt, diese soll später die Helligkeit um +5 erhöhen und um -5 herunterzählen.
Die Variable wird wieder über dem void setup()
geschrieben.
[Quelltext 5: LED.ino
]
Lösung |
const byte LED_PIN = 9; //Das Wort „LED_PIN“ steht jetzt für den Wert 9
byte helligkeit = 0; // Das Wort „Helligkeit“ steht nun für den Wert, der ausgegeben wird
byte FADE_SCHRITT = 5; //⇐ Bestimmt die Geschwindigkeit des „Fadens“
void setup()
{
pinMode(LED_PIN, OUTPUT); // Definiert den Pin als Ausgang
}
void loop()
{
analogWrite(LED_PIN, helligkeit);
}
|
Addition:
Zum Schluss muss die Helligkeit um die FADE_SCHRITTEN erhöht und der neue Wert gespeichert werden.
Um dies umzusetzen, wird die Helligkeit gleichgesetzt mit der Helligkeit plus den FADE_SCHRITTEN.
- Beispiel:
Ergebnis = Ergebnis + Addition;
- Zudem wird nach eine kurze Pause [delay] von 25ms eingefügt, um die Leuchtstufen länger anzuzeigen.
Dieser Code muss unter dem Code analogWrite(LED_PIN,helligkeit);
geschrieben werden.
[Quelltext 6: LED.ino
]
Lösung |
const byte LED_PIN = 9; //Das Wort „LED_PIN“ steht jetzt für den Wert 9
byte helligkeit = 0; // Das Wort „Helligkeit“ steht nun für den Wert, der ausgegeben wird
byte FADE_SCHRITT = 5; // Bestimmt die Geschwindigkeit des „Fadens“
void setup()
{
pinMode(LED_PIN, OUTPUT); // Definiert den Pin als Ausgang
}
void loop()
{
analogWrite(LED_PIN, helligkeit);
helligkeit =helligkeit + FADE_SCHRITT; // ⇐ Wert für die PWM-Ausgabe verändert
delay(25); // ⇐ Wartet 25ms, damit die Helligkeit länger angezeigt wird
}
|
if-Bedingung Helligkeit
Abschließend muss eine if-Bedingung erstellt werden, um die Helligkeit wieder herunterzuzählen.
- Wenn die Variable Helligkeit den Wert 0 oder 255 erreicht, ändert sich das Vorzeichen von FADE_SCHRITTEN.
- Beispiel: Helligkeit erreicht den Wert 255, folgend wird FADE_SCHRITTE zu -FADE_SCHRITTE.
- Dies sorgt dafür, dass die Helligkeit wieder heruntergezählt wird.
Dieser Code wird unter delay(25);
geschrieben.
Hinweis:
Die Lösung der if-Aufgabe ist anspruchsvoller, so wird geraten, die Lösung 7 zu übernehmen.
Um im Anschluss die Lösung besser nachvollziehen zu können, ist es wichtig, zu verstehen, wie die Aufgabe gelöst wurde.
[Quelltext 7: LED.ino
]
Lösung |
const byte LED_PIN = 9; //Das Wort „LED_PIN“ steht jetzt für den Wert 9
byte helligkeit = 0; // Das Wort „Helligkeit“ steht nun für den Wert, der ausgegeben wird
byte FADE_SCHRITT = 5; // Bestimmt die Geschwindigkeit des „Fadens“
void setup()
{
pinMode(LED_PIN, OUTPUT);
}
void loop()
{
analogWrite(LED_PIN, helligkeit);
helligkeit= helligkeit + FADE_SCHRITT;
delay(25); // 25 Sekunden Pause zwischen dem Hochzählen
if(helligkeit== 0 || helligkeit== 255) // ⇐ if-Bedingung
{
FADE_SCHRITT = -FADE_SCHRITT; // Zahl negieren, sodass subtrahiert wird
}
}
|
Musterlösung
Sollte der Code nicht ordnungsgemäß funktionieren, überprüfen ihn anhand der Musterlösung.
Musterlösung |
/* Konstanten */
const byte LED_PIN = 9; //Das Wort „LED_PIN“ steht jetzt für den Wert 9
byte FADE_SCHRITT = 5; // Bestimmt die Geschwindigkeit des „fadens“
/* Variablen deklarieren */
byte helligkeit = 0; // Das Wort „Helligkeit“ steht nun für den Wert, der bei der PWM ausgegeben wird
void setup()
{
pinMode(LED_PIN, OUTPUT); // Der Pin mit der LED (Pin9) ist ein Ausgang
}
void loop()
{
analogWrite(LED_PIN, helligkeit); // LED (Pin9) die PWM Ausgabe aktiviert
helligkeit = helligkeit + FADE_SCHRITT; // Wert für die PWM-Ausgabe verändert
delay(25); // Helligkeit beibehalten
if (helligkeit == 0 || helligkeit == 255) // Wenn Helligkeit 0 ODER 255 erreicht wird die Schleife ausgeführt
{
FADE_SCHRITT = -FADE_SCHRITT ; // Wechselt den Wert für die „Fadeschritte“ von positiv zu negativ
}
} // Loop-Teil geschlossen.
|
→ zurück zum Hauptartikel: BA: Arduino-Projekte für die Lehre