improve sender class and cleanup code. change bitorder

This commit is contained in:
interfisch 2018-01-13 19:11:17 +01:00
parent a953156059
commit 9519e9b876
3 changed files with 16 additions and 51 deletions

View File

@ -18,7 +18,6 @@ class MatrixSender(object):
global threadrunning global threadrunning
threadrunning=False threadrunning=False
def __init__(self, udphost, udpport, img_size=(160,48), bitsperpixel=1): def __init__(self, udphost, udpport, img_size=(160,48), bitsperpixel=1):
self._udphost = udphost self._udphost = udphost
@ -31,58 +30,21 @@ class MatrixSender(object):
self._sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) self._sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
def send(self, image,invert=False):
def _list2byte(self, l):
byte = 0
i = 0
for i in range(8):
byte += 2**(7-i) if l[i] else 0
return byte
def _array2packet(self, a):
return [self._list2byte(a[i*8:i*8+8]) for i in range(int(len(a)/8))]
def _intToBitlist(self,number): #convert integer number to list of bits, exampe: 1-> [0,1], 2->[1,0]
bitlistvaryinglength=[x for x in "{0:b}".format(number)]
bitlist=np.zeros(self.bitsperpixel,dtype=int)
bitlist[self.bitsperpixel-len(bitlistvaryinglength):]=bitlistvaryinglength
return bitlist
def send(self, image,invert=False): #changes slowly 'fadespeed'-pixels at a time
global threadrunning global threadrunning
imgmap = [] imgmap = []
sendbyte=0
senddata=bytearray()
pixelofbyte=0
for pixel in image.getdata(): for pixel in image.getdata():
r, g, b, a = pixel r, g, b, a = pixel
pixelbrightness=int( (r+g+b)/3 *(pow(2,self.bitsperpixel)-1) /255 +0.5) pixelbrightness=int( (r+g+b)/3 *(pow(2,self.bitsperpixel)-1) /255 +0.5)
sendbyte+=pixelbrightness<<(pixelofbyte*self.bitsperpixel)
pixelofbyte+=1
if pixelofbyte>=(8/self.bitsperpixel):
pixelofbyte=0
senddata.append(sendbyte)
sendbyte=0
if invert: self._sock.sendto(bytes(senddata), (self._udphost, self._udpport))
pixelbrightness=pow(2,self.bitsperpixel)-1-pixelbrightness
for b in self._intToBitlist(pixelbrightness):
imgmap.append(b)
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))
def send_bytes(self, img):
imgmap = []
for pixel in img:
if pixel == "1":
imgmap.append(1)
else:
imgmap.append(0)
if len(img) < 1280:
imgmap = np.hstack((imgmap, np.zeros(1280-len(img), dtype=int)))
packet = self._array2packet(imgmap)
self._sock.sendto(bytes(packet), (self._udphost, self._udpport))

View File

@ -94,7 +94,7 @@ class FlipdotMatrixSimulatorWidget():
def showFromRawData(self, rawData): def showFromRawData(self, rawData):
x=0 #pixel x position x=0 #pixel x position
y=0 #pixel y position y=0 #pixel y position
bitshifts=[x*self.bitsperpixel for x in reversed(range(int(8/self.bitsperpixel)))] bitshifts=[x*self.bitsperpixel for x in range(int(8/self.bitsperpixel))]
bitmask=int('00000011', 2) bitmask=int('00000011', 2)
for cbyte in rawData: for cbyte in rawData:

View File

@ -34,7 +34,10 @@ if __name__ == '__main__':
#draw ball #draw ball
draw.ellipse((ball_pos[0]-ball_size/2,ball_pos[1]-ball_size/2,ball_pos[0]+ball_size/2,ball_pos[1]+ball_size/2,),fill=(255,255,255)) draw.ellipse((ball_pos[0]-ball_size/2,ball_pos[1]-ball_size/2,ball_pos[0]+ball_size/2,ball_pos[1]+ball_size/2,),fill=(255,255,255))
_time_startsending=time.time()
matrix.send(im) #construct udp packet and send to matrix matrix.send(im) #construct udp packet and send to matrix
_time_endsending=time.time()
print("Sendtime="+str(round(_time_endsending-_time_startsending,4))+"s, FPS="+str(round(1/(_time_endsending-_time_startsending),2)))
time.sleep(.1) #wait time.sleep(.1) #wait