Witam wszystkich,
Tak jak w temacie:
Poszukuje sprawnego programu aby zrobić zegar LCD na ATMEGA8. Program musi być w języku bascom.
Znalazłem coś takiego ale nie działa :/
Opoźnienie sekundy wynois jakies 4s
Za działający program dam 15 Pkt
Pozdrawiam
Tak jak w temacie:
Poszukuje sprawnego programu aby zrobić zegar LCD na ATMEGA8. Program musi być w języku bascom.
Znalazłem coś takiego ale nie działa :/
Opoźnienie sekundy wynois jakies 4s
'Program zegara wykorzystującego przerwania od Timer1
'Przerwanie przepełnienia Timer1 jest generowane co 1 s
'8 MHz/256/31250 = 1 s
'Przycisk S1 ustawia minuty, a S2 godziny
$regfile = "m8def.dat" 'informuje kompilator o pliku
'dyrektyw mikrokontrolera
$crystal = 8000000 'informuje kompilator
'o częstotliwości oscylatora
'taktującego mikrokontroler
Config Pinb.1 = Input 'linia PB1 jako wejściowa
Config Pinb.2 = Input 'linia PB2 jako wejściowa
Config Lcd = 16 * 2 'konfiguracja typu wyświetlacza
'LCD
Config Lcdpin = Pin , Db4 = Portc.3 , Db5 = Portc.2 , Db6 = Portc.1 , Db7 = Portc.0 , E = Portc.4 , Rs = Portc.5 'konfiguracja linii
'mikrokontrolera, do których
'dołączono wyświetlacz
'LCD
Config Timer1 = Timer , Prescale = 256
'konfiguracja Timer1 jako timer
'z podziałem preskalera przez
'256
Declare Sub Wysw_czas 'procedura wyświetlająca czas na
'LCD w formacie gg:mm:ss
On Timer1 Odmierz_1s 'przerwanie od przepełnienia
'Timer1 o etykiecie Odmierz_1s
Dim Sekundy As Byte 'zmienna zliczająca sekundy
Dim Minuty As Byte 'zmienna zliczająca minuty
Dim Godziny As Byte 'zmienna zliczająca godziny
Dim Nowa_w As Bit 'flaga zezwolenia aktualizacji
'czasu na LCD
Dim Wart_bcd As Byte 'zmienna pomocnicza, w której
'jest zapisywana wartość BCD
'czasu
S1 Alias Pinb.2 'przypisanie nazwie Pinb.2
'nazwy S1
S2 Alias Pinb.1 'przypisanie nazwie Pinb.1
'nazwy S2
Enable Interrupts 'odblokowanie globalnego systemu
'przerwań
Enable Timer1 'odblokowanie przerwania od
'przepełnienia Timer1
Counter1 = 34286 'wartość początkowa wpisywana do
'Timer1 (65536 - 31250 = 34286)
Set Nowa_w 'zezwolenie na wyświetlenie
'aktualnego czasu
Set Portb.1 'dołączenie do linii PB1
'rezystora podciągającego
Set Portb.2 'dołączenie do linii PB2
'rezystora podciągającego
Do 'pętla główna programu
Call Wysw_czas 'wywołanie procedury
'wyświetlającej aktualny czas
If S1 = 0 Then 'jeśli przyciśnięty S1, to
Waitms 25 'opóźnienie dla eliminacji drgań
'styków
If S1 = 0 Then 'sprawdzenie, czy przycisk S1
'dalej naciśniety, jeśli tak, to
Incr Minuty 'zwiększenie wartości minut
Sekundy = 0 'wyzerowanie zmiennej Sekundy
If Minuty = 60 Then 'jeśli wartość Minuty = 60, to
Minuty = 0 'zerowanie wartości Minuty
End If
Set Nowa_w 'zezwolenie na wyświetlenie
'czasu
Call Wysw_czas 'wywołanie procedury
'wyświetlenia aktualnego czasu
Waitms 200 'opóźnienie 200 ms
End If 'koniec instrukcji warunkowej
End If
If S2 = 0 Then 'jeśli przyciśnięty S2, to
Waitms 25 'opóźnienie dla eliminacji drgań
'styków
If S2 = 0 Then 'sprawdzenie czy przycisk S2
'dalej naciśniety, jeśli tak, to
Incr Godziny 'zwiększenie wartości Godziny
If Godziny = 24 Then 'jeśli wartość Godziny = 24, to
Godziny = 0 'wyzerowanie wartości Godziny
End If
Set Nowa_w 'zezwolenie na wyświetlenie
'czasu
Call Wysw_czas 'wywołanie procedury
'wyświetlenia aktualnego czasu
Waitms 200 'opóźnienie 200 ms
End If 'koniec instrukcji warunkowej
End If
Loop
End 'koniec programu
Sub Wysw_czas 'procedura wyświetlająca czas
If Nowa_w = 1 Then 'jeśli flaga Nowa_w = 1, to
Cls 'czyszczenie LCD
Wart_bcd = Makebcd(godziny) 'zamiana wartości Godziny na
'wartość w kodzie BCD
Lcd Bcd(wart_bcd) ; ":" 'wyświetlenie wartości godzin
'w kodzie BCD zamienionych na
'tekst oraz znaku :
Wart_bcd = Makebcd(minuty) 'zamiana wartości Minuty na
'wartość BCD
Lcd Bcd(wart_bcd) ; ":" 'wyświetlenie wartości minut
'w kodzie BCD zamienionych na
'tekst oraz znaku :
Wart_bcd = Makebcd(sekundy) 'zamiana wartości Sekundy na
'wartość w kodzie BCD
Lcd Bcd(wart_bcd) ; 'wyświetlenie wartości sekund
'w kodzie BCD zamienionych na
'tekst
Reset Nowa_w 'zerowanie flagi Nowa_w
End If
End Sub 'koniec procedury
Odmierz_1s: 'podprogramu obsługi przerwania
'przepełnienia od Timer1
Counter1 = Counter1 + 34286 'wpisanie wartości początkowej
'licznika
Incr Sekundy 'zwiększenie o 1 wartości
'Sekundy
Set Nowa_w 'zezwolenie na wyświetlenie
'czasu
If Sekundy = 60 Then 'jeśli Sekundy = 60, to
Sekundy = 0 'wyzerowanie wartości Sekundy
Incr Minuty 'zwiększenie o 1 wartości Minuty
If Minuty = 60 Then 'jeśli Minuty = 60, to
Minuty = 0 'zerowanie wartości Minuty
Incr Godziny 'zwiększenie o 1 wartości
'Godziny
If Godziny = 24 Then 'jeśli Godziny = 24, to
Godziny = 0 'zerowanie wartości Godziny
End If 'koniec warunków
End If
End If
Return 'powrót z przerwania
Za działający program dam 15 Pkt
Pozdrawiam