objektify2 / generate.py
tripleS-Dev
update V1.3.4L Beta
f050b9c
raw
history blame
18 kB
import os
import time
import numpy as np
import gradio as gr
import fn
import edimg
import edgif
from PIL import Image, ImageDraw, ImageFont, ImageColor, ImageFilter, ImageSequence
import maker
import pre
img_blank = Image.open('resource/blank.png')
side = Image.open("resources/side.png")
side_special = Image.open("resources/side_special.png")
side_oma1 = Image.open("resources/side_oma1.png")
side_oma2 = Image.open("resources/side_oma2.png")
def sorting(img_type, img_static, img_dynamic_file, obj_color, obj_color_picker, ai_num, txt_color, txt_color_picker, member_name_dropdown, group_name_radio, group_name_txt, obj_num, obj_alphabet, obj_alphabet_txt, obj_serial, horizontal):
if not img_static.size == (1164, 1800):
img_static = edimg.resize_img(img_static, 1164, 1800)
print('resized!')
match img_type:
case "Image":
if img_static == None:
gr.Warning("Upload the image first")
return "resource/upload_first.png", "resource/upload_first.png", None
img = front_static(img_static, obj_color, obj_color_picker, ai_num, txt_color, txt_color_picker, member_name_dropdown, group_name_radio, group_name_txt, obj_num, obj_alphabet, obj_alphabet_txt, obj_serial)
if horizontal:
img_rotate = img.rotate(90, expand=True)
return img_rotate, img, None
return img, img, None
case "Gif":
if img_dynamic_file == None:
gr.Warning("Upload the gif first")
return "resource/upload_first.png", "resource/upload_first.png", None
overlay = front_static(img_blank, obj_color, obj_color_picker, ai_num, txt_color, txt_color_picker, member_name_dropdown, group_name_radio, group_name_txt, obj_num, obj_alphabet, obj_alphabet_txt, obj_serial)
gif = Image.open(img_dynamic_file)
edgif.attach_gif(gif, overlay)
return "output.gif", "output.gif", "output.gif"
def front_static(img, obj_color, obj_color_picker, ai_num, txt_color, txt_color_picker, member_name_dropdown, group_name_radio, group_name_txt, obj_num, obj_alphabet, obj_alphabet_txt, obj_serial):
match obj_color:
case "Atom01":
obj_color = "#ffdd00"
front_side = edimg.color(side, obj_color)
img.paste(front_side, (1039, 104), front_side)
case "Binary01":
obj_color = "#00ff01"
front_side = edimg.color(side, obj_color)
img.paste(front_side, (1039, 104), front_side)
case "Cream01":
obj_color = "#ff7477"
front_side = edimg.color(side, obj_color)
img.paste(front_side, (1039, 104), front_side)
case "Divine01":
obj_color = "#a226f5"
front_side = edimg.color(side, obj_color)
img.paste(front_side, (1039, 104), front_side)
case "Special":
img.paste(side_special, (1039, 104), side_special)
case "OMA1":
img = edimg.paste_img(img, side_oma1, (1016, 83))
case "OMA2":
img = edimg.paste_img(img, side_oma2, (1016, 83))
case "Other color":
obj_color = obj_color_picker
front_side = edimg.color(side, obj_color)
img.paste(front_side, (1039, 104), front_side)
case "AI Color":
front_side = edimg.color_ai(ai_num)
img.paste(front_side, (1039, 0), front_side)
match txt_color:
case "White":
txt_color_r = 255
txt_color_g = 255
txt_color_b = 255
txt_color_hex = "#FFFFFF"
case "Black":
txt_color_r = 0
txt_color_g = 0
txt_color_b = 0
txt_color_hex = "#000000"
case _:
txt_color_r, txt_color_g, txt_color_b = fn.hex_to_rgb(txt_color_picker)
txt_color_hex = txt_color_picker
if member_name_dropdown:
img_name = edimg.txt(member_name_dropdown, txt_color_r, txt_color_g, txt_color_b, 61, 270, "l")
img.paste(img_name, (1050, 161), img_name)
match group_name_radio:
case "tripleS":
img_group_name = edimg.txt(group_name_radio, txt_color_r, txt_color_g, txt_color_b, 61, 270, "r")
img.paste(img_group_name, (1050, 1240), img_group_name)
case "ARTMS":
img_artms_side = edimg.color("resource/artms_side.png", txt_color_hex)
img.paste(img_artms_side, (1081, 1371), img_artms_side)
case "Other":
img_group_name = edimg.txt(group_name_txt, txt_color_r, txt_color_g, txt_color_b, 61, 270, "r")
img.paste(img_group_name, (1050, 1240), img_group_name)
case None:
pass
case _:
img_group_name = edimg.txt(group_name_radio, txt_color_r, txt_color_g, txt_color_b, 61, 270, "r")
img.paste(img_group_name, (1050, 1240), img_group_name)
if obj_num != "" and obj_alphabet != "":
if obj_alphabet == "Other":
obj_alphabet = obj_alphabet_txt
img_obj_num = edimg.txt(obj_num+obj_alphabet, txt_color_r, txt_color_g, txt_color_b, 75, 270, "r")
img.paste(img_obj_num, (1050, 452), img_obj_num)
if obj_serial:
img_serial = edimg.serial(obj_serial, txt_color_r, txt_color_g, txt_color_b, 75)
img.paste(img_serial, (1046, 871), img_serial)
img = edimg.rounded(img)
krtime = fn.get_kr_time()
img_jpeg = img.convert('RGB')
img_jpeg.save(f'/data/cache/{member_name_dropdown}_{group_name_radio}_{obj_num}{obj_alphabet}_{krtime}.jpg', quality=90)
return img
sign_positions = {
"SeoYeon": (31, 1068),
"HyeRin": (0, 1103),
"JiWoo": (34, 1101),
"ChaeYeon": (1, 1053),
"YooYeon": (79, 1100),
"SooMin": (0, 1057),
"NaKyoung": (0, 1116),
"YuBin": (20, 1109),
"Kaede": (26, 1109),
"DaHyun": (42, 1104),
"Kotone": (31, 1105),
"YeonJi": (0, 1065),
"Nien": (58, 1108),
"SoHyun": (0, 1110),
"Xinyu": (0, 1105),
"Mayu": (49, 1056),
"Lynn": (61, 1105),
"JooBin": (84, 1118),
"HaYeon": (39, 1167),
"ShiOn": (170, 1105),
"ChaeWon": (64, 1124),
"Sullin": (41, 1146),
"SeoAh": (52, 1113),
"JiYeon": (65, 1129),
"HeeJin": (38, 1148),
"KimLip": (61, 1100),
"JinSoul": (52, 1113),
"Choerry": (46, 1022),
"HaSeul": (62, 1131)
}
cream01 = Image.open("resource/cream01.png")
atom01 = Image.open("resource/atom01.png")
binary01 = Image.open("resource/binary01.png")
divine01 = Image.open("resource/divine01.png")
back_ui = Image.open("resource/back_ui.png")
outline_ui = Image.open("resources/outline.png")
outline_ui_oma = Image.open("resources/outline_oma.png")
back_ = Image.open("resources/back.png")
right_modhaus = Image.open("resource/right_modhaus.png")
img_qr_white_space = Image.new("RGB", (335, 335), 'white')
def back(obj_color, obj_color_picker, ai_num, txt_color, txt_color_picker, group_name_radio, group_name_txt, member_name_dropdown, obj_num, obj_alphabet, obj_alphabet_txt, obj_serial, obj_outline_color, obj_outline_color_picker, logo_radio, class_radio, class_txt, season_radio, season_txt, season_txt_outline, sign, qr_url_dropdown, qr_Logo_radio, right_btn, preset):
match obj_color:
case 'OMA1':
frame = outline_ui_oma
case 'OMA2':
frame = outline_ui_oma
case _:
frame = outline_ui
match obj_outline_color:
case "White":
outline = edimg.color(frame, "#FFFFFF")
case "Black":
outline = edimg.color(frame, "#000000")
case _:
outline = edimg.color(frame, obj_outline_color_picker)
match obj_color:
case "Atom01":
obj_color = "#ffdd00"
img = edimg.color(back_, obj_color)
case "Binary01":
obj_color = "#00ff01"
img = edimg.color(back_, obj_color)
case "Cream01":
obj_color = "#ff7477"
img = edimg.color(back_, obj_color)
case "Divine01":
obj_color = "#a226f5"
img = edimg.color(back_, obj_color)
case "Special":
img = Image.open('resources/back_special.png.png')
case "OMA1":
img = Image.open('resources/back_oma1.png')
case "OMA2":
img = Image.open('resources/back_oma2.png')
case "Other color":
obj_color = obj_color_picker
img = edimg.color(back_, obj_color)
case "AI Color":
img = edimg.color_ai_back(ai_num)
case _:
img = edimg.color(back_, '#ffffff')
img.paste(outline, (0, 0), outline)
match txt_color:
case "White":
txt_color_r = 255
txt_color_g = 255
txt_color_b = 255
txt_color_hex = "#FFFFFF"
case "Black":
txt_color_r = 0
txt_color_g = 0
txt_color_b = 0
txt_color_hex = "#000000"
case _:
txt_color_r, txt_color_g, txt_color_b = fn.hex_to_rgb(txt_color_picker)
txt_color_hex = txt_color_picker
back_ui_colored = edimg.color(back_ui, txt_color_hex)
img.paste(back_ui_colored, (0, 0), back_ui_colored)
match logo_radio:
case "tripleS":
logo = edimg.color('resource/triples_logo.png', txt_color_hex)
img.paste(logo, (61, 162), logo)
case "ARTMS":
logo = edimg.color('resource/artms_logo.png', txt_color_hex)
img.paste(logo, (61, 162), logo)
case 'None':
pass
case _:
logo = edimg.color(f'/data/presets/{preset}/top_logo.png', txt_color_hex)
width, height = logo.size
# Calculate the new width to maintain the aspect ratio
new_height = 126
aspect_ratio = width / height
new_width = int(new_height * aspect_ratio)
# Resize the image
logo = logo.resize((new_width, new_height), Image.Resampling.LANCZOS)
img.paste(logo, (61, 162), logo)
if member_name_dropdown:
img_name = edimg.txt(member_name_dropdown, txt_color_r, txt_color_g, txt_color_b, 130, 0, "l", "font/Helvetica_Neue_LT_Std_65_Medium.otf", (800, 136))
img.paste(img_name, (54, 466), img_name)
img_name_side = edimg.txt(member_name_dropdown, txt_color_r, txt_color_g, txt_color_b, 61, 270, "l")
img.paste(img_name_side, (940, 159), img_name_side)
if obj_num:
if obj_alphabet == "Other":
obj_alphabet = obj_alphabet_txt
img_obj_num_side = edimg.txt(obj_num+obj_alphabet, txt_color_r,txt_color_g,txt_color_b, 75, 270, "r")
img.paste(img_obj_num_side, (951, 448), img_obj_num_side)
if obj_serial:
img_obj_serial_side = edimg.serial(obj_serial, txt_color_r,txt_color_g,txt_color_b, 75)
img.paste(img_obj_serial_side, (943, 867), img_obj_serial_side)
match group_name_radio:
case "tripleS":
img_group_name_side = edimg.txt("tripleS", txt_color_r, txt_color_g, txt_color_b, 61, 270, "r")
img.paste(img_group_name_side, (943, 1238), img_group_name_side)
case "ARTMS":
img_group_name_side = edimg.color("resource/artms_side.png", txt_color_hex)
img.paste(img_group_name_side, (974, 1371), img_group_name_side)
case "Other":
img_group_name_side = edimg.txt(group_name_txt, txt_color_r, txt_color_g, txt_color_b, 61, 270, "r")
img.paste(img_group_name_side, (943, 1238), img_group_name_side)
group_name_radio = group_name_txt
case None:
pass
case _:
img_group_name_side = edimg.txt(group_name_radio, txt_color_r, txt_color_g, txt_color_b, 61, 270, "r")
img.paste(img_group_name_side, (943, 1238), img_group_name_side)
group_name_radio = group_name_txt
match class_radio:
case "Zero" | "First" | "Double" | "Special":
img_class = edimg.txt(class_radio, txt_color_r, txt_color_g, txt_color_b, 130, 0, "l", "font/Helvetica_Neue_LT_Std_65_Medium.otf", (800, 136))
img.paste(img_class, (54, 700), img_class)
case "Other":
img_class = edimg.txt(class_txt, txt_color_r, txt_color_g, txt_color_b, 130, 0, "l", "font/Helvetica_Neue_LT_Std_65_Medium.otf", (800, 136))
img.paste(img_class, (54, 700), img_class)
match season_radio:
case "Atom01":
img_atom01 = edimg.color(atom01, txt_color_hex)
img.paste(img_atom01, (63, 951), img_atom01)
case "Binary01":
img_binary01 = edimg.color(binary01, txt_color_hex)
img.paste(img_binary01, (63, 951), img_binary01)
case "Cream01":
img_cream01 = edimg.color(cream01, txt_color_hex)
img.paste(img_cream01, (62, 950), img_cream01)
case "Divine01":
img_divine01 = edimg.color(divine01, txt_color_hex)
img.paste(img_divine01, (61, 951), img_divine01)
case "Other":
img_season = edimg.txt(season_txt, txt_color_r, txt_color_g, txt_color_b, 130, 0, "l", "font/Helvetica_Neue_LT_Std_65_Medium.otf", (1100, 136))
x = edimg.calculate_size(season_txt, 130, "font/Helvetica_Neue_LT_Std_65_Medium.otf")
img_season_outline = edimg.txt(season_txt_outline, txt_color_r, txt_color_g, txt_color_b, 135, 0, "l", "font/Helvetica_Neue_LT_Std_75_Bold_Outline.otf", (1100, 136))
img.paste(img_season,(53, 936), img_season)
img.paste(img_season_outline, (53 + x, 936), img_season_outline)
if sign in pre.names:
colored_icon = edimg.color(f'sign/{sign}.png', txt_color_hex)
position = sign_positions[sign]
img.paste(colored_icon, position, colored_icon)
elif sign:
colored_icon = edimg.color(f'/data/presets/{preset}/{sign}.png', txt_color_hex)
original_width, original_height = colored_icon.size
ratio = min(480 / original_width, 330 / original_height)
new_width = int(original_width * ratio)
new_height = int(original_height * ratio)
colored_icon = colored_icon.resize((new_width, new_height), Image.Resampling.LANCZOS)
img = maker.space(img, (63, 1097), (488, 335), colored_icon)
if qr_url_dropdown:
url_txt = fn.url_mapping(qr_url_dropdown)
img_qr = edimg.qr(url_txt)
match qr_Logo_radio:
case "tripleS":
img_qr_icon = edimg.qr_icon("resource/qr_icon_triples.png")
img_qr.paste(img_qr_icon, (126, 126), img_qr_icon)
case 'None':
pass
case _:
img_qr_icon = Image.open(f'/data/presets/{preset}/qr_logo.png')
colored_icon = img_qr_icon
original_width, original_height = colored_icon.size
ratio = min(84 / original_width, 84 / original_height)
new_width = int(original_width * ratio)
new_height = int(original_height * ratio)
colored_icon = colored_icon.resize((new_width, new_height), Image.Resampling.LANCZOS)
qr_logo_bg = Image.new(size=(84, 84), mode='RGB', color=(255,255,255))
qr_logo_bg = maker.space(qr_logo_bg, (0,0), (84,84), colored_icon)
img_qr.paste(qr_logo_bg, (126, 126))
img_qr = edimg.resize_img(img_qr, 335,335)
img.paste(img_qr, (555, 1098))
else:
img.paste(img_qr_white_space,(555, 1098))
if right_btn:
img_right_modhaus = edimg.color(right_modhaus, txt_color_hex)
img.paste(img_right_modhaus, (61,1604), img_right_modhaus)
krtime = fn.get_kr_time()
img_jpeg = img.convert('RGB')
img_jpeg.save(f'/data/cache/{member_name_dropdown}_{group_name_radio}_{class_radio}_{obj_num}{obj_alphabet}_{krtime}.jpg', quality=90)
return img, img
make_image_first = Image.open("resource/make_image_first.png")
remove_black = Image.open("resource/remove_black.png")
def ex_gen(img_front, file_front_path, img_back, count, blur, blur_strength, watermark):
if img_back == None:
gr.Warning("Make two images, front and back")
return make_image_first, make_image_first
if img_front == None and file_front_path == None:
gr.Warning("Make two images, front and back")
return make_image_first, make_image_first
if file_front_path:
file_front = Image.open(file_front_path)
match count:
case "One File":
img_back = img_back.resize(file_front.size)
img_remove_black = remove_black.resize(file_front.size)
img_back.paste(img_remove_black,(0,0), img_remove_black)
filename, _ = os.path.splitext(os.path.basename(file_front_path))
edimg.makegif(file_front, img_back)
return f"exgif.gif", img_back
case "Two Files":
return file_front, img_back
if blur:
img_front = img_front.filter(ImageFilter.GaussianBlur(blur_strength))
img_back = img_back.filter(ImageFilter.GaussianBlur(blur_strength))
if watermark:
img_txt = edimg.txt(watermark, 255, 255, 255, 210, 50, "l", "font/Helvetica_Neue_LT_Std_75_Bold.otf",(1338, 222), 120)
img_front.paste(img_txt, (65, 333), img_txt)
img_back.paste(img_txt, (65, 333), img_txt)
match count:
case "One File":
img = Image.new("RGBA", (2328, 1800), (0, 0, 0, 0))
img_front = edimg.rounded(img_front)
img_back = edimg.rounded(img_back)
img.paste(img_front, (0, 0), img_front)
img.paste(img_back, (1164, 0), img_back)
return img, img_blank
case "Two Files":
img_front = edimg.rounded(img_front)
img_back = edimg.rounded(img_back)
return img_front, img_back
def find_value(n, percent):
return n * (percent / 100.0)