1
0
mirror of https://github.com/sehugg/8bitworkshop.git synced 2025-01-15 04:30:15 +00:00
8bitworkshop/tools/p4_to_pfbytes.py

61 lines
1.6 KiB
Python
Raw Normal View History

2016-12-27 15:17:47 -05:00
#!/usr/bin/python
import sys, struct
# playfield bytes, one array for each of 6 columns
output = [[],[],[],[],[],[]]
# reverse byte
def rev(n):
return int('{:08b}'.format(n)[::-1], 2)
# output bits in given range
def out(i, pix, lb, hb, reverse=0, shift=0):
x = (pix >> lb) & ((1<<(hb-lb))-1)
if reverse:
x = rev(x)
if shift:
x = x << shift
assert(x>=0 and x<=255)
output[i].append(x)
# read PBM (binary P4 format) file
with open(sys.argv[1],'rb') as f:
# read PBM header
header = f.readline().strip()
2018-11-22 14:11:56 -05:00
assert(header == b'P4')
2016-12-27 15:17:47 -05:00
dims = f.readline().strip()
2018-11-22 14:11:56 -05:00
if dims[0:1] == b'#':
2016-12-27 15:17:47 -05:00
dims = f.readline().strip()
2018-11-22 14:11:56 -05:00
print(dims)
width,height = list(map(int, dims.split()))
2016-12-27 15:17:47 -05:00
assert(width==40)
# read bitmap rows
for y in range(0,height):
2018-11-22 14:11:56 -05:00
row = bytes(f.read(5) + b'\0\0\0') # pad to 8 bytes
2016-12-27 15:17:47 -05:00
# convert bytes from MSB first to LSB first
2018-11-22 14:11:56 -05:00
row2 = []
2016-12-27 15:17:47 -05:00
for i in range(0,8):
2018-11-22 14:11:56 -05:00
row2.append(rev(row[i]))
2016-12-27 15:17:47 -05:00
# convert to 64-bit integer
2018-11-22 14:11:56 -05:00
pix = struct.unpack('<q',bytes(row2))[0]
2016-12-27 15:17:47 -05:00
# generate playfield bytes
out(0, pix, 0, 4, 0, 4)
out(1, pix, 4, 12, 1)
out(2, pix, 12, 20, 0)
out(3, pix, 20, 24, 0, 4)
out(4, pix, 24, 32, 1)
out(5, pix, 32, 40, 0)
# output bitmap tables
for c in range(0,6):
2018-11-22 14:11:56 -05:00
print(("PFBitmap%d" % c))
2016-12-27 15:17:47 -05:00
s = '\thex '
for i in range(0,height):
s += '%02x' % output[c][height-i-1]
if i % 16 == 15:
2018-11-22 14:11:56 -05:00
print(s)
2016-12-27 15:17:47 -05:00
s = '\thex '
if len(s)>5:
2018-11-22 14:11:56 -05:00
print(s)