1 | """mac_image - Helper routines (hacks) for images"""
|
---|
2 | import imgformat
|
---|
3 | from Carbon import Qd
|
---|
4 | import struct
|
---|
5 | import MacOS
|
---|
6 |
|
---|
7 | _fmt_to_mac = {
|
---|
8 | imgformat.macrgb16 : (16, 16, 3, 5),
|
---|
9 | }
|
---|
10 |
|
---|
11 | def mkpixmap(w, h, fmt, data):
|
---|
12 | """kludge a pixmap together"""
|
---|
13 | fmtinfo = _fmt_to_mac[fmt]
|
---|
14 |
|
---|
15 | rv = struct.pack("lHhhhhhhlllhhhhlll",
|
---|
16 | id(data)+MacOS.string_id_to_buffer, # HACK HACK!!
|
---|
17 | w*2 + 0x8000,
|
---|
18 | 0, 0, h, w,
|
---|
19 | 0,
|
---|
20 | 0, 0, # XXXX?
|
---|
21 | 72<<16, 72<<16,
|
---|
22 | fmtinfo[0], fmtinfo[1],
|
---|
23 | fmtinfo[2], fmtinfo[3],
|
---|
24 | 0, 0, 0)
|
---|
25 | ## print 'Our pixmap, size %d:'%len(rv)
|
---|
26 | ## dumppixmap(rv)
|
---|
27 | return Qd.RawBitMap(rv)
|
---|
28 |
|
---|
29 | def dumppixmap(data):
|
---|
30 | baseAddr, \
|
---|
31 | rowBytes, \
|
---|
32 | t, l, b, r, \
|
---|
33 | pmVersion, \
|
---|
34 | packType, packSize, \
|
---|
35 | hRes, vRes, \
|
---|
36 | pixelType, pixelSize, \
|
---|
37 | cmpCount, cmpSize, \
|
---|
38 | planeBytes, pmTable, pmReserved \
|
---|
39 | = struct.unpack("lhhhhhhhlllhhhhlll", data)
|
---|
40 | print 'Base: 0x%x'%baseAddr
|
---|
41 | print 'rowBytes: %d (0x%x)'%(rowBytes&0x3fff, rowBytes)
|
---|
42 | print 'rect: %d, %d, %d, %d'%(t, l, b, r)
|
---|
43 | print 'pmVersion: 0x%x'%pmVersion
|
---|
44 | print 'packing: %d %d'%(packType, packSize)
|
---|
45 | print 'resolution: %f x %f'%(float(hRes)/0x10000, float(vRes)/0x10000)
|
---|
46 | print 'pixeltype: %d, size %d'%(pixelType, pixelSize)
|
---|
47 | print 'components: %d, size %d'%(cmpCount, cmpSize)
|
---|
48 | print 'planeBytes: %d (0x%x)'%(planeBytes, planeBytes)
|
---|
49 | print 'pmTable: 0x%x'%pmTable
|
---|
50 | print 'pmReserved: 0x%x'%pmReserved
|
---|
51 | for i in range(0, len(data), 16):
|
---|
52 | for j in range(16):
|
---|
53 | if i + j < len(data):
|
---|
54 | print '%02.2x'%ord(data[i+j]),
|
---|
55 | print
|
---|