forked from mc-meme/mc-meme
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathauto_pack_img.py
executable file
·146 lines (107 loc) · 4.23 KB
/
auto_pack_img.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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
#!/usr/bin/env python3
import random
import cv2
import numpy as np
import os
class Node:
def __init__(self, x, y, width, height):
self.x = x
self.y = y
self.width = width
self.height = height
self.used = False
self.right = None
self.down = None
def find_node(root, width, height):
if root.used:
return find_node(root.right, width, height) or find_node(root.down, width, height)
elif width <= root.width and height <= root.height:
return root
else:
return None
def split_node(node, width, height):
node.used = True
node.down = Node(node.x, node.y + height, node.width, node.height - height)
node.right = Node(node.x + width, node.y, node.width - width, height)
return node
def grow_node(root, width, height):
can_grow_down = (width <= root.width)
can_grow_right = (height <= root.height)
should_grow_right = can_grow_right and (root.height >= (root.width + width))
should_grow_down = can_grow_down and (root.width >= (root.height + height))
if should_grow_right:
return grow_right(root, width, height)
elif should_grow_down:
return grow_down(root, width, height)
elif can_grow_right:
return grow_right(root, width, height)
elif can_grow_down:
return grow_down(root, width, height)
else:
root.width=root.width+width//2
root.height=root.height+height//2
return grow_node(root, width, height)
def grow_right(root, width, height):
new_root = Node(0, 0, root.width + width, root.height)
new_root.used = True
new_root.down = root
new_root.right = Node(root.width, 0, width, root.height)
return new_root if find_node(new_root, width, height) else None
def grow_down(root, width, height):
new_root = Node(0, 0, root.width, root.height + height)
new_root.used = True
new_root.right = root
new_root.down = Node(0, root.height, root.width, height)
return new_root if find_node(new_root, width, height) else None
def stitch_images_bin_packing(images):
root = Node(0, 0, images[0].shape[1], images[0].shape[0])
positions = []
for img in images:
node = find_node(root, img.shape[1], img.shape[0])
if node:
split_node(node, img.shape[1], img.shape[0])
else:
root = grow_node(root, img.shape[1], img.shape[0])
node = find_node(root, img.shape[1], img.shape[0])
split_node(node, img.shape[1], img.shape[0])
positions.append((node.x, node.y))
# stitched_image = np.zeros((root.height, root.width, 3), dtype=np.uint8)
stitched_image = np.full((root.height, root.width, 3),255, dtype=np.uint8)
for pos, img in zip(positions, images):
x, y = pos
stitched_image[y:y + img.shape[0], x:x + img.shape[1]] = img
return stitched_image
def load_images_from_folder(folder,max_height=768,max_width=768):
images = []
for filename in os.listdir(folder):
img = cv2.imread(os.path.join(folder, filename))
if img is not None:
if max_height is not None and max_width is not None:
if img.shape[0] > max_height or img.shape[1] > max_width:
scw=img.shape[1]/max_width
sch=img.shape[0]/max_height
mac=max(scw,sch)
img = cv2.resize(img, (int(img.shape[1]//mac),int(img.shape[0]//mac)))
# img = cv2.resize(img, (min(img.shape[1], max_width), min(img.shape[0], max_height)))
# img = cv2.resize(img, (min(img.shape[1], max_width), min(img.shape[0], max_height)))
images.append(img)
random.shuffle(images)
scc=[]
for i in images:
w=i.shape[1]
h=i.shape[0]
sizezz=w*h
scc.append((sizezz,i))
scc.sort(key=lambda x: x[0], reverse=True)
images=[]
for i in scc:
images.append(i[1])
return images
folder = 'zh_cn'
images = load_images_from_folder(folder)
stitched_image = stitch_images_bin_packing(images)
cv2.imwrite('images/auto_img_zh_cn.png', stitched_image)
folder = 'en'
images = load_images_from_folder(folder)
stitched_image = stitch_images_bin_packing(images)
cv2.imwrite('images/auto_img_en.png', stitched_image)