
Inhalt
Ziel des Projekts
Die Weckzeit wird zusammen mit Wochentag, Datum und Uhrzeit auf dem LCD-Display angezeigt.
Die Taster stellen die Weckzeit ein und schalten den Wecker ein oder aus:
- linker Taster: eine Stunde vorwärts
- mittlerer Taster: eine Minute weiter
- rechter Taster: Wecker ein- oder ausschalten
So sieht es aus:

Die Hardware
Schließe das LCD an:


⇒LCD

Normalerweise wäre eine komplexe Verkabelung zum Betrieb eines LCDs nötig. Der ⇒I2C-Bus regelt über einen eigenen Mikroprozessor die Kommunikation der Datenleitungen untereinander. Es werden deshalb nur vier Anschlüsse benötigt.

Die Helligkeit kann mit einem Potentiometer auf der Rückseite des LCDs eingestellt werden.
Funktionen der Bibliothek LiquidCrystal_I2C
| Schlüsselwort | Aktion |
|---|---|
| init() | LCD starten |
| backlight() | Hintergrundbeleuchtung einschalten |
| home() | Position auf links oben setzen |
| setCursor(Spalte, Zeile) | Cursor in Spalte/Zeile platzieren |
| clear() | Anzeige löschen |
| print(“Text”) | Text anzeigen |
| blink() | blinkender Cursor |
Benötigte Bauteile
- 3 Taster
- 4‑zeiliges LCD mit I²C-Schnittstelle
- RTC-Modul DS3231
- Lautsprecher
- Leitungsdrähte
Der Schaltplan
(Fahre mit der Maus über das Bild, um die Bezeichnungen der Bauteile zu sehen)
Das Programm
Benötigte Bibliotheken und Variablen

![]() | ![]() |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 | #include “RTClib.h” #include “LiquidCrystal_I2C.h” #include “Bounce2.h” // Name des RTC-Moduls RTC_DS3231 rtc; // 4‑zeiliges LCD LiquidCrystal_I2C lcd(0x27, 20, 4); int Lautsprecher = 5; int TasterLinks = 7; int TasterMitte = 8; int TasterRechts = 9 ; // Beginn der Weckzeit int StundeWeckzeit = 6; int MinuteWeckzeit = 0; // Dauer des Signal in Sekunden int DauerWecksignal = 3; bool TonSekunde = true; bool WeckerEinAus = true; // Zeit messen für Ticken der Uhr long Startzeit; long ZeitJetzt; Bounce WeckzeitStunde = Bounce(); Bounce WeckzeitMinute = Bounce(); Bounce StatusWecker = Bounce(); |
Der setup-Teil
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 | void setup() { pinMode(TasterLinks, INPUT_PULLUP); pinMode(TasterMitte, INPUT_PULLUP); pinMode(TasterRechts, INPUT_PULLUP); // Instanzen des Objekts Bounce für jede Taste zuordnen // Zeitintervall einstellen WeckzeitStunde.attach(TasterLinks); WeckzeitStunde.interval(20); WeckzeitMinute.attach(TasterMitte); WeckzeitMinute.interval(20); StatusWecker.attach(TasterRechts); StatusWecker.interval(20); Serial.begin(9600); // auf serielle Verbindung warten while (!Serial) {;} rtc.begin(); /* wenn Datum und Zeit nicht korrekt -> Datum/Zeit setzen Jahr, Monat, Tag, Stunde, Minute, Sekunde keine führende 0 setzen rtc.adjust(DateTime(2025, 4, 14, 16, 42, 30)); */ // rtc.adjust(DateTime(2025, 4, 14, 16, 42, 30)); // Zeitpunkt des Kompilierens als aktuelle Zeit setzen rtc.adjust(DateTime(F(__DATE__), F(__TIME__))); // LCD starten lcd.init(); // Hintergrundbeleuchtung einschalten lcd.backlight(); Serial.println(“Bitte die Weckzeit eingeben:”); Serial.println(“Taster links -> Stunde +/Taster Mitte -> Minute + Taster rechts -> Weckzeit ein/aus”); Startzeit = millis(); } |
Der loop-Teil
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 | void loop() { String Stunde, Minute, Weckzeit; // aktuelle Zeit lesen DateTime aktuell = rtc.now(); // Stunde einstellen if (WeckzeitStunde.update()) { if (WeckzeitStunde.read() == LOW) { if (StundeWeckzeit >= 24) StundeWeckzeit = 1; else StundeWeckzeit ++; } } // Minute einstellen if (WeckzeitMinute.update()) { if (WeckzeitMinute.read() == LOW) { if (MinuteWeckzeit >= 59) MinuteWeckzeit = 0; else MinuteWeckzeit ++; } } // Wecker ein/aus if (StatusWecker.update()) { if (StatusWecker.read() == LOW) { WeckerEinAus = !WeckerEinAus; } } // Wochentag, Datum und Zeit anzeigen lcd.setCursor(0, 0); /* Wochentag anzeigen 0 = Sonntag 1 = Montag … 6 = Samstag */ switch (aktuell.dayOfTheWeek()) { case 0: lcd.print(“Sonntag”); break; case 1: lcd.print(“Montag”); break; case 2: lcd.print(“Dienstag”); break; case 3: lcd.print(“Mittwoch”); break; case 4: lcd.print(“Donnerstag”); break; case 5: lcd.print(“Freitag”); break; case 6: lcd.print(“Samstag”); break; } lcd.setCursor(0, 1); lcd.print(aktuell.day()); lcd.print(“.”); // Monatsnamen anzeigen lcd.print(“ ”); switch (aktuell.month()) { case 1: lcd.print(“Januar”); break; case 2: lcd.print(“Februar”); break; case 3: lcd.print(“M\341rz”); break; case 4: lcd.print(“April”); break; case 5: lcd.print(“Mai”); break; case 6: lcd.print(“Juni”); break; case 7: lcd.print(“Juli”); break; case 8: lcd.print(“August”); break; case 9: lcd.print(“September”); break; case 10: lcd.print(“Oktober”); break; case 11: lcd.print(“November”); break; case 12: lcd.print(“Dezember”); break; } lcd.print(“ ”); lcd.print(aktuell.year()); lcd.setCursor(0, 2); // wenn Stunden < 10 -> führende 0 setzen if (aktuell.hour() < 10) lcd.print(“0”); lcd.print(aktuell.hour()); lcd.print(‘:’); // wenn Minuten < 10 -> führende 0 setzen if (aktuell.minute() < 10) lcd.print(“0”); lcd.print(aktuell.minute()); lcd.print(‘:’); // wenn Sekunden < 10 -> führende 0 setzen if (aktuell.second() < 10) lcd.print(“0”); lcd.print(aktuell.second()); if (WeckerEinAus) lcd.print(“ Wecker ein”); else lcd.print(“ Wecker aus”); /* Weckzeit formatieren -> führende 0 ergänzen 4 mögliche Fälle Stunde < 10 Minute < 10 Stunde < 10 Minute > 9 Stunde > 10 Minute < 10 Stunde > 10 Minute > 9 */ if (StundeWeckzeit < 10 && MinuteWeckzeit < 10) { Weckzeit = “0” + String(StundeWeckzeit) + “:0” + String(MinuteWeckzeit); } if (StundeWeckzeit < 10 && MinuteWeckzeit > 9) { Weckzeit = “0” + String(StundeWeckzeit) + “:” + String(MinuteWeckzeit); } if (StundeWeckzeit > 9 && MinuteWeckzeit < 10) { Weckzeit = String(StundeWeckzeit) + “:0” + String(MinuteWeckzeit); } if (StundeWeckzeit > 9 && MinuteWeckzeit > 9) { Weckzeit = String(StundeWeckzeit) + “:” + String(MinuteWeckzeit); } lcd.setCursor(0, 3); lcd.print(“Weckzeit: ” + Weckzeit); // führende 0 setzen if (aktuell.hour() < 10) Stunde = “0” + String(aktuell.hour()); else Stunde = String(aktuell.hour()); // führende 0 setzen if (aktuell.minute() < 10) Minute = “0” + String(aktuell.minute()); else Minute = String(aktuell.minute()); // String zusammensetzen String aktuelleZeit = Stunde + “:” + Minute; if (aktuelleZeit == Weckzeit && aktuell.second() < DauerWecksignal) { tone(Lautsprecher, 1000, 500); } /* Ticken der Uhr aktuelle Zeit (ZeitJetzt) messen millis() -> Zeit, die seit dem Start des Programms vergangen ist wenn die Differenz zwischen der gerade gemessenen Zeit und der im setup gemessenen Startzeit >= 1000 (1 Sekunde) ist -> kurzen Ton wiedergeben Startzeit muss anschließend auf die aktuelle Zeit gesetzt werden */ ZeitJetzt = millis(); if (ZeitJetzt - Startzeit >= 1000) { if (TonSekunde) tone(Lautsprecher, 1000, 2); Startzeit = ZeitJetzt; } } |
Verwandte Anleitungen:
- Datum und Zeit mit ESP und time.h anzeigen
- Datum und Zeit mit dem NTP-Protokoll anzeigen
- DHT — Messdaten und Zeit auf TFT anzeigen
- Stoppuhr
- Uhr mit TFT 240x240 Pixeln
- Zeit mit time.h auf einem TFT anzeigen
- Zeit im Seriellen Monitor mit ESP-Mikrocontroller anzeigen
- Datum, Uhrzeit und Temperatur auf einem LCD mit einem RTC-Modul anzeigen
- Uhrzeit und Temperatur auf einem 4‑stelligen 7‑Segment-Modul anzeigen
- Zeit mit time.h auf einer 4‑stelligen 7‑Segment-Anzeige darstellen
Letzte Aktualisierung:








