添加图片生成接口插件
Browse files- crazy_functional.py +10 -0
- crazy_functions/图片生成.py +64 -0
crazy_functional.py
CHANGED
@@ -236,5 +236,15 @@ def get_crazy_functions():
|
|
236 |
"Function": HotReload(同时问询_指定模型)
|
237 |
},
|
238 |
})
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
239 |
###################### 第n组插件 ###########################
|
240 |
return function_plugins
|
|
|
236 |
"Function": HotReload(同时问询_指定模型)
|
237 |
},
|
238 |
})
|
239 |
+
from crazy_functions.图片生成 import 图片生成
|
240 |
+
function_plugins.update({
|
241 |
+
"图片生成(先切换模型到openai或api2d)": {
|
242 |
+
"Color": "stop",
|
243 |
+
"AsButton": False,
|
244 |
+
"AdvancedArgs": True, # 调用时,唤起高级参数输入区(默认False)
|
245 |
+
"ArgsReminder": "在这里输入分辨率, 如256x256(默认)", # 高级参数输入区的显示提示
|
246 |
+
"Function": HotReload(图片生成)
|
247 |
+
},
|
248 |
+
})
|
249 |
###################### 第n组插件 ###########################
|
250 |
return function_plugins
|
crazy_functions/图片生成.py
ADDED
@@ -0,0 +1,64 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
from toolbox import CatchException, update_ui, get_conf, select_api_key
|
2 |
+
from .crazy_utils import request_gpt_model_in_new_thread_with_ui_alive
|
3 |
+
import datetime
|
4 |
+
|
5 |
+
|
6 |
+
def gen_image(llm_kwargs, prompt, resolution="256x256"):
|
7 |
+
import requests, json, time, os
|
8 |
+
from request_llm.bridge_all import model_info
|
9 |
+
|
10 |
+
proxies, = get_conf('proxies')
|
11 |
+
# Set up OpenAI API key and model
|
12 |
+
api_key = select_api_key(llm_kwargs['api_key'], llm_kwargs['llm_model'])
|
13 |
+
chat_endpoint = model_info[llm_kwargs['llm_model']]['endpoint']
|
14 |
+
# 'https://api.openai.com/v1/chat/completions'
|
15 |
+
img_endpoint = chat_endpoint.replace('chat/completions','images/generations')
|
16 |
+
# # Generate the image
|
17 |
+
url = img_endpoint
|
18 |
+
headers = {
|
19 |
+
'Authorization': f"Bearer {api_key}",
|
20 |
+
'Content-Type': 'application/json'
|
21 |
+
}
|
22 |
+
data = {
|
23 |
+
'prompt': prompt,
|
24 |
+
'n': 1,
|
25 |
+
'size': '256x256',
|
26 |
+
'response_format': 'url'
|
27 |
+
}
|
28 |
+
response = requests.post(url, headers=headers, json=data, proxies=proxies)
|
29 |
+
print(response.content)
|
30 |
+
image_url = json.loads(response.content.decode('utf8'))['data'][0]['url']
|
31 |
+
|
32 |
+
# 文件保存到本地
|
33 |
+
r = requests.get(image_url, proxies=proxies)
|
34 |
+
file_path = 'gpt_log/image_gen/'
|
35 |
+
os.makedirs(file_path, exist_ok=True)
|
36 |
+
file_name = 'Image' + time.strftime("%Y-%m-%d-%H-%M-%S", time.localtime()) + '.png'
|
37 |
+
with open(file_path+file_name, 'wb+') as f: f.write(r.content)
|
38 |
+
|
39 |
+
|
40 |
+
return image_url, file_path+file_name
|
41 |
+
|
42 |
+
|
43 |
+
|
44 |
+
@CatchException
|
45 |
+
def 图片生成(prompt, llm_kwargs, plugin_kwargs, chatbot, history, system_prompt, web_port):
|
46 |
+
"""
|
47 |
+
txt 输入栏用户输入的文本,例如需要翻译的一段话,再例如一个包含了待处理文件的路径
|
48 |
+
llm_kwargs gpt模型参数,如温度和top_p等,一般原样传递下去就行
|
49 |
+
plugin_kwargs 插件模型的参数,暂时没有用武之地
|
50 |
+
chatbot 聊天显示框的句柄,用于显示给用户
|
51 |
+
history 聊天历史,前情提要
|
52 |
+
system_prompt 给gpt的静默提醒
|
53 |
+
web_port 当前软件运行的端口号
|
54 |
+
"""
|
55 |
+
history = [] # 清空历史,以免输入溢出
|
56 |
+
chatbot.append(("这是什么功能?", "[Local Message] 生成图像, 请先把模型切换至gpt-xxxx或者api2d-xxxx。如果中文效果不理想, 尝试Prompt。正在处理中 ....."))
|
57 |
+
yield from update_ui(chatbot=chatbot, history=history) # 刷新界面 # 由于请求gpt需要一段时间,我们先及时地做一次界面更新
|
58 |
+
resolution = plugin_kwargs.get("advanced_arg", '256x256')
|
59 |
+
image_url, image_path = gen_image(llm_kwargs, prompt, resolution)
|
60 |
+
chatbot.append([prompt,
|
61 |
+
f'`{image_url}`\n\n'+
|
62 |
+
f'<div align="center"><img src="file={image_path}"></div>'
|
63 |
+
])
|
64 |
+
yield from update_ui(chatbot=chatbot, history=history) # 刷新界面 # 界面更新
|