-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathtest_angle.py
executable file
·80 lines (61 loc) · 2.66 KB
/
test_angle.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
# coding: utf-8
from tr import *
from PIL import Image, ImageDraw, ImageFont
import cv2, sys, time
if __name__ == "__main__":
img_path = "imgs/id_card.jpeg"
img_pil = Image.open(img_path)
try:
if hasattr(img_pil, '_getexif'):
# from PIL import ExifTags
# for orientation in ExifTags.TAGS.keys():
# if ExifTags.TAGS[orientation] == 'Orientation':
# break
orientation = 274
exif = dict(img_pil._getexif().items())
if exif[orientation] == 3:
img_pil = img_pil.rotate(180, expand=True)
elif exif[orientation] == 6:
img_pil = img_pil.rotate(270, expand=True)
elif exif[orientation] == 8:
img_pil = img_pil.rotate(90, expand=True)
except:
pass
MAX_SIZE = 1600
if img_pil.height > MAX_SIZE or img_pil.width > MAX_SIZE:
scale = max(img_pil.height / MAX_SIZE, img_pil.width / MAX_SIZE)
new_width = int(img_pil.width / scale + 0.5)
new_height = int(img_pil.height / scale + 0.5)
img_pil = img_pil.resize((new_width, new_height), Image.BICUBIC)
print(img_path, img_pil.width, img_pil.height)
color_pil = img_pil.convert("RGB")
gray_pil = img_pil.convert("L")
rect_arr = detect(gray_pil, FLAG_ROTATED_RECT)
img_draw = ImageDraw.Draw(color_pil)
colors = ['red', 'green', 'blue', "purple"]
for i, rect in enumerate(rect_arr):
cx, cy, w, h, a = rect
box = cv2.boxPoints(((cx, cy), (w, h), a))
box = numpy.int0(box)
for p1, p2 in [(0, 1), (1, 2), (2, 3), (3, 0)]:
img_draw.line(xy=(box[p1][0], box[p1][1], box[p2][0], box[p2][1]), fill=colors[i % len(colors)], width=2)
color_pil.save("~color_pil.png")
color_pil.show()
blank_pil = Image.new("RGBA", img_pil.size, (255, 255, 255, 255))
blank_draw = ImageDraw.Draw(blank_pil)
results = run_angle(gray_pil)
for i, line in enumerate(results):
cx, cy, w, h, a = line[0]
if a < -45:
w, h = h, w
a += 90
txt_pil = Image.new('RGBA', (int(w * 1.4), h), (255, 255, 255, 0))
txt_draw = ImageDraw.Draw(txt_pil)
txt = line[1]
print(i, txt)
font = ImageFont.truetype("msyh.ttf", max(int(h * 0.4), 12))
txt_draw.text(xy=(0, 0), text=txt, font=font, fill=(0, 0, 0, 255))
txt_pil = txt_pil.rotate(-a, expand=1, resample=Image.BICUBIC)
blank_pil.paste(txt_pil, (int(cx - w / 2), int(cy - h / 2)), txt_pil)
blank_pil.show()
blank_pil.save("~blank_pil.png")