forked from FlintyLemming/ComfyUI-AnyText
104 lines
8.0 KiB
Markdown
104 lines
8.0 KiB
Markdown
|
# AnyText非官方的简单粗糙实现 | [English README](../../README.md)
|
|||
|
|
|||
|
## 原Repo: [AnyText: Multilingual Visual Text Generation And Editing](https://github.com/tyxsspa/AnyText)
|
|||
|
|
|||
|
## 个人原因暂停维护。
|
|||
|
|
|||
|
## 警告:
|
|||
|
- 非程序员,所以很多问题我都没办法解决。
|
|||
|
- **如果不需要`damo/nlp_csanmt_translation_zh2en`翻译,不要安装modelscope、tensorflow包!!!**
|
|||
|
- 这个插件生成质量可能比官方差很多。
|
|||
|
- 仅测试 **cuda+fp16/fp32** ,其他搭配自行测试。
|
|||
|
- 仅在**ComfyUI官方整合包稳定版**+**绿色便携(python_embed)**+**windows测试**,第三方整合包、虚拟环境和其他操作系统(例如linux)自行测试,无法保证正常使用。
|
|||
|
- Tensorflow需要特定版本cuda才能跑到gpu上,但是在原生windows上 [tensorflow 2.10+:详情看note](https://github.com/tensorflow/tensorflow/releases/tag/v2.11.1) 无法调用gpu,必须使用linux或者wsl2才行。这种情况下`damo/nlp_csanmt_translation_zh2en`翻译只能跑在cpu上,速度很慢。
|
|||
|
- 如果出现`Input type (torch.cuda.FloatTensor) and weight type (torch.FloatTensor) should be the same`错误,打开**all_to_device**,也许有效。感谢 **@[602387193c](https://github.com/602387193c)** -----> **[issues/17](https://github.com/zmwv823/ComfyUI-AnyText/issues/17)**
|
|||
|
- 如果出现`expected scalar type Half but found Float`,尝试fp32。
|
|||
|
### v2测试,更加本地化,非远程代码模式。
|
|||
|
|
|||
|
## 使用说明:
|
|||
|
- `utrobinmv/t5_translate_en_ru_zh_small_1024`(212MB)翻译速度快、体积小,但是准确度远不如`damo/nlp_csanmt_translation_zh2en`(7.3GB)。
|
|||
|
- 自动检测提示词是否中文,来决定是否自动加载翻译。
|
|||
|
- 手绘遮罩数量必须>=你想生成文字的数量,每一个“”代表一个文字数量,“”里面内容不限长度,否则会报错 ["not enough values to unpack"](https://github.com/zmwv823/ComfyUI-AnyText/issues/7).
|
|||
|
- 个人电脑环境: ComfyUI官方整合包+(ComfyUI_windows_portable\ComfyUI下)脚本运行+python_embed+win10+py311+torch2.3.0+cu121+rtx3050laptop(4GB).
|
|||
|
- pillow>=9.5.0(10.3.0)大部分包都是最新版本。
|
|||
|
- **支持任意分辨率图片输入,但是会被缩放到<=768,输出图片也会被限制到<=768(官方策略)。**
|
|||
|
- **如果font、ckpt_name、clip设置为Auto_DownLoad,则会自动下载默认模型到特定目录。如果模型已经存在,则会自动加载。**
|
|||
|
- 自动从笑脸(huggingface)下载的AnyText模型(fp16: 2.66 GB)在"ComfyUI\models\checkpoints\15\anytext_v1.1.safetensors"。
|
|||
|
- 你可以手动从[魔搭(modelscope)-AnyText-FP32-5.73 GB](https://modelscope.cn/models/iic/cv_anytext_text_generation_editing/file/view/master?fileName=anytext_v1.1.ckpt&status=2)下载,然后放到**ComfyUI\models\checkpoints**。
|
|||
|
- 或者手动从[笑脸(huggingface)-AnyText-FP16-2.66 GB](https://huggingface.co/Sanster/AnyText/blob/main/pytorch_model.fp16.safetensors) 下载并重命名为**anytext_v1.1.safetensors或者任意名字**。然后放到 **ComfyUI\models\checkpoints**。
|
|||
|
- [clip模型-**clip-vit-large-patch14**](https://huggingface.co/openai/clip-vit-large-patch14)会下载到 `C:\Users\username\.cache\huggingface\hub`。可以手动下载[clip模型](https://huggingface.co/openai/clip-vit-large-patch14)放到**ComfyUI\models\clip\openai--clip-vit-large-patch14**位置。
|
|||
|
- ![](./clip_model.jpg)
|
|||
|
- [字体-(SourceHanSansSC-Medium.otf)-18MB](https://huggingface.co/Sanster/AnyText/blob/main/SourceHanSansSC-Medium.otf)会从笑脸(huggingface)下载到**ComfyUI\models\fonts**位置,你也可以使用自己的字体。
|
|||
|
- 翻译模型会自动从[笑脸huggingface--utrobinmv/t5_translate_en_ru_zh_small_1024](https://huggingface.co/utrobinmv/t5_translate_en_ru_zh_small_1024--212MB)下载到`C:\Users\username\.cache\huggingface\hub`或者 [魔搭modelscope--damo\nlp_csanmt_translation_zh2en--7.3GB](https://www.modelscope.cn/models/iic/nlp_csanmt_translation_zh2en)下载到`C:\Users\username\.cache\modelscope\hub\damo`位置。可以手动从前面链接下载,然后把所有文件放到`ComfyUI\models\prompt_generator\models--utrobinmv--t5_translate_en_ru_zh_small_1024`或者`ComfyUI\models\prompt_generator\nlp_csanmt_translation_zh2en`
|
|||
|
- ![](./zh2en_model.jpg)
|
|||
|
- **AnyText模型本身是一个标准的sd1.5文生图模型。**
|
|||
|
|
|||
|
## 示例提示词:
|
|||
|
### 文本生成英文提示词:
|
|||
|
- An exquisite mug with an ancient Chinese poem engraved on it, including “花落知多少” and “夜来风雨声” and “处处闻啼鸟” and “春眠不觉晓”
|
|||
|
- Sign on the clean building that reads “科学” and "과학" and "ステップ" and "SCIENCE"
|
|||
|
- An ice sculpture is made with the text "Happy" and "Holidays".Dslr photo.
|
|||
|
- A baseball cap with words “要聪明地” and “全力以赴”
|
|||
|
- A nice drawing of octopus, sharks, and boats made by a child with crayons, with the words “神奇海底世界”
|
|||
|
### 文本编辑英文提示词
|
|||
|
- A Minion meme that says "wrong"
|
|||
|
- A pile of fruit with "UIT" written in the middle
|
|||
|
- photo of clean sandy beach," " " "
|
|||
|
### 文本生成中文提示词:
|
|||
|
- 一个儿童蜡笔画,森林里有一个可爱的蘑菇形状的房子,标题是"森林小屋"
|
|||
|
- 一个精美设计的logo,画的是一个黑白风格的厨师,带着厨师帽,logo下方写着“深夜食堂”
|
|||
|
- 一张户外雪地靴的电商广告,上面写着 “双12大促!”,“立减50”,“加绒加厚”,“穿脱方便”,“温暖24小时送达”, “包邮”,高级设计感,精美构图
|
|||
|
- 一个精致的马克杯,上面雕刻着一首中国古诗,内容是 "花落知多少" "夜来风雨声" "处处闻啼鸟" "春眠不觉晓"
|
|||
|
- 一个漂亮的蜡笔画,有行星,宇航员,还有宇宙飞船,上面写的是"去火星旅行", "王小明", "11月1日"
|
|||
|
- 一个装饰华丽的蛋糕,上面用奶油写着“阿里云”和"APSARA"
|
|||
|
- 一张关于墙上的彩色涂鸦艺术的摄影作品,上面写着“人工智能" 和 "神经网络"
|
|||
|
- 一枚中国古代铜钱, 上面的文字是 "康" "寶" "通" "熙"
|
|||
|
- 精美的书法作品,上面写着“志” “存” “高” “远”
|
|||
|
### 文本编辑中文提示词:
|
|||
|
- 一个表情包,小猪说 "下班"
|
|||
|
- 一个中国古代铜钱,上面写着"乾" "隆"
|
|||
|
- 一个黄色标志牌,上边写着"不要" 和 "大意"
|
|||
|
- 一个建筑物前面的字母标牌, 上面写着 " "
|
|||
|
## 示例工作流:
|
|||
|
|
|||
|
![workflow](./AnyText-wf.png)
|
|||
|
|
|||
|
## 部分参数:
|
|||
|
|
|||
|
### sort_radio: 位置排序,位置排序时的优先级。
|
|||
|
|
|||
|
- ↕代表Y轴,这个选项会按照遮罩(mask)位置从上到下生成,提示词里面的从开始到结束顺序的字符串(""内的内容)。
|
|||
|
- ↔代表X轴,这个选项会按照遮罩(mask)位置从左到右生成,提示词里面的从开始到结束顺序的字符串(""内的内容)。
|
|||
|
|
|||
|
### revise_pose: 修正位置(仅text-generation模式生效)。
|
|||
|
|
|||
|
- 尝试通过渲染后的文字行的外接矩形框修正位置,但是这个选项对生成的图片创造性有一定影响。
|
|||
|
|
|||
|
### Random_Gen: 自动生成随机位置遮罩。
|
|||
|
|
|||
|
- 根据提示词内字符串数量自动生成遮罩,启用这个选项时手动绘制的遮罩图不生效。
|
|||
|
|
|||
|
### nonEdit_random_gen_width & nonEdit_random_gen_height:
|
|||
|
|
|||
|
- 当**text-generation和Random_Gen**一起使用时控制图片尺寸,仅此时生效。
|
|||
|
|
|||
|
### cpu_offload:
|
|||
|
|
|||
|
- 如果是多轮生成,能大幅提速。但是需要在最后不再需要这个节点时且还有后续其他流程,最后关掉这个选项跑一次,来释放转移到cpu上的模型。如果仅生成一次,不要开这个选项。
|
|||
|
|
|||
|
## 鸣谢:
|
|||
|
### [Fork Repo: MaletteAI/anytext](https://github.com/MaletteAI/anytext)
|
|||
|
- V2构建本地管线思路的来源。
|
|||
|
### [Official Repo: tyxsspa/AnyText](https://github.com/tyxsspa/AnyText)
|
|||
|
|
|||
|
```
|
|||
|
@article{tuo2023anytext,
|
|||
|
title={AnyText: Multilingual Visual Text Generation And Editing},
|
|||
|
author={Yuxiang Tuo and Wangmeng Xiang and Jun-Yan He and Yifeng Geng and Xuansong Xie},
|
|||
|
year={2023},
|
|||
|
eprint={2311.03054},
|
|||
|
archivePrefix={arXiv},
|
|||
|
primaryClass={cs.CV}
|
|||
|
}
|
|||
|
```
|