# Licensed under the TENCENT HUNYUAN COMMUNITY LICENSE AGREEMENT (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# https://github.com/Tencent-Hunyuan/HunyuanVideo-1.5/blob/main/LICENSE
#
# Unless and only to the extent required by applicable law, the Tencent Hunyuan works and any
# output and results therefrom are provided "AS IS" without any express or implied warranties of
# any kind including any warranties of title, merchantability, noninfringement, course of dealing,
# usage of trade, or fitness for a particular purpose. You are solely responsible for determining the
# appropriateness of using, reproducing, modifying, performing, displaying or distributing any of
# the Tencent Hunyuan works or outputs and assume any and all risks associated with your or a
# third party's use or distribution of any of the Tencent Hunyuan works or outputs and your exercise
# of rights and permissions under this agreement.
# See the License for the specific language governing permissions and limitations under the License.
import json
def closest_color(requested_color):
import webcolors
min_colors = {}
for key, name in webcolors.CSS3_HEX_TO_NAMES.items():
r_c, g_c, b_c = webcolors.hex_to_rgb(key)
rd = (r_c - requested_color[0]) ** 2
gd = (g_c - requested_color[1]) ** 2
bd = (b_c - requested_color[2]) ** 2
min_colors[(rd + gd + bd)] = name
res = min_colors.get(min(min_colors.keys()), None)
if res is None:
raise KeyError
return res
def convert_rgb_to_names(rgb_tuple):
try:
import webcolors
color_name = webcolors.rgb_to_name(rgb_tuple)
except ValueError:
color_name = closest_color(rgb_tuple)
return color_name
class MultilingualPromptFormat:
def __init__(
self,
font_path: str = 'assets/glyph_sdxl_assets/multilingual_10-lang_idx.json',
color_path: str = 'assets/glyph_sdxl_assets/color_idx.json',
):
with open(font_path, 'r') as f:
self.font_dict = json.load(f)
with open(color_path, 'r') as f:
self.color_dict = json.load(f)
def format_prompt(self, texts, styles):
'''
Text "{text}" in {color}, {type}.
'''
prompt = ""
for text, style in zip(texts, styles):
text_prompt = f'Text "{text}"'
attr_list = []
# format color
if style["color"] is not None:
import webcolors
hex_color = style["color"]
rgb_color = webcolors.hex_to_rgb(hex_color)
color_name = convert_rgb_to_names(rgb_color)
attr_list.append(f"<color-{self.color_dict[color_name]}>")
# format font
if style["font-family"] is not None:
attr_list.append(f"<{style['font-family'][:2]}-font-{self.font_dict[style['font-family']]}>")
attr_suffix = ", ".join(attr_list)
text_prompt += " in " + attr_suffix
text_prompt += ". "
else:
text_prompt += ". "
prompt = prompt + text_prompt
return prompt