-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathimg2clourfultxt.py
75 lines (63 loc) · 2.68 KB
/
img2clourfultxt.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
import argparse
import cv2
import numpy as np
def get_args():
parser = argparse.ArgumentParser("Image to ASCII")
parser.add_argument("--input", type=str, default="data/myfurina-22.jpg", help="Path to input image")
parser.add_argument("--mode", type=str, default="simple", choices=["simple", "complex"],
help="10 or 70 different characters")
parser.add_argument("--num_cols", type=int, default=1500, help="number of character for output's width")
parser.add_argument("--output", type=str, default="output.txt", help="Path to output text file")
args = parser.parse_args()
return args
def rgb_to_ansi(r, g, b):
"""
将 RGB 颜色转换为 ANSI 转义序列
"""
# print(f" {"\033[38;2;{r};{g};{b}m"} ")
# return f"\033[38;2;{r};{g};{b}m"
f"\033[38;2;{r};{g};{b}m"
return f"\\033[38;2;{r};{g};{b}m"
def main(opt):
if opt.mode == "simple":
CHAR_LIST = '@%#*+=-:. '
else:
CHAR_LIST = r'$@B%8&WM#*oahkbdpqwmZO0QLCJUYXzcvunxrjft/\|()1{}[]?-_+~<>i!lI;:,"^`\'. '
num_chars = len(CHAR_LIST)
num_cols = opt.num_cols
image = cv2.imread(opt.input)
image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)
height, width, _ = image.shape
cell_width = width / opt.num_cols
cell_height = 2 * cell_width
num_rows = int(height / cell_height)
if num_cols > width or num_rows > height:
print("Too many columns or rows. Use default setting")
cell_width = 6
cell_height = 12
num_cols = int(width / cell_width)
num_rows = int(height / cell_height)
with open(opt.output, 'w', encoding='utf-8') as f:
for i in range(num_rows):
for j in range(num_cols):
# 获取部分图像
partial_image = image[
int(i * cell_height):min(int((i + 1) * cell_height), height),
int(j * cell_width):min(int((j + 1) * cell_width), width),
:
]
# 计算部分图像的平均颜色
avg_color = np.mean(partial_image, axis=(0, 1)).astype(int)
r, g, b = avg_color
# 计算平均亮度并选择合适的字符
avg_brightness = np.mean(avg_color)
char = CHAR_LIST[min(int(avg_brightness * num_chars / 255), num_chars - 1)]
# 写入带有 ANSI 转义序列的字符到文件
ansi_char = f"{rgb_to_ansi(r, g, b)}{char}\033[0m"
f.write(ansi_char)
print(ansi_char, end='') # 打印到控制台
f.write('\n') # 换行
print() # 控制台换行
if __name__ == '__main__':
opt = get_args()
main(opt)