2017-09-17 17:06:10 +02:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Die Klassen Uhrenanzeige implementiert die Anzeige einer Digitaluhr.
|
|
|
|
|
* Die Anzeige zeigt Stunden und Minuten. Der Anzeigebereich reicht von
|
|
|
|
|
* 00:00 (Mitternacht) bis 23:59 (eine Minute vor Mitternacht).
|
|
|
|
|
*
|
|
|
|
|
* Eine Uhrenanzeige sollte minütlich "Taktsignale" (über die Operation
|
|
|
|
|
* "taktsignalGeben") erhalten, damit sie die Anzeige aktualisieren
|
|
|
|
|
* kann. Dies geschieht, wie man es bei einer Uhr erwartet: Die
|
|
|
|
|
* Stunden erhöhen sich, wenn das Minutenlimit einer Stunde erreicht
|
|
|
|
|
* ist.
|
|
|
|
|
*
|
|
|
|
|
* @author Michael Kölling und David J. Barnes
|
|
|
|
|
* @version 31.07.2011
|
|
|
|
|
*/
|
|
|
|
|
public class Uhrenanzeige
|
|
|
|
|
{
|
|
|
|
|
private Nummernanzeige stunden;
|
|
|
|
|
private Nummernanzeige minuten;
|
2021-10-09 16:17:02 +02:00
|
|
|
|
private Nummernanzeige sekunden;
|
2017-09-17 17:06:10 +02:00
|
|
|
|
private String zeitanzeige; // simuliert die tatsächliche Anzeige
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Konstruktor für ein Exemplar von Uhrenanzeige.
|
|
|
|
|
* Mit diesem Konstruktor wird die Anzeige auf 00:00 initialisiert.
|
|
|
|
|
*/
|
|
|
|
|
public Uhrenanzeige()
|
|
|
|
|
{
|
|
|
|
|
stunden = new Nummernanzeige(24);
|
|
|
|
|
minuten = new Nummernanzeige(60);
|
2021-10-09 16:17:02 +02:00
|
|
|
|
sekunden = new Nummernanzeige(60);
|
2017-09-17 17:06:10 +02:00
|
|
|
|
anzeigeAktualisieren();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Konstruktor für ein Exemplar von Uhrenanzeige.
|
|
|
|
|
* Mit diesem Konstruktor wird die Anzeige auf den Wert
|
|
|
|
|
* initialisiert, der durch 'stunde' und 'minute'
|
|
|
|
|
* definiert ist.
|
|
|
|
|
*/
|
2021-10-09 16:17:02 +02:00
|
|
|
|
public Uhrenanzeige(int stunde, int minute, int sekunde)
|
2017-09-17 17:06:10 +02:00
|
|
|
|
{
|
|
|
|
|
stunden = new Nummernanzeige(24);
|
|
|
|
|
minuten = new Nummernanzeige(60);
|
2021-10-09 16:17:02 +02:00
|
|
|
|
sekunden = new Nummernanzeige(60);
|
|
|
|
|
setzeUhrzeit(stunde, minute, sekunde);
|
2017-09-17 17:06:10 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Diese Operation sollte einmal pro Minute aufgerufen werden -
|
|
|
|
|
* sie sorgt dafür, dass diese Uhrenanzeige um eine Minute
|
|
|
|
|
* weiter gestellt wird.
|
|
|
|
|
*/
|
|
|
|
|
public void taktsignalGeben()
|
|
|
|
|
{
|
2021-10-09 16:17:02 +02:00
|
|
|
|
sekunden.erhoehen();
|
|
|
|
|
if(sekunden.gibWert() == 0) {
|
|
|
|
|
minuten.erhoehen();
|
|
|
|
|
if (minuten.gibWert() == 0) { // Limit wurde erreicht!
|
|
|
|
|
stunden.erhoehen();
|
|
|
|
|
}
|
2017-09-17 17:06:10 +02:00
|
|
|
|
}
|
|
|
|
|
anzeigeAktualisieren();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Setze die Uhrzeit dieser Anzeige auf die gegebene 'stunde' und
|
|
|
|
|
* 'minute'.
|
|
|
|
|
*/
|
2021-10-09 16:17:02 +02:00
|
|
|
|
public void setzeUhrzeit(int stunde, int minute, int sekunde)
|
2017-09-17 17:06:10 +02:00
|
|
|
|
{
|
|
|
|
|
stunden.setzeWert(stunde);
|
|
|
|
|
minuten.setzeWert(minute);
|
2021-10-09 16:17:02 +02:00
|
|
|
|
sekunden.setzeWert(sekunde);
|
2017-09-17 17:06:10 +02:00
|
|
|
|
anzeigeAktualisieren();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Liefere die aktuelle Uhrzeit dieser Uhrenanzeige im Format SS:MM.
|
|
|
|
|
*/
|
|
|
|
|
public String gibUhrzeit()
|
|
|
|
|
{
|
|
|
|
|
return zeitanzeige;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Aktualisiere die interne Zeichenkette, die die Zeitanzeige h<EFBFBD>lt.
|
|
|
|
|
*/
|
|
|
|
|
private void anzeigeAktualisieren()
|
|
|
|
|
{
|
|
|
|
|
zeitanzeige = stunden.gibAnzeigewert() + ":"
|
2021-10-09 16:17:02 +02:00
|
|
|
|
+ minuten.gibAnzeigewert() + ":"
|
|
|
|
|
+ sekunden.gibAnzeigewert();
|
2017-09-17 17:06:10 +02:00
|
|
|
|
}
|
|
|
|
|
}
|