-
Notifications
You must be signed in to change notification settings - Fork 522
/
genplate_advanced.py
96 lines (86 loc) · 3.61 KB
/
genplate_advanced.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
#coding=utf-8
import os
import argparse
from math import *
import numpy as np
import cv2
# import PIL
from PIL import Image, ImageFont, ImageDraw
from PlateCommon import *
class GenPlate:
def __init__(self,fontCh,fontEng,NoPlates):
self.fontC = ImageFont.truetype(fontCh,43,0);
self.fontE = ImageFont.truetype(fontEng,60,0);
self.img=np.array(Image.new("RGB", (226,70),(255,255,255)))
self.bg = cv2.resize(cv2.imread("./images/template.bmp"),(226,70));
self.smu = cv2.imread("./images/smu2.jpg");
self.noplates_path = [];
for parent,parent_folder,filenames in os.walk(NoPlates):
for filename in filenames:
path = parent+"/"+filename;
self.noplates_path.append(path);
def draw(self,val):
offset= 2
self.img[0:70,offset+8:offset+8+23]= GenCh(self.fontC,val[0]);
self.img[0:70,offset+8+23+6:offset+8+23+6+23]= GenCh1(self.fontE,val[1]);
for i in range(5):
base = offset+8+23+6+23+17 +i*23 + i*6 ;
self.img[0:70, base : base+23]= GenCh1(self.fontE,val[i+2]);
return self.img
def generate(self,text):
if len(text) == 9:
fg = self.draw(text.decode(encoding="utf-8"));
fg = cv2.bitwise_not(fg);
com = cv2.bitwise_or(fg,self.bg);
# com = rot(com,r(60)-30,com.shape,30);
com = rot(com,r(40)-20,com.shape,20);
com = rotRandrom(com,10,(com.shape[1],com.shape[0]));
com = AddSmudginess(com,self.smu)
# com = tfactor(com)
com = random_envirment(com,self.noplates_path)
com = AddGauss(com, 1+r(2))
com = addNoise(com)
return com
def genPlateString(self,pos,val):
plateStr = "";
box = [0,0,0,0,0,0,0];
if(pos!=-1):
box[pos]=1;
for unit,cpos in zip(box,xrange(len(box))):
if unit == 1:
plateStr += val
else:
if cpos == 0:
plateStr += chars[r(31)]
elif cpos == 1:
plateStr += chars[41+r(24)]
else:
plateStr += chars[31 + r(34)]
return plateStr;
def genBatch(self, batchSize,pos,charRange, outputPath,size):
if not os.path.exists(outputPath):
os.makedirs(outputPath)
for i in xrange(batchSize):
plateStr = self.genPlateString(-1,-1)
img = self.generate(plateStr)
img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
img = cv2.resize(img,size)
# filename = os.path.join(outputPath, str(i).zfill(4) + '.' + plateStr + ".jpg")
filename = os.path.join(outputPath, str(i).zfill(5) + '_' + plateStr + ".jpg")
cv2.imwrite(filename, img)
print filename, plateStr
def parse_args():
parser = argparse.ArgumentParser()
parser.add_argument('--font_ch', default='./font/platech.ttf')
parser.add_argument('--font_en', default='./font/platechar.ttf')
parser.add_argument('--bg_dir', default='./NoPlates')
parser.add_argument('--out_dir', default='./data/plate_train', help='output dir')
parser.add_argument('--make_num', default=10000, type=int, help='num')
parser.add_argument('--img_w', default=120, type=int, help='num')
parser.add_argument('--img_h', default=32, type=int, help='num')
return parser.parse_args()
def main(args):
G = GenPlate(args.font_ch, args.font_en, args.bg_dir)
G.genBatch(args.make_num,2,range(31,65), args.out_dir, (args.img_w, args.img_h))
if __name__ == '__main__':
main(parse_args())