forked from chezsick/MyGist
-
Notifications
You must be signed in to change notification settings - Fork 1
/
map2file.py
executable file
·37 lines (28 loc) · 3.13 KB
/
map2file.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
import sys
import math
def coordinate2position(c,b):
xb = format(c[0],"0"+str(b)+"b")
yb = format(c[1],"0"+str(b)+"b")
g = ""
for n in range(b):
g = g + yb[n] + xb[n]
return int(g,2)
col = ["000000","560000","640000","750000","870000","9b0000","b00000","c60000","dd0000","f50000","ff0f0f","ff2828","ff4343","ff5e5e","ff7979","fe9595","4c1600","561900","641e00","752300","872800","9b2e00","b03400","c63b00","dd4200","f54900","ff570f","ff6928","ff7b43","ff8e5e","ffa179","feb595","4c3900","564000","644b00","755700","876500","9b7400","b08400","c69400","dda600","f5b800","ffc30f","ffc928","ffd043","ffd65e","ffdd79","fee495","4c4c00","565600","646400","757500","878700","9b9b00","b0b000","c6c600","dddd00","f5f500","ffff0f","ffff28","ffff43","ffff5e","ffff79","fffe95","324c00","395600","426400","4e7500","5a8700","679b00","75b000","84c600","93dd00","a3f500","afff0f","b7ff28","c0ff43","c9ff5e","d2ff79","dbfe95","1f4c00","235600","296400","307500","388700","409b00","49b000","52c600","5cdd00","66f500","73ff0f","82ff28","91ff43","a1ff5e","b1ff79","c1fe95","004c00","005600","006400","007500","008700","009b00","00b000","00c600","00dd00","00f500","0fff0f","28ff28","43ff43","5eff5e","79ff79","95fe95","004c19","00561c","006421","007527","00872d","009b33","00b03a","00c642","00dd49","00f551","0fff5f","28ff70","43ff81","5eff93","79ffa6","95feb8","004c4c","005656","006464","007575","008787","009b9b","00b0b0","00c6c6","00dddd","00f5f5","0ffffe","28fffe","43fffe","5efffe","79ffff","95fffe","00394c","004056","004b64","005775","006587","00749b","0084b0","0094c6","00a6dd","00b8f5","0fc3ff","28c9ff","43d0ff","5ed6ff","79ddff","95e4fe","00264c","002b56","003264","003a75","004387","004d9b","0058b0","0063c6","006edd","007af5","0f87ff","2893ff","43a1ff","5eaeff","79bcff","95cafe","00134c","001556","001964","001d75","002187","00269b","002cb0","0031c6","0037dd","003df5","0f4bff","285eff","4372ff","5e86ff","799aff","95b0fe","19004c","1c0056","210064","270075","2d0087","33009b","3a00b0","4200c6","4900dd","5100f5","5f0fff","7028ff","8143ff","935eff","a679ff","b895fe","33004c","390056","420064","4e0075","5a0087","67009b","7500b0","8400c6","9300dd","a300f5","af0fff","b728ff","c043ff","c95eff","d279ff","db95fe","4c004c","560056","640064","750075","870087","9b009b","b000b0","c600c6","dd00dd","f500f5","fe0fff","fe28ff","fe43ff","fe5eff","fe79ff","fe95fe","4c0032","560039","640042","75004e","87005a","9b0067","b00075","c60084","dd0093","f500a3","ff0faf","ff28b7","ff43c0","ff5ec9","ff79d2","ffffff"] # Copied From :::: https://github.com/FireyFly/pixd/blob/master/pixd.c#L20
if not "farbfeld" == sys.stdin.read(8):
exit(1)
x = sys.stdin.read(4)
y = sys.stdin.read(4)
sx = (ord(x[0])*pow(256,3))+(ord(x[1])*pow(256,2))+(ord(x[2])*pow(256,1))+(ord(x[3])*pow(256,0))
sy = (ord(y[0])*pow(256,3))+(ord(y[1])*pow(256,2))+(ord(y[2])*pow(256,1))+(ord(y[3])*pow(256,0))
n=0
u = int(math.log(sx,2))
t = (sx*sy) * [0]
while (sx*sy)-n:
o = sys.stdin.read(8)
r = str(format(ord(o[0]),"02x"))
g = str(format(ord(o[2]),"02x"))
b = str(format(ord(o[4]),"02x"))
t[coordinate2position([n%sx,n/sy],u)] = col.index(r+g+b)
n=n+1
for a in t:
sys.stdout.write("%s" %(chr(a)))