viele aenderungen vom fisch
This commit is contained in:
parent
be69a44dfe
commit
174ac4c363
3 changed files with 128 additions and 19 deletions
|
@ -15,8 +15,10 @@ class FlipdotSender(object):
|
||||||
C_BLACK = 0
|
C_BLACK = 0
|
||||||
C_WHITE = 255
|
C_WHITE = 255
|
||||||
|
|
||||||
|
lastimgmap = []
|
||||||
|
|
||||||
def __init__(self, udphost, udpport, img_size=(80,16), font_size=8, font_size_scroll=12,
|
def __init__(self, udphost, udpport, img_size=(80,16), font_size=8, font_size_scroll=12,
|
||||||
font_offset1=(0,-1), font_offset2=(0,7),
|
font_offset1=(0,0), font_offset2=(0,8),
|
||||||
#font_family='/usr/share/fonts/gnu-free/FreeMono.ttf',
|
#font_family='/usr/share/fonts/gnu-free/FreeMono.ttf',
|
||||||
font_family='/usr/share/fonts/truetype/ttf-dejavu/DejaVuSansMono.ttf',
|
font_family='/usr/share/fonts/truetype/ttf-dejavu/DejaVuSansMono.ttf',
|
||||||
#font_family='/usr/share/fonts/truetype/freefont/FreeMono.ttf',
|
#font_family='/usr/share/fonts/truetype/freefont/FreeMono.ttf',
|
||||||
|
@ -51,8 +53,8 @@ class FlipdotSender(object):
|
||||||
def _array2packet(self, a):
|
def _array2packet(self, a):
|
||||||
return [self._list2byte(a[i*8:i*8+8]) for i in range(int(len(a)/8))]
|
return [self._list2byte(a[i*8:i*8+8]) for i in range(int(len(a)/8))]
|
||||||
|
|
||||||
|
'''
|
||||||
def _send(self, image):
|
def _send(self, image): #old function, backup
|
||||||
imgmap = []
|
imgmap = []
|
||||||
for pixel in image.getdata():
|
for pixel in image.getdata():
|
||||||
r, g, b, a = pixel
|
r, g, b, a = pixel
|
||||||
|
@ -61,9 +63,44 @@ class FlipdotSender(object):
|
||||||
else:
|
else:
|
||||||
imgmap.append(0)
|
imgmap.append(0)
|
||||||
|
|
||||||
|
lastimgmap=imgmap
|
||||||
|
|
||||||
packet = self._array2packet(imgmap)
|
packet = self._array2packet(imgmap)
|
||||||
|
|
||||||
|
self._sock.sendto(bytes(packet), (self._udphost, self._udpport))'''
|
||||||
|
|
||||||
|
def _send(self, image,fadespeed=0): #changes slowly 'fadespeed'-pixels at a time
|
||||||
|
#if fadespeed=0 -> change instant.
|
||||||
|
#time to change= 1280/25*0.2
|
||||||
|
imgmap = []
|
||||||
|
for pixel in image.getdata():
|
||||||
|
r, g, b, a = pixel
|
||||||
|
if r == FlipdotSender.C_WHITE:
|
||||||
|
imgmap.append(1)
|
||||||
|
else:
|
||||||
|
imgmap.append(0)
|
||||||
|
|
||||||
|
imgmaptmp=FlipdotSender.lastimgmap
|
||||||
|
|
||||||
|
if fadespeed>0:
|
||||||
|
#diff=np.sum(np.array(imgmaptmp) != np.array(imgmap)) #different pixels
|
||||||
|
pixelchangeind=np.arange(self._img_size[0]*self._img_size[1])
|
||||||
|
np.random.shuffle(pixelchangeind)
|
||||||
|
for _i,ind in enumerate(pixelchangeind):
|
||||||
|
if ind<len(imgmaptmp): #imgmaptmp is not empty (normally at first run)
|
||||||
|
imgmaptmp[ind]=imgmap[ind]
|
||||||
|
if _i%fadespeed==0:
|
||||||
|
packet = self._array2packet(imgmaptmp)
|
||||||
self._sock.sendto(bytes(packet), (self._udphost, self._udpport))
|
self._sock.sendto(bytes(packet), (self._udphost, self._udpport))
|
||||||
|
time.sleep(0.2)
|
||||||
|
|
||||||
|
self.sendPacket(imgmap) #send packet and save last-imagemap
|
||||||
|
|
||||||
|
def sendPacket(self, imgmap):
|
||||||
|
packet = self._array2packet(imgmap)
|
||||||
|
self._sock.sendto(bytes(packet), (self._udphost, self._udpport))
|
||||||
|
|
||||||
|
FlipdotSender.lastimgmap=imgmap
|
||||||
|
|
||||||
def send_bytes(self, img):
|
def send_bytes(self, img):
|
||||||
imgmap = []
|
imgmap = []
|
||||||
|
@ -81,7 +118,7 @@ class FlipdotSender(object):
|
||||||
self._sock.sendto(bytes(packet), (self._udphost, self._udpport))
|
self._sock.sendto(bytes(packet), (self._udphost, self._udpport))
|
||||||
|
|
||||||
|
|
||||||
def send_text(self, text):
|
def send_text(self, text,fadespeed=0):
|
||||||
image = Image.new("RGBA", self._img_size, FlipdotSender.C_BLACK)
|
image = Image.new("RGBA", self._img_size, FlipdotSender.C_BLACK)
|
||||||
draw = ImageDraw.Draw(image)
|
draw = ImageDraw.Draw(image)
|
||||||
draw.fontmode = "1" # No AA
|
draw.fontmode = "1" # No AA
|
||||||
|
@ -96,7 +133,37 @@ class FlipdotSender(object):
|
||||||
if len(splitted_text)>1:
|
if len(splitted_text)>1:
|
||||||
draw.text(self._font_offset2, splitted_text[1], font=font, fill=FlipdotSender.C_WHITE)
|
draw.text(self._font_offset2, splitted_text[1], font=font, fill=FlipdotSender.C_WHITE)
|
||||||
|
|
||||||
self._send(image)
|
self._send(image,fadespeed)
|
||||||
|
|
||||||
|
def send_textFull(self, text,fadespeed=0):
|
||||||
|
image = Image.new("RGBA", self._img_size, FlipdotSender.C_BLACK)
|
||||||
|
draw = ImageDraw.Draw(image)
|
||||||
|
draw.fontmode = "1" # No AA
|
||||||
|
|
||||||
|
l=1000 #init very high
|
||||||
|
splitpoint=40 #very high
|
||||||
|
currentfontsize=12+1 #init with max font size
|
||||||
|
font = ImageFont.truetype(self._font_family, currentfontsize)
|
||||||
|
|
||||||
|
while(l>80): #while text too long and font not too small
|
||||||
|
if currentfontsize>8:
|
||||||
|
currentfontsize=currentfontsize-1 #reduce size and try if fits
|
||||||
|
else: #if fontsize too small, try cutting sentence (2 lines)
|
||||||
|
splitpoint=splitpoint-1
|
||||||
|
|
||||||
|
font = ImageFont.truetype(self._font_family, currentfontsize)
|
||||||
|
l=draw.textsize(text[0:splitpoint], font=font)[0]
|
||||||
|
print("Textlength="+str(l)+" split="+str(splitpoint))
|
||||||
|
|
||||||
|
if splitpoint==40: #not splitted
|
||||||
|
draw.text((0,int((16-currentfontsize)/2) ), text, font=font, fill=FlipdotSender.C_WHITE)
|
||||||
|
else:
|
||||||
|
draw.text((0,-1), text[0:splitpoint], font=font, fill=FlipdotSender.C_WHITE)
|
||||||
|
draw.text((0,-1+currentfontsize), text[splitpoint:], font=font, fill=FlipdotSender.C_WHITE)
|
||||||
|
|
||||||
|
|
||||||
|
self._send(image,fadespeed)
|
||||||
|
|
||||||
|
|
||||||
def send_marquee(self, str, speed=3):
|
def send_marquee(self, str, speed=3):
|
||||||
offset = self._img_size[0]
|
offset = self._img_size[0]
|
||||||
|
|
37
hangman.py
37
hangman.py
|
@ -3,7 +3,7 @@ from PIL import Image, ImageFont, ImageDraw
|
||||||
import sys, os
|
import sys, os
|
||||||
import fileinput
|
import fileinput
|
||||||
from random import randint
|
from random import randint
|
||||||
|
from FlipdotSender import FlipdotSender
|
||||||
|
|
||||||
class Hangman(object):
|
class Hangman(object):
|
||||||
'''
|
'''
|
||||||
|
@ -17,6 +17,7 @@ class Hangman(object):
|
||||||
global C_HM
|
global C_HM
|
||||||
global FPS
|
global FPS
|
||||||
global FONT_SIZE_word
|
global FONT_SIZE_word
|
||||||
|
global G_ALLOWNUMERIC
|
||||||
|
|
||||||
C_BLACK = 0
|
C_BLACK = 0
|
||||||
C_WHITE = 255
|
C_WHITE = 255
|
||||||
|
@ -25,12 +26,13 @@ class Hangman(object):
|
||||||
C_HM=C_TEXT
|
C_HM=C_TEXT
|
||||||
FPS=2
|
FPS=2
|
||||||
FONT_SIZE_word=9 #was 9
|
FONT_SIZE_word=9 #was 9
|
||||||
|
G_ALLOWNUMERIC=True
|
||||||
|
|
||||||
#hangman/alterebro-pixel-font.ttf size=14, -2 and 6
|
#hangman/alterebro-pixel-font.ttf size=14, -2 and 6
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def __init__(self, udphost, udpport, img_size=(80,16)):
|
def __init__(self, udphost, udpport, pflipdot=None,img_size=(80,16)):
|
||||||
'''
|
'''
|
||||||
Constructor
|
Constructor
|
||||||
'''
|
'''
|
||||||
|
@ -39,11 +41,14 @@ class Hangman(object):
|
||||||
if not type(udpport) is int or udpport > 65536:
|
if not type(udpport) is int or udpport > 65536:
|
||||||
raise TypeError('port has to be int and > 65536 !!')
|
raise TypeError('port has to be int and > 65536 !!')
|
||||||
self._udpport = udpport
|
self._udpport = udpport
|
||||||
|
self._flipdot=pflipdot
|
||||||
|
|
||||||
self._img_size = img_size
|
self._img_size = img_size
|
||||||
self._fo_word= (15, -1) #(15, -1)
|
self._fo_word= (15, -1) #(15, -1)
|
||||||
self._fo_word2= (15, 7) #(15,7)
|
self._fo_word2= (15, 7) #(15,7)
|
||||||
#self._wordlist="/home/pi/mqtt-to-flipdot/hangman/nomenliste_de.txt"
|
#self._wordlist="/home/pi/mqtt-to-flipdot/hangman/nomenliste_de.txt"
|
||||||
self._wordlist="/home/pi/mqtt-to-flipdot/hangman/crodict_nomen.txt"
|
#self._wordlist="/home/pi/mqtt-to-flipdot/hangman/crodict_nomen.txt"
|
||||||
|
self._wordlist="/home/pi/mqtt-to-flipdot/hangman/nerdwords.txt"
|
||||||
self._gamestate=0# 0=start 1=ingame 2=lose 3=win
|
self._gamestate=0# 0=start 1=ingame 2=lose 3=win
|
||||||
self._g_word="test" #word
|
self._g_word="test" #word
|
||||||
self._g_displword="" #display word
|
self._g_displword="" #display word
|
||||||
|
@ -64,9 +69,10 @@ class Hangman(object):
|
||||||
self._maxwlen=26
|
self._maxwlen=26
|
||||||
|
|
||||||
self._words=[]
|
self._words=[]
|
||||||
fobj = open(self._wordlist)
|
fobj = open(self._wordlist, encoding="utf-8")
|
||||||
for line in fobj:
|
for line in fobj:
|
||||||
string=line.rstrip()
|
string=line.rstrip().upper() #remove whitespaces and make uppercase
|
||||||
|
string=string.replace(" ","+") #if using another replacement, also change in validateWord and generateDisplayWord
|
||||||
if (self._validateWord(string)==1):
|
if (self._validateWord(string)==1):
|
||||||
if (len(string)>=self._minwlen and len(string)<=self._maxwlen):
|
if (len(string)>=self._minwlen and len(string)<=self._maxwlen):
|
||||||
self._words.append(string)
|
self._words.append(string)
|
||||||
|
@ -83,7 +89,8 @@ class Hangman(object):
|
||||||
self._g_chars=""
|
self._g_chars=""
|
||||||
self._generateDisplword()
|
self._generateDisplword()
|
||||||
self._g_gamestate=1
|
self._g_gamestate=1
|
||||||
self._sock.sendto(bytes(self._array2packet(self._draw())), (self._udphost, self._udpport))
|
self._sendPacket(self._draw())
|
||||||
|
#self._sock.sendto(bytes(self._array2packet(self._draw())), (self._udphost, self._udpport))
|
||||||
|
|
||||||
|
|
||||||
def _list2byte(self, l):
|
def _list2byte(self, l):
|
||||||
|
@ -118,6 +125,8 @@ class Hangman(object):
|
||||||
a=s
|
a=s
|
||||||
elif (oc>=48 and oc<=57 and G_ALLOWNUMERIC==1):#0-9
|
elif (oc>=48 and oc<=57 and G_ALLOWNUMERIC==1):#0-9
|
||||||
a=s
|
a=s
|
||||||
|
elif (s[c]=="-" or s[c]==" " or s[c]=="+"):#or - or whitespace (will be given characters)
|
||||||
|
a=s
|
||||||
else:
|
else:
|
||||||
return 0
|
return 0
|
||||||
return 1
|
return 1
|
||||||
|
@ -132,11 +141,13 @@ class Hangman(object):
|
||||||
for c in range(0,len(self._g_chars)):
|
for c in range(0,len(self._g_chars)):
|
||||||
if cha.lower()==self._g_chars[c]: #if current char is opened
|
if cha.lower()==self._g_chars[c]: #if current char is opened
|
||||||
show=1
|
show=1
|
||||||
|
if cha==" " or cha=="-" or cha=="+": #show spaces and - and _
|
||||||
|
show=1
|
||||||
|
|
||||||
if show==1: #if character cha is opened
|
if show==1: #if character cha is opened
|
||||||
self._g_displword+=cha #show
|
self._g_displword+=cha #show
|
||||||
else:
|
else:
|
||||||
self._g_displword+="-" #do not show
|
self._g_displword+="'" #do not show
|
||||||
|
|
||||||
def _countFails(self):
|
def _countFails(self):
|
||||||
fails=0
|
fails=0
|
||||||
|
@ -257,6 +268,12 @@ class Hangman(object):
|
||||||
def _drawWinScreen(self,draw):
|
def _drawWinScreen(self,draw):
|
||||||
self._drawGameScreen(draw)
|
self._drawGameScreen(draw)
|
||||||
|
|
||||||
|
def _sendPacket(self,imgmap):
|
||||||
|
if self._flipdot is not None:
|
||||||
|
self._flipdot.sendPacket(imgmap)
|
||||||
|
else:
|
||||||
|
self._sock.sendto(bytes(self._array2packet(imgmap)), (self._udphost, self._udpport))
|
||||||
|
|
||||||
|
|
||||||
def step(self,strinput): #returns 0 if game ended
|
def step(self,strinput): #returns 0 if game ended
|
||||||
|
|
||||||
|
@ -272,7 +289,7 @@ class Hangman(object):
|
||||||
|
|
||||||
|
|
||||||
#draw() #test
|
#draw() #test
|
||||||
self._sock.sendto(bytes(self._array2packet(self._draw())), (self._udphost, self._udpport))
|
self._sendPacket(self._draw())
|
||||||
print("Display:"+self._g_displword)
|
print("Display:"+self._g_displword)
|
||||||
print("Used:"+self._g_chars)
|
print("Used:"+self._g_chars)
|
||||||
print("fails:"+str(self._countFails()))
|
print("fails:"+str(self._countFails()))
|
||||||
|
@ -284,14 +301,14 @@ class Hangman(object):
|
||||||
#C_TEXT=C_BG #invert text
|
#C_TEXT=C_BG #invert text
|
||||||
#C_BG=c_t #invert text
|
#C_BG=c_t #invert text
|
||||||
self._g_displword=self._g_word
|
self._g_displword=self._g_word
|
||||||
self._sock.sendto(bytes(self._array2packet(self._draw())), (self._udphost, self._udpport))
|
self._sendPacket(self._draw())
|
||||||
print("verloren, das Wort war:"+self._g_word)
|
print("verloren, das Wort war:"+self._g_word)
|
||||||
self._g_gamestate=0
|
self._g_gamestate=0
|
||||||
return 2
|
return 2
|
||||||
|
|
||||||
|
|
||||||
elif self._g_gamestate==3:
|
elif self._g_gamestate==3:
|
||||||
self._sock.sendto(bytes(self._array2packet(self._draw())), (self._udphost, self._udpport))
|
self._sendPacket(self._draw())
|
||||||
print("gewonnen")
|
print("gewonnen")
|
||||||
self._g_gamestate=0
|
self._g_gamestate=0
|
||||||
return 3
|
return 3
|
||||||
|
|
|
@ -7,6 +7,8 @@ from hangman import Hangman
|
||||||
|
|
||||||
global mode
|
global mode
|
||||||
mode="standby"
|
mode="standby"
|
||||||
|
global gametimeout
|
||||||
|
gametimeout=0
|
||||||
|
|
||||||
def on_connect(client, userdata, flags, rc):
|
def on_connect(client, userdata, flags, rc):
|
||||||
print("Connected with result code " + str(rc))
|
print("Connected with result code " + str(rc))
|
||||||
|
@ -19,13 +21,15 @@ def on_connect(client, userdata, flags, rc):
|
||||||
def on_message(client, userdata, msg):
|
def on_message(client, userdata, msg):
|
||||||
print(msg.topic + " " + str(msg.payload.decode("utf-8")))
|
print(msg.topic + " " + str(msg.payload.decode("utf-8")))
|
||||||
global mode
|
global mode
|
||||||
|
global gametimeout
|
||||||
|
|
||||||
if mode=="standby":
|
if mode=="standby":
|
||||||
|
gametimeout=0
|
||||||
|
|
||||||
if msg.topic == "raum2/flipdot/scroll/set":
|
if msg.topic == "raum2/flipdot/scroll/set":
|
||||||
payload = msg.payload.decode("utf-8")
|
payload = msg.payload.decode("utf-8")
|
||||||
|
|
||||||
if (payload[0]).isdigit():
|
if len(payload)>0 and (payload[0]).isdigit():
|
||||||
speed = int(payload[0])
|
speed = int(payload[0])
|
||||||
text = payload[1:]
|
text = payload[1:]
|
||||||
else:
|
else:
|
||||||
|
@ -35,7 +39,18 @@ def on_message(client, userdata, msg):
|
||||||
flipdot.send_marquee(text, speed)
|
flipdot.send_marquee(text, speed)
|
||||||
if msg.topic == "raum2/flipdot/text/set":
|
if msg.topic == "raum2/flipdot/text/set":
|
||||||
payload = msg.payload.decode("utf-8")
|
payload = msg.payload.decode("utf-8")
|
||||||
flipdot.send_text(payload)
|
|
||||||
|
if len(payload)>0 and payload[0]=='~':
|
||||||
|
payload=payload[1:] #remove first char
|
||||||
|
flipdot.send_text(payload,25) #send_text with animation
|
||||||
|
flipdot.send_text(payload) #without animation
|
||||||
|
|
||||||
|
if msg.topic == "raum2/flipdot/textFull/set":
|
||||||
|
payload = msg.payload.decode("utf-8")
|
||||||
|
if len(payload)>0 and payload[0]=='~':
|
||||||
|
payload=payload[1:]
|
||||||
|
flipdot.send_textFull(payload,50)
|
||||||
|
flipdot.send_textFull(payload)
|
||||||
|
|
||||||
if msg.topic == "raum2/flipdot/image/set":
|
if msg.topic == "raum2/flipdot/image/set":
|
||||||
payload = msg.payload.decode("utf-8")
|
payload = msg.payload.decode("utf-8")
|
||||||
|
@ -49,12 +64,15 @@ def on_message(client, userdata, msg):
|
||||||
|
|
||||||
if payload=="#start":
|
if payload=="#start":
|
||||||
hangman.setup()
|
hangman.setup()
|
||||||
|
gametimeout=int(round(time.time() * 1000))
|
||||||
client.publish("raum2/flipdot/hangman","started")
|
client.publish("raum2/flipdot/hangman","started")
|
||||||
mode="hangman"
|
mode="hangman"
|
||||||
|
|
||||||
elif (mode=="hangman") and (len(payload)>0): #try entered character
|
elif (mode=="hangman") and (len(payload)>0): #try entered character
|
||||||
|
gametimeout=int(round(time.time() * 1000))
|
||||||
trychar=payload[-1]
|
trychar=payload[-1]
|
||||||
gamestatus=hangman.step(trychar)
|
gamestatus=hangman.step(trychar)
|
||||||
|
client.publish("raum2/flipdot/hangman","char="+trychar.upper())
|
||||||
if gamestatus!=1: #game has ended
|
if gamestatus!=1: #game has ended
|
||||||
mode="standby"
|
mode="standby"
|
||||||
if gamestatus==2: #gameover
|
if gamestatus==2: #gameover
|
||||||
|
@ -72,7 +90,7 @@ def on_message(client, userdata, msg):
|
||||||
|
|
||||||
|
|
||||||
flipdot = FlipdotSender("2001:67c:275c:a9::c", 2323)
|
flipdot = FlipdotSender("2001:67c:275c:a9::c", 2323)
|
||||||
hangman= Hangman("2001:67c:275c:a9::c", 2323)
|
hangman= Hangman("2001:67c:275c:a9::c", 2323,flipdot)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -84,6 +102,13 @@ client.loop_start()
|
||||||
|
|
||||||
|
|
||||||
while True:
|
while True:
|
||||||
|
millis = int(round(time.time() * 1000))
|
||||||
|
if gametimeout!=0:
|
||||||
|
if millis-120000 > gametimeout: #timeout
|
||||||
|
print("Game Timeout")
|
||||||
|
mode="standby"
|
||||||
|
gametimeout=0
|
||||||
|
|
||||||
time.sleep(2)
|
time.sleep(2)
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue