Grundkenntnisse Programmierung 1 (Pulsierende LED): Unterschied zwischen den Versionen
(39 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt) | |||
Zeile 1: | Zeile 1: | ||
[[Kategorie:Arduino: Projekt]] | [[Kategorie:Arduino: Projekt Grundkenntnisse]] | ||
'''Autor:''' Justin Frommberger<br> | '''Autor:''' Justin Frommberger<br> | ||
== Void loop und void setup == | == Void loop und void setup == | ||
['''Quelltext 1:''' <code>ArduinoSketchStruktur.ino</code>] | ['''Quelltext 1:''' <code>ArduinoSketchStruktur.ino</code>] | ||
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size: | <syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small"> | ||
void setup ( ) // Programmstart | void setup ( ) // Programmstart | ||
{ | { | ||
Zeile 16: | Zeile 16: | ||
'''Setup-Funktion''' | '''Setup-Funktion''' | ||
* Wird einmalig beim Start des Arduino-Boards oder nach einem Reset ausgeführt. | * Wird einmalig beim Start des Arduino-Boards oder nach einem Neustart (Reset) ausgeführt. | ||
* In dieser Funktion werden Variablen, | * In dieser Funktion werden [[https://myhomethings.eu/de/arduino-datentypen-und-variablen/ Variablen]], [[https://www.arduino.cc/reference/de/language/functions/digital-io/pinmode/ Pinmode]], [[https://starthardware.org/bibliotheken/ Bibliotheken]], usw. initialisiert. | ||
* Muss immer vorhanden sein! | * Muss immer vorhanden sein! | ||
Zeile 25: | Zeile 25: | ||
== Initialisierung (Zuweisung)== | == Initialisierung (Zuweisung)== | ||
Ist die Zuweisung für ein Datenobjekt oder einer Variable | Ist die Zuweisung für ein Datenobjekt oder einer Variable | ||
* Wird benötigt, um im Programm Variablen Eigenschaften zuzuweisen. | * Wird benötigt, um im Programm Variablen Eigenschaften zuzuweisen. | ||
* | * '''Beispielhaft''' wird der Person ('''Lisa''') ihr Alter zugeordnet Alter ('''18''') zugewiesen. | ||
* So weiß das Programm, dass Lisa gerade 18 Jahre alt ist. | * So weiß das Programm, dass Lisa gerade 18 Jahre alt ist. | ||
---- | |||
===Datentypen (const byte)=== | ===Datentypen (const byte)=== | ||
* Um die erstellte Variable (Lisa = 18) verwenden zu können, benötigen Sie einen Datentypen. | * Um die erstellte Variable (Lisa = 18) verwenden zu können, benötigen Sie einen Datentypen. | ||
* Für das Beispiel (Lisa = 18) wird der Datentyp <code>'''const byte'''</code> verwendet, siehe Tabelle 1. | * Für das Beispiel (Lisa = 18) wird der Datentyp <code>'''const byte'''</code> verwendet, siehe Tabelle 1. | ||
---- | |||
=== | ===Const=== | ||
Steht für eine Konstante und ändert die Variable zu "read-only" | Steht für eine Konstante und ändert die Variable zu "read-only" | ||
* Das bedeutet, dass die Variable wie alle anderen Variablen des gleichen Typs benutzt werden kann, aber dass der Wert unveränderlich ist. | * Das bedeutet, dass die Variable wie alle anderen Variablen des gleichen Typs benutzt werden kann, aber dass der Wert unveränderlich ist. | ||
* Wenn | * Wenn der Variable ein neuer Wert zugewiesen wird, kommt es zu einem Compiler-Fehler. | ||
['''Quelltext 2: ''' <code>byte.ino</code>] | ['''Quelltext 2: ''' <code>byte.ino</code>] | ||
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size: | <syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small"> | ||
const byte Lisa = 18; // Lisa ist 18 Jahre alt | const byte Lisa = 18; // Lisa ist 18 Jahre alt | ||
</syntaxhighlight> | </syntaxhighlight> | ||
---- | |||
== Datentypen == | === Datentypen === | ||
In der Programmierung gibt es verschiedene '''Datentypen''', die angeben, welche Art von Wert eine Variable hat und welche Operationen auf sie angewendet werden können.<br> | In der Programmierung gibt es verschiedene '''Datentypen''', die angeben, welche Art von Wert eine Variable hat und welche Operationen auf sie angewendet werden können.<br> | ||
Ein '''Byte''' kann nur Zahlen im Bereich von 0 bis 255 speichern, ohne dass ein Fehler auftritt. | Ein '''Byte''' kann nur Zahlen im Bereich von 0 bis 255 speichern, ohne dass ein Fehler auftritt. | ||
Zeile 98: | Zeile 99: | ||
['''Quelltext 3: ''' <code>pinMode.ino</code>] | ['''Quelltext 3: ''' <code>pinMode.ino</code>] | ||
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size: | <syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small"> | ||
pinMode(Pin, OUTPUT); // Ausgang Zuweisung | pinMode(Pin, OUTPUT); // Ausgang Zuweisung | ||
/* Oder */ | /* Oder */ | ||
pinMode(Pin, INPUT); // Eingang Zuweisung | pinMode(Pin, INPUT); // Eingang Zuweisung | ||
</syntaxhighlight> | </syntaxhighlight> | ||
---- | |||
===<code>analogWrite()</code>=== | ===<code>analogWrite()</code>=== | ||
Schreibt einen Analogwert auf einen Pin. | Schreibt einen Analogwert auf einen Pin. | ||
Zeile 114: | Zeile 114: | ||
['''Quelltext 4: ''' <code>analogWrite.ino</code>] | ['''Quelltext 4: ''' <code>analogWrite.ino</code>] | ||
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size: | <syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small"> | ||
analogWrite(Pin, Analogwert); // Aufbau | analogWrite(Pin, Analogwert); // Aufbau | ||
Zeile 122: | Zeile 122: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
==<code>delay()</code>== | ---- | ||
===<code>delay()</code>=== | |||
Legt für die angegebene Zeit im Programm eine Pause ein. | Legt für die angegebene Zeit im Programm eine Pause ein. | ||
* Angabe in der Klammer ist in Millisekunden | * Angabe in der Klammer ist in Millisekunden | ||
* Benötigt, um Teile des Programmes langsamer ausführen zu lassen | * Benötigt, um Teile des Programmes langsamer ausführen zu lassen | ||
['''Quelltext 5: ''' <code>delay.ino</code>] | ['''Quelltext 5: ''' <code>delay.ino</code>] | ||
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size: | <syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small"> | ||
void loop() { | void loop() { | ||
delay(400) // Pause von 400ms | delay(400) // Pause von 400ms | ||
Zeile 158: | Zeile 159: | ||
| % || Modulo || a= 7%5; a= 2; || Liefert den Rest bei der Division von | | % || Modulo || a= 7%5; a= 2; || Liefert den Rest bei der Division von | ||
|} | |} | ||
== Strukturen == | == Strukturen == | ||
===if-Bedingung=== | ===if-Bedingung=== | ||
Die if-Bedingung prüft, ob die angegebene Bedingung in den runden Klammern () wahr ist und führt dann den Code aus, der innerhalb der geschweiften Klammern {} steht (siehe Beispiel). | |||
===Vergleichsoperatoren | ===Vergleichsoperatoren=== | ||
{| class="wikitable" | |||
|+ style = "text-align: left"| Tabelle 5: Operatoren | |||
x == y | |- | ||
x != y | | '''x == y ''' || x ist gleich y | ||
x < | |- | ||
x > y | | '''x != y''' || x ist nicht gleich y | ||
x <= y | |- | ||
x >= y | | '''x < y''' || x ist kleiner als y | ||
|- | |||
| '''x > y''' || x ist größer als y | |||
|- | |||
| '''x <= y''' || x ist kleiner als oder gleich zu y | |||
|- | |||
| '''x >= y''' || x ist größer als oder gleich zu y | |||
|} | |||
=== Geschweifte Klammern {} === | === Geschweifte Klammern {} === | ||
Auf eine öffnende geschweifte Klammer {muss immer eine schließende geschweifte Klammer} folgen.<br> | Auf eine öffnende geschweifte Klammer {muss immer eine schließende geschweifte Klammer} folgen.<br> | ||
Siehe im Beispiel: '''if-Bedingung''' | Siehe im Beispiel: '''if-Bedingung'''<br> | ||
['''Quelltext 6:''' <code> | Beispiel: '''if-Bedingung'''<br> | ||
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size: | ['''Quelltext 6: ''' <code>if-Bedingung.ino</code>] | ||
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small"> | |||
if (Lisa == 18) { // Wenn Lisa 18 Jahre alt ist, wird die Anweisung ausgeführt | if (Lisa == 18) { // Wenn Lisa 18 Jahre alt ist, wird die Anweisung ausgeführt | ||
// Anweisung; | // Anweisung; | ||
Zeile 193: | Zeile 197: | ||
} | } | ||
if (Lisa == 18 || Lisa == 20) { // Wenn Lisa 18 | if (Lisa == 18 || Lisa == 20) { // Wenn Lisa 18 oder 20 Jahre alt ist, wird die Anweisung ausgeführt | ||
// Anweisung; | // Anweisung; | ||
} | } | ||
if (Lisa == 18 && Lisa != 20) { // Wenn Lisa 18 | if (Lisa == 18 && Lisa != 20) { // Wenn Lisa 18 und nicht 20 Jahre alt ist, wird die Anweisung ausgeführt | ||
// Anweisung; | // Anweisung; | ||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
<br> | |||
'''→ zurück | ---- | ||
'''→ zurück zur Übersicht: [https://wiki.hshl.de/wiki/index.php/Konzipierung_und_Evaluierung_von_Arduino-Projekten_verschiedener_Schwierigkeitsgrade_f%C3%BCr_die_Lehre#Projekte_unterschiedlicher_Schwierigkeitsgrade Projekte]''' |
Aktuelle Version vom 21. September 2023, 08:04 Uhr
Autor: Justin Frommberger
Void loop und void setup
[Quelltext 1: ArduinoSketchStruktur.ino
]
void setup ( ) // Programmstart
{
// Anweisungen
}
void loop ( ) // Hauptschleife
{
// Anweisungen
}
Setup-Funktion
- Wird einmalig beim Start des Arduino-Boards oder nach einem Neustart (Reset) ausgeführt.
- In dieser Funktion werden [Variablen], [Pinmode], [Bibliotheken], usw. initialisiert.
- Muss immer vorhanden sein!
Die Loop-Funktion
- Ist eine Endlosschleife, die nach jedem Durchlauf erneut aufgerufen wird.
- Hier wird der Code hineingeschrieben, der dauerhaft ausgeführt werden soll.
Initialisierung (Zuweisung)
Ist die Zuweisung für ein Datenobjekt oder einer Variable
- Wird benötigt, um im Programm Variablen Eigenschaften zuzuweisen.
- Beispielhaft wird der Person (Lisa) ihr Alter zugeordnet Alter (18) zugewiesen.
- So weiß das Programm, dass Lisa gerade 18 Jahre alt ist.
Datentypen (const byte)
- Um die erstellte Variable (Lisa = 18) verwenden zu können, benötigen Sie einen Datentypen.
- Für das Beispiel (Lisa = 18) wird der Datentyp
const byte
verwendet, siehe Tabelle 1.
Const
Steht für eine Konstante und ändert die Variable zu "read-only"
- Das bedeutet, dass die Variable wie alle anderen Variablen des gleichen Typs benutzt werden kann, aber dass der Wert unveränderlich ist.
- Wenn der Variable ein neuer Wert zugewiesen wird, kommt es zu einem Compiler-Fehler.
[Quelltext 2: byte.ino
]
const byte Lisa = 18; // Lisa ist 18 Jahre alt
Datentypen
In der Programmierung gibt es verschiedene Datentypen, die angeben, welche Art von Wert eine Variable hat und welche Operationen auf sie angewendet werden können.
Ein Byte kann nur Zahlen im Bereich von 0 bis 255 speichern, ohne dass ein Fehler auftritt.
Datentyp | Bemerkung | Wertebereich |
---|---|---|
bool | 1 Bit [true,false] | [0,1] |
byte | 8 Bit ohne Vorzeichen | [0,255] |
char | 8 Bit ASCII-Zeichen | [-128,128] |
double | 64 Bit Fließkommazahl, 15 Nachkommastellen | [2,2^−308, +1,79^308] |
float | 32 Bit Fließkommazahl, 6 Nachkommastellen | [−3,4^38, +3,4^38] |
int | 16 Bit Integer mit VZ | [-32768, +32767] |
long | 32 Bit Integer mit VZ | [−2^32, +2^32 − 1] |
short | 16 Bit Integer mit VZ | [-32 768,+32 767] |
string | Zeichenkette vom Typ char | Buchstaben |
unsigned char | 8 Bit Integer ohne VZ | [0,255] |
unsigned int | 16 Bit Integer ohne VZ | [0,65535] |
unsigned long | 32 Bit Integer ohne VZ | [0,4294967295] |
Funktionen
pinMode()
Mit der Funktion kann ein bestimmter Pin als Ein- oder Ausgang konfiguriert werden.
PIN | Die Nummer des Pins am Arduino |
Modus | INPUT oder OUTPUT |
OUTPUT | Definiert den Pin als Ausgang |
INPUT | Definiert den Pin als Eingang |
[Quelltext 3: pinMode.ino
]
pinMode(Pin, OUTPUT); // Ausgang Zuweisung
/* Oder */
pinMode(Pin, INPUT); // Eingang Zuweisung
analogWrite()
Schreibt einen Analogwert auf einen Pin.
- Ein Analogwert ist ein Zahlenwert, wie Temperatur = 30
- Diese Funktion wird verwendet, um eine LED mit verschiedener Helligkeit leuchten zu lassen.
[Quelltext 4: analogWrite.ino
]
analogWrite(Pin, Analogwert); // Aufbau
analogWrite(PIN_LED, 200); // Beispiel: Pin 5 sendet nun den Wert 200 an die verbundene LED.
delay()
Legt für die angegebene Zeit im Programm eine Pause ein.
- Angabe in der Klammer ist in Millisekunden
- Benötigt, um Teile des Programmes langsamer ausführen zu lassen
[Quelltext 5: delay.ino
]
void loop() {
delay(400) // Pause von 400ms
}
Mathematische Funktionen
Operator | Bedeutung | Anwendung | Funktion |
---|---|---|---|
= | Zuweisung | a= 2∗b; | Weist der linken Seite den Wert auf der rechten Seite zu |
+ | Addition | a= b+c; | Für die Addition |
- | Subtraktion | a= b-c; | Für die Subtraktion |
++ | Inkrementieren | a++; | Zählt zu der Variable 1 hinzu (+1) |
- | Dekrementieren | a–; | Zieht von der Variable 1 ab (-1) |
* | Multiplikation | a= b∗c; | Für die Multiplikation |
/ | Division | a= b/c; | Dabei darf c nie gleich null sein |
% | Modulo | a= 7%5; a= 2; | Liefert den Rest bei der Division von |
Strukturen
if-Bedingung
Die if-Bedingung prüft, ob die angegebene Bedingung in den runden Klammern () wahr ist und führt dann den Code aus, der innerhalb der geschweiften Klammern {} steht (siehe Beispiel).
Vergleichsoperatoren
x == y | x ist gleich y |
x != y | x ist nicht gleich y |
x < y | x ist kleiner als y |
x > y | x ist größer als y |
x <= y | x ist kleiner als oder gleich zu y |
x >= y | x ist größer als oder gleich zu y |
Geschweifte Klammern {}
Auf eine öffnende geschweifte Klammer {muss immer eine schließende geschweifte Klammer} folgen.
Siehe im Beispiel: if-Bedingung
Beispiel: if-Bedingung
[Quelltext 6: if-Bedingung.ino
]
if (Lisa == 18) { // Wenn Lisa 18 Jahre alt ist, wird die Anweisung ausgeführt
// Anweisung;
}
else (Lisa != 30) { // Wenn Lisa nicht 30 Jahre alt ist, wird die Anweisung ausgeführt
// Anweisung;
}
if (Lisa == 18 || Lisa == 20) { // Wenn Lisa 18 oder 20 Jahre alt ist, wird die Anweisung ausgeführt
// Anweisung;
}
if (Lisa == 18 && Lisa != 20) { // Wenn Lisa 18 und nicht 20 Jahre alt ist, wird die Anweisung ausgeführt
// Anweisung;
}
→ zurück zur Übersicht: Projekte