1 Star 0 Fork 0

xxxqhloveu/AnyText

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
dataset_util.py 2.29 KB
一键复制 编辑 原始数据 按行查看 历史
tuoyuxiang 提交于 2023-12-26 21:36 . inference code and demo
import json
import pathlib
__all__ = ['load', 'save', 'show_bbox_on_image']
def load(file_path: str):
file_path = pathlib.Path(file_path)
func_dict = {'.txt': load_txt, '.json': load_json, '.list': load_txt}
assert file_path.suffix in func_dict
return func_dict[file_path.suffix](file_path)
def load_txt(file_path: str):
with open(file_path, 'r', encoding='utf8') as f:
content = [x.strip().strip('\ufeff').strip('\xef\xbb\xbf') for x in f.readlines()]
return content
def load_json(file_path: str):
with open(file_path, 'r', encoding='utf8') as f:
content = json.load(f)
return content
def save(data, file_path):
file_path = pathlib.Path(file_path)
func_dict = {'.txt': save_txt, '.json': save_json}
assert file_path.suffix in func_dict
return func_dict[file_path.suffix](data, file_path)
def save_txt(data, file_path):
if not isinstance(data, list):
data = [data]
with open(file_path, mode='w', encoding='utf8') as f:
f.write('\n'.join(data))
def save_json(data, file_path):
with open(file_path, 'w', encoding='utf-8') as json_file:
json.dump(data, json_file, ensure_ascii=False, indent=4)
def show_bbox_on_image(image, polygons=None, txt=None, color=None, font_path='./font/Arial_Unicode.ttf'):
from PIL import ImageDraw, ImageFont
image = image.convert('RGB')
draw = ImageDraw.Draw(image)
if len(txt) == 0:
txt = None
if color is None:
color = (255, 0, 0)
if txt is not None:
font = ImageFont.truetype(font_path, 20)
for i, box in enumerate(polygons):
box = box[0]
if txt is not None:
draw.text((int(box[0][0]) + 20, int(box[0][1]) - 20), str(txt[i]), fill='red', font=font)
for j in range(len(box) - 1):
draw.line((box[j][0], box[j][1], box[j + 1][0], box[j + 1][1]), fill=color, width=2)
draw.line((box[-1][0], box[-1][1], box[0][0], box[0][1]), fill=color, width=2)
return image
def show_glyphs(glyphs, name):
import numpy as np
import cv2
size = 64
gap = 5
n_char = 20
canvas = np.ones((size, size*n_char + gap*(n_char-1), 1))*0.5
x = 0
for i in range(glyphs.shape[-1]):
canvas[:, x:x + size, :] = glyphs[..., i:i+1]
x += size+gap
cv2.imwrite(name, canvas*255)
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/corrshaw/AnyText.git
[email protected]:corrshaw/AnyText.git
corrshaw
AnyText
AnyText
main

搜索帮助