Updated. /JL

This commit is contained in:
Jan Lerking
2025-04-10 11:06:28 +02:00
parent cffc195128
commit 0948db2a2e
7 changed files with 63 additions and 52 deletions

View File

@@ -1,19 +0,0 @@
from microbit import *
BINÆR_DATA = {
0: "00000:", 1: "00009:", 2: "00090:", 3: "00099:", 4: "00900:", 5: "00909:",
6: "00990:", 7: "00999:", 8: "09000:", 9: "09009:", 10: "09090:", 11: "09099:",
12: "09900:", 13: "09909", 14: "09990:", 15: "09999:", 16: "90000:", 17: "90009:",
18: "90090:", 19: "90099:", 20: "90900:", 21: "90909:", 22: "90990:", 23: "90999:",
24: "99000:", 25: "99009:", 26: "99090:", 27: "99099:", 28: "99900:", 29: "99909:",
30: "99990:", 31: "99999:"
}
while True:
for b in range(32):
display.show(BINÆR_DATA[b],
"00000:"
"00000:"
"00000:"
"00000")
sleep(100) #sov 0.1 sekund

View File

@@ -1,32 +0,0 @@
from microbit import *
# Binære tal tælles altid fra 0
# Binære tal representeres med 0-ere og 1-ere - Derfor også kaldet 2-talssystem
# Binære tal læses altid fra højre mod venstre i følgende orden:
# 16-ere, 8-ere, 4-ere, 2-ere og 1-ere
# Et eksempel for værdien 13 oversat til binær
# 0 16-ere, 1 8-er, 1 4-er, 0 2-ere, 1 1-er
# | | | | |
# 0 1 1 0 1 = 01101 = 1 + 4 + 8 = 13
def get_binær(n):
# Vi starter med at formatere vores binære streng til 5 karakterer (5 led), hvilket giver n = max 31
# f.eks. hvis n er 10, bliver den binære værdi til "0b01010"
bin_format = format(n, '05b')
# Vi fjerner "0b" fra strengen
# Herved bliver strengen til "01010"
bin_nummer = bin_format[2:]
# Vi erstatter "1" med "9", og tilføjer ":" og returnerer den nye streng
# Den returnerede streng bliver "09090:"
return bin_nummer.replace("1", "9") + ":"
while True:
for b in range(32):
display.show(get_binær(b),
"00000:"
"00000:"
"00000:"
"00000")
sleep(100) #sov 0.1 sekund

View File

@@ -1,62 +0,0 @@
"""
Vi vil her lave en Matrix lignende animation, med de 25 LED.
Hvad skal vi bruge?
Random kollonne valg (0 til 4)
Random lysstyrke (1 til 9)
Random faldhastighed (1 til 10)
Hvergang der faldes, skal de eksisterende LED rykkes ned på næste linie, og en ny sættes i toppen.
Når en hel kollonne har været fyldt ud, skal der ikke længere sættes en ny LED, i toppen.
Når alle LED, i en kollonne er faldet ned, startes forfra.
Der skal holdes styr, på hver eneste LED, deres lysstyrke, faldhastighed, og om de er faldet ud.
"""
from microbit import *
from collections import deque
kol_1 = [0, 0, 0, 0, 0]
kol_2 = [0, 0, 0, 0, 0]
kol_3 = [0, 0, 0, 0, 0]
kol_4 = [0, 0, 0, 0, 0]
kol_5 = [0, 0, 0, 0, 0]
d_kol_1 = deque(kol_1)
d_kol_2 = deque(kol_2)
d_kol_3 = deque(kol_3)
d_kol_4 = deque(kol_4)
d_kol_5 = deque(kol_5)
matrix = {1: d_kol_1, 2: d_kol_2, 3: d_kol_3, 4: d_kol_4, 5: d_kol_5}
# Hver LED representation, skal kun holde styr på sig selv.
class LED:
def __init__(self, kol, lys, hast):
self.kol = []
self.i_live = True # Vi starter med at være i live.
self.række = 0 # Vi starter på øverste række.
self.kollonne = kol # Vi ved hvilken kollonne vi er i.
self.lys = lys # Vi sætter vores lysstyrke.
self.hastighed = hast # Vi falder med en konstant hastighed.
self.vis_led() # Tænd led
def fald(self):
self.række += 1 # Ryk til næste række
self.lys -= 1
if self.række > 4:
self.i_live = False
else:
self.vis_led()
self.matrix.ny_led(self.kol, self.lys, self.hastighed)
def vis_led(self):
display.set_pixel(self.kollonne, self.række, self.lys)
while True:
kol = random(1, 5)
lys = random(5, 9)
hast = random(1, 10)
for k in matrix:
matrix[k].pop()
matrix[k].appendleft(0)

View File

@@ -1,16 +0,0 @@
from collections import deque
from time import sleep
kol = [0] * 5
d_kol = deque(kol)
test = True
while test == True:
d_kol.pop()
d_kol.appendleft(1)
print(d_kol)
sleep(0.5)
for i in range(5):
test = False
if d_kol[i] == 0:
test = True