LineArt: Bound box visibility check when loading
[blender.git] / source / blender / datatoc / datatoc_icon_split_to_png.py
1 #!/usr/bin/env python3
2
3 # ##### BEGIN GPL LICENSE BLOCK #####
4 #
5 #  This program is free software; you can redistribute it and/or
6 #  modify it under the terms of the GNU General Public License
7 #  as published by the Free Software Foundation; either version 2
8 #  of the License, or (at your option) any later version.
9 #
10 #  This program is distributed in the hope that it will be useful,
11 #  but WITHOUT ANY WARRANTY; without even the implied warranty of
12 #  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 #  GNU General Public License for more details.
14 #
15 #  You should have received a copy of the GNU General Public License
16 #  along with this program; if not, write to the Free Software Foundation,
17 #  Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18 #
19 # ##### END GPL LICENSE BLOCK #####
20
21 # This script is just to view the icons
22
23
24 def write_png(buf, width, height):
25     import zlib
26     import struct
27     # reverse the vertical line order and add null bytes at the start
28     width_byte_4 = width * 4
29     raw_data = b"".join(
30         b'\x00' + buf[span:span + width_byte_4]
31         for span in range((height - 1) * width * 4, -1, - width_byte_4)
32     )
33
34     def png_pack(png_tag, data):
35         chunk_head = png_tag + data
36         return struct.pack("!I", len(data)) + chunk_head + struct.pack("!I", 0xFFFFFFFF & zlib.crc32(chunk_head))
37
38     return b"".join([
39         b'\x89PNG\r\n\x1a\n',
40         png_pack(b'IHDR', struct.pack("!2I5B", width, height, 8, 6, 0, 0, 0)),
41         png_pack(b'IDAT', zlib.compress(raw_data, 9)),
42         png_pack(b'IEND', b'')])
43
44
45 def icondata_to_png(file_src, file_dst):
46     import struct
47
48     with open(file_src, 'rb') as f_src:
49         # 2 ints
50         temp_data = f_src.read(4 * 2)
51         w, h = struct.unpack('<2I', temp_data)
52         temp_data = f_src.read(4 * 2)  # (x, y)         - ignored
53         temp_data = f_src.read(4 * 2)  # (xfrom, yfrom) - ignored
54         # pixels
55         temp_data = f_src.read(w * h * 4)
56
57     buf = write_png(temp_data, w, h)
58
59     with open(file_dst, 'wb') as f_dst:
60         f_dst.write(buf)
61
62
63 def main():
64     import sys
65     import os
66
67     for arg in sys.argv[1:]:
68         file_src = arg
69         file_dst = os.path.splitext(arg)[0] + ".png"
70
71         icondata_to_png(file_src, file_dst)
72
73
74 if __name__ == "__main__":
75     main()