Grundkenntnisse Programmierung 1 (Pulsierende LED): Unterschied zwischen den Versionen

Aus HSHL Mechatronik
Zur Navigation springen Zur Suche springen
 
(132 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 1: Zeile 1:
== Void loop und void setup ==
[[Kategorie:Arduino: Projekt Grundkenntnisse]]
----
'''Autor:''' Justin Frommberger<br>
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:14px">
== Void loop und void setup ==  
 
['''Quelltext 1:''' <code>ArduinoSketchStruktur.ino</code>]
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small">
void setup ( ) // Programmstart
void setup ( ) // Programmstart
{
{
Zeile 11: Zeile 14:
}
}
</syntaxhighlight>
</syntaxhighlight>
----
 
'''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, Pinmodi, Bibliotheken, usw. initalisiert.  
* 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!


'''Die Loop-Funktion'''
'''Die Loop-Funktion'''
* Ist eine Endlosschleife, die nach jedem Durchlauf erneut aufgerufen wird.
* Ist eine Endlosschleife, die nach jedem Durchlauf erneut aufgerufen wird.
* Hier schreiben wir unseren Code hinein, der dauerhaft ausgeführt werden soll.
* 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 <code>'''const byte'''</code> 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.


== Initialisierung (Zuweisung )==
['''Quelltext 2: ''' <code>byte.ino</code>]
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small">


'''Erklärung'''
const byte Lisa = 18;    // Lisa ist 18 Jahre alt
* Ist die Zuweisung für ein Datenobjekt oder einer Variable.
* Wird benötigt, um in unserem Programm Variablen Eigenschaften zuzuweisen.
* Sozusagen wird einer Person ihr Alter zugeordnet ('''Lisa'''), um sie wiederzuerkennen weißen wir ihr das Alter ('''18''') zu.
* So weiß das Programm, dass Lisa 18 Jahre alt ist.


===Datentypen (Int)===
</syntaxhighlight>
* Um nun unsere erstelle Variable (Lisa = 18) verwerden zu können, benötigen wir einen Datentypen.
* Arduino verfügt über einige Datentypen, siehe [[https://www.arduino.cc/reference/de/#variables Hier!]]
* Für unser Beispiel (Lisa = 18) benötigen wir eine Variable für Zahlen, Intiger(Int)
----
----
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:14px">


int 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.<br>
Ein '''Byte''' kann nur Zahlen im Bereich von 0 bis 255 speichern, ohne dass ein Fehler auftritt.


</syntaxhighlight>
{| class="wikitable"
----
|+ style = "text-align: left"| Tabelle 1: Datentypen
|-
! 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 ==
== Funktionen ==


'''Erklärung'''
===<code>pinMode()</code>===
* Zum Steuern des Arduino-Boards und zur Durchführung von Berechnungen.
Mit der Funktion kann ein bestimmter Pin als Ein- oder Ausgang konfiguriert werden.<br>
* Für unser Projekt, benötigen wird drei Funktionen, pinMode(), analogWrite() und delay().


===pinMode()===
{| class="wikitable"
* Wird benötigt, um den Verwendeten Pin vom Arduino als '''OUTPUT''' (Ausgang) oder '''INPUT''' (Eingang) festzulegen.
|+ style = "text-align: left"| Tabelle 3: pinMode(PIN, Modus);
* '''OUTPUT''' um Informationen mit dem Arduino zu empfangen.
|-
* '''INPUT''' um Daten vom Arduino zu einem Empfänger zu verschicken.
| '''PIN''' || Die Nummer des Pins am Arduino
* Wir verwenden diese Funktion, um die LED zuzuweisen.
|-
----
| '''Modus''' || INPUT oder OUTPUT
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:14px">
|-
| '''OUTPUT''' ||  Definiert den Pin als Ausgang
|-
| '''INPUT''' || Definiert den Pin als Eingang
|}
 
['''Quelltext 3: ''' <code>pinMode.ino</code>]
<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>===
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.


===analogWrite()===
['''Quelltext 4: ''' <code>analogWrite.ino</code>]
* Schreibt einen Analogwert auf einen Pin.
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small">
* Ein Analogwert ist ein Zahlenwert, wie Temperatur = 30
* Wir verwenden diese Funktion, um eine LED mit verschiedener Helligkeit leuchten zu lassen.
----
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:14px">


analogWrite(Pin, Analogwert);  // Aufbau
analogWrite(Pin, Analogwert);  // Aufbau


analogWrite(Pin(LED), 200);    // Beispiel: Pin 5 sendet nun den Wert 200 an die verbundene LED.
analogWrite(PIN_LED, 200);    // Beispiel: Pin 5 sendet nun den Wert 200 an die verbundene LED.


</syntaxhighlight>
</syntaxhighlight>
----
----
===<code>delay()</code>===
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: ''' <code>delay.ino</code>]
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small">
void loop() {
  delay(400)    // Pause von 400ms
}
</syntaxhighlight>
== Mathematische Funktionen ==
{| class="wikitable"
|+ style = "text-align: left"| Tabelle 4: Operatoren
|-
! 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 ==
== Strukturen ==


===if-Verzweigung===
===if-Bedingung===
* Das if-Statement checkt, ob eine Bedingung true ist und führt dann den Code aus, der innerhalb der Klammern steht.
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===
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:14px">
{| class="wikitable"
|+ style = "text-align: left"| Tabelle 5: Operatoren
|-
| '''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.<br>
Siehe im Beispiel: '''if-Bedingung'''<br>


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)


</syntaxhighlight>
Beispiel: '''if-Bedingung'''<br>
----
['''Quelltext 6: ''' <code>if-Bedingung.ino</code>]
'''Beispiel if-Verzweigung'''
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:small">
<syntaxhighlight lang="C" style="border: none; background-color: #EFF1C1; font-size:14px">
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;
}
}
else (Lisa != 30) {      // Wenn Lisa nicht 30 Jahre alt ist wird die Anweisung ausgeführt
else (Lisa != 30) {      // Wenn Lisa nicht 30 Jahre alt ist, wird die Anweisung ausgeführt
   // Anweisung;
   // Anweisung;
}
}


if (Lisa == 18 || Lisa == 20) {        // Wenn Lisa 18 '''oder''' 20 Jahre alt ist wird die Anweisung ausgeführt
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 '''und '''nicht 20 Jahre alt ist wird die Anweisung ausgeführt
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 Ü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.

Tabelle 1: Datentypen
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.

Tabelle 3: pinMode(PIN, Modus);
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

Tabelle 4: Operatoren
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

Tabelle 5: Operatoren
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