Initial tries to support different screen configurations.

master
Raphaël Vinot 2015-05-10 03:39:20 +02:00
parent 761a191da6
commit e2df6a69ef
3 changed files with 102 additions and 38 deletions

View File

@ -4,10 +4,10 @@ from prepare import prepare
import random import random
# Config, will be checked upstream # Config, will be checked upstream
height = 25 height = 15
width = 15 width = 25
framerate = 10 framerate = 30
brightness = 0.5 brightness = 1
##################################### #####################################
#receiver_IP = "10.2.113.151" #receiver_IP = "10.2.113.151"
#receiver_IP = "10.24.147.20" #receiver_IP = "10.24.147.20"
@ -15,7 +15,9 @@ receiver_IP = "dummy"
receiver_port = 9999 receiver_port = 9999
# Do we have one single long line? # Do we have one single long line?
long_line = True long_line = False
# Type of installation (see details in data_generator)
type = 2
# TODO: test with real serial # TODO: test with real serial
# https://www.pjrc.com/teensy/td_uart.html # https://www.pjrc.com/teensy/td_uart.html
@ -38,23 +40,22 @@ def setup():
cur_color = color(random.randint(0, 255), random.randint(0, 255), random.randint(0, 255)) cur_color = color(random.randint(0, 255), random.randint(0, 255), random.randint(0, 255))
ledTCP, data = prepare(Client, receiver_IP, receiver_port, height, width, framerate, brightness) ledTCP, data = prepare(Client, receiver_IP, receiver_port, height, width, framerate, brightness)
send_TCP(ledTCP, data, long_line) send_TCP(ledTCP, data, long_line, type)
def draw(): def draw():
global cur_len global cur_len
global current_px global current_px
global cur_color global cur_color
global len_change global len_change
if cur_len == 0:
pixels[current_px] = cur_color pixels[current_px] = cur_color
else: px = current_px - 1
px = current_px for i in range(cur_len + 1):
for i in range(cur_len):
if px == 0: if px == 0:
prec_col = pixels[len(pixels) - 1] col = pixels[len(pixels) -1]
else: else:
prec_col = pixels[px - 1] col = pixels[px]
col = color(red(prec_col) / 1.1, green(prec_col) / 1.1, blue(prec_col) / 1.1) if i == cur_len:
col = color(red(col) * 0.9, green(col) * 0.9, blue(col) * 0.9)
pixels[px] = col pixels[px] = col
px -=1 px -=1
updatePixels() updatePixels()
@ -69,4 +70,4 @@ def draw():
current_px = 0 current_px = 0
else: else:
current_px += 1 current_px += 1
send_TCP(ledTCP, data, long_line) send_TCP(ledTCP, data, long_line, type)

View File

@ -47,16 +47,80 @@ def prepare_data(dimension, b):
data = jarray.zeros(dimension * 24 + 1, "b") data = jarray.zeros(dimension * 24 + 1, "b")
return data return data
def image2data(data, long_line): '''
Possibilities:
Start: Top left / Top Right / Bottom Left / Bottom Right
Direction: Up / Down / Right / Left
'''
def make_line(type, nb, long_line):
'''
If moving up or down: 0 <= nb <= height
If moving right or left: 0 <= nb <= width
'''
indexes = []
if type == 0:
# top left -> down / OK
pxstart = nb
for h in range(height):
indexes.append(pxstart + width * h)
elif type == 1:
# top left -> right / OK
pxstart = nb * width
for w in range((width)):
indexes.append(pxstart + w)
elif type == 2:
# bottom left -> up / OK
pxstart = width * (height - 1) + nb
for h in range(height):
indexes.append(pxstart - width * h)
elif type == 3:
# bottom left -> right / OK
pxstart = width * (height - 1) - nb * width
for w in range((width)):
indexes.append(pxstart + w)
elif type == 4:
# top right -> down / OK
pxstart = width - 1 - nb
for h in range(height):
indexes.append(pxstart + width * h)
elif type == 5:
# top right -> left / OK
pxstart = width - 1 + nb * width
for w in range((width)):
indexes.append(pxstart - w)
elif type == 6:
# bottom right -> up / OK
pxstart = width * height - 1 - nb * height
for h in range(height):
indexes.append(pxstart - width * h)
elif type == 7:
# bottom right -> left / OK
pxstart = width * height - 1 - nb * width
for w in range((width)):
indexes.append(pxstart - w)
else:
raise Exception("Invalid Type")
if long_line and nb % 2 == 1:
return reversed([pixels[px] for px in indexes])
return [pixels[px] for px in indexes]
def image2data(data, type, long_line):
offset = 0 offset = 0
pixel_nb = 0
loadPixels() loadPixels()
inline_image = []
if type in [0, 2, 4, 6]:
# Organized up or down
for x in range(0, width):
inline_image += make_line(type, x, long_line)
elif type in [1, 3, 5, 7]:
# Organized left or right
for x in range(0, height): for x in range(0, height):
pixel_line = pixels[pixel_nb:pixel_nb+width] inline_image += make_line(type, x, long_line)
if long_line and pixel_nb/width%2 == 1: for img_px in inline_image:
pixel_line = reversed(pixel_line) py_bytes = _encode_pixel(img_px)
for px in pixel_line:
py_bytes = _encode_pixel(px)
for b in py_bytes: for b in py_bytes:
if b > 127: if b > 127:
# Convert to signed bytes (expected by jarray) # Convert to signed bytes (expected by jarray)
@ -65,7 +129,6 @@ def image2data(data, long_line):
else: else:
data[offset] = b data[offset] = b
offset += 1 offset += 1
pixel_nb +=1
# New line # New line
data[-1] = 10 data[-1] = 10
return data return data

View File

@ -28,9 +28,9 @@ def send_config(socket, height, width, framerate):
socket.write(struct.pack('<i', width)) socket.write(struct.pack('<i', width))
socket.write(struct.pack('<i', framerate)) socket.write(struct.pack('<i', framerate))
def send_TCP(socket, data, long_line): def send_TCP(socket, data, long_line, type):
if socket is None: if socket is None:
# Dummy mode # Dummy mode
return return
image2data(data, long_line) image2data(data, type, long_line)
socket.write(data) socket.write(data)