|
@@ -5,9 +5,9 @@ import cn.hutool.core.date.DateUtil;
|
|
import cn.hutool.json.JSONObject;
|
|
import cn.hutool.json.JSONObject;
|
|
import cn.hutool.json.JSONUtil;
|
|
import cn.hutool.json.JSONUtil;
|
|
import com.backendsys.exception.CustException;
|
|
import com.backendsys.exception.CustException;
|
|
-import com.backendsys.modules.common.config.security.utils.SecurityUtil;
|
|
|
|
import com.backendsys.modules.crt.dao.CrtDramaProjectSettingsDao;
|
|
import com.backendsys.modules.crt.dao.CrtDramaProjectSettingsDao;
|
|
import com.backendsys.modules.crt.dao.CrtDramaProjectStoryboardDao;
|
|
import com.backendsys.modules.crt.dao.CrtDramaProjectStoryboardDao;
|
|
|
|
+import com.backendsys.modules.crt.dao.CrtGenerateImageDao;
|
|
import com.backendsys.modules.crt.dao.CrtModelDao;
|
|
import com.backendsys.modules.crt.dao.CrtModelDao;
|
|
import com.backendsys.modules.crt.entity.CrtDramaProjectSettings;
|
|
import com.backendsys.modules.crt.entity.CrtDramaProjectSettings;
|
|
import com.backendsys.modules.crt.entity.CrtDramaProjectStoryboard;
|
|
import com.backendsys.modules.crt.entity.CrtDramaProjectStoryboard;
|
|
@@ -19,6 +19,11 @@ import com.backendsys.modules.sdk.comfyui.entity.CFPromptResponse;
|
|
import com.backendsys.modules.sdk.comfyui.entity.CFQueue;
|
|
import com.backendsys.modules.sdk.comfyui.entity.CFQueue;
|
|
import com.backendsys.modules.sdk.comfyui.service.ComfyUIService;
|
|
import com.backendsys.modules.sdk.comfyui.service.ComfyUIService;
|
|
import com.backendsys.modules.sdk.comfyui.service.ComfyUISocketService;
|
|
import com.backendsys.modules.sdk.comfyui.service.ComfyUISocketService;
|
|
|
|
+import com.backendsys.modules.upload.enums.StyleEnums;
|
|
|
|
+import com.backendsys.modules.upload.utils.UploadUtil;
|
|
|
|
+import com.backendsys.utils.response.PageEntity;
|
|
|
|
+import com.backendsys.utils.response.PageInfoResult;
|
|
|
|
+import com.backendsys.utils.v2.PageUtils;
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.stereotype.Service;
|
|
import org.springframework.stereotype.Service;
|
|
@@ -28,6 +33,7 @@ import java.util.LinkedHashMap;
|
|
import java.util.List;
|
|
import java.util.List;
|
|
import java.util.Map;
|
|
import java.util.Map;
|
|
import java.util.UUID;
|
|
import java.util.UUID;
|
|
|
|
+import java.util.stream.Collectors;
|
|
|
|
|
|
@Service
|
|
@Service
|
|
public class CrtGenerateServiceImpl implements CrtGenerateService {
|
|
public class CrtGenerateServiceImpl implements CrtGenerateService {
|
|
@@ -43,6 +49,8 @@ public class CrtGenerateServiceImpl implements CrtGenerateService {
|
|
private CrtDramaProjectSettingsDao crtDramaProjectSettingsDao;
|
|
private CrtDramaProjectSettingsDao crtDramaProjectSettingsDao;
|
|
@Autowired
|
|
@Autowired
|
|
private CrtDramaProjectStoryboardDao crtDramaProjectStoryboardDao;
|
|
private CrtDramaProjectStoryboardDao crtDramaProjectStoryboardDao;
|
|
|
|
+ @Autowired
|
|
|
|
+ private CrtGenerateImageDao crtGenerateImageDao;
|
|
|
|
|
|
/**
|
|
/**
|
|
* [ComfyUI] 查询任务队列
|
|
* [ComfyUI] 查询任务队列
|
|
@@ -85,9 +93,17 @@ public class CrtGenerateServiceImpl implements CrtGenerateService {
|
|
System.out.println("- 生图配置: " + JSONUtil.toJsonStr(settings_image));
|
|
System.out.println("- 生图配置: " + JSONUtil.toJsonStr(settings_image));
|
|
System.out.println("- 生视频配置: " + JSONUtil.toJsonStr(settings_video));
|
|
System.out.println("- 生视频配置: " + JSONUtil.toJsonStr(settings_video));
|
|
|
|
|
|
|
|
+ // 用于更新的参数实体类
|
|
|
|
+ CrtDramaProjectStoryboard entity = new CrtDramaProjectStoryboard();
|
|
|
|
+ LambdaQueryWrapper<CrtDramaProjectStoryboard> wrapper = new LambdaQueryWrapper<>();
|
|
|
|
+ wrapper.eq(CrtDramaProjectStoryboard::getId, drama_project_storyboard_id);
|
|
|
|
+
|
|
|
|
+
|
|
|
|
|
|
// 文生图提示词
|
|
// 文生图提示词
|
|
String text_to_image_prompt = crtDramaProjectStoryboard.getText_to_image_prompt();
|
|
String text_to_image_prompt = crtDramaProjectStoryboard.getText_to_image_prompt();
|
|
|
|
+ // [更新] 文生图提示词
|
|
|
|
+ entity.setText_to_image_prompt(text_to_image_prompt);
|
|
|
|
|
|
// == 从 storboard detail 获取参数 =============================================================================
|
|
// == 从 storboard detail 获取参数 =============================================================================
|
|
Integer param_batch_size = storyboardDetail.getParam_batch_size(); // 生成图片数量
|
|
Integer param_batch_size = storyboardDetail.getParam_batch_size(); // 生成图片数量
|
|
@@ -100,16 +116,13 @@ public class CrtGenerateServiceImpl implements CrtGenerateService {
|
|
String param_seed_custom = storyboardDetail.getParam_seed_custom();
|
|
String param_seed_custom = storyboardDetail.getParam_seed_custom();
|
|
if (param_seed == 1) {
|
|
if (param_seed == 1) {
|
|
param_seed_custom = Convert.toStr(DateUtil.current()); // 生成一个随机值 (毫秒时间戳)
|
|
param_seed_custom = Convert.toStr(DateUtil.current()); // 生成一个随机值 (毫秒时间戳)
|
|
-
|
|
|
|
- // 【随机值,要保存到数据库】
|
|
|
|
- CrtDramaProjectStoryboard entity = new CrtDramaProjectStoryboard();
|
|
|
|
|
|
+ // [更新] 种子值
|
|
entity.setParam_seed_custom(param_seed_custom);
|
|
entity.setParam_seed_custom(param_seed_custom);
|
|
- LambdaQueryWrapper<CrtDramaProjectStoryboard> wrapper = new LambdaQueryWrapper<>();
|
|
|
|
- wrapper.eq(CrtDramaProjectStoryboard::getId, drama_project_storyboard_id);
|
|
|
|
- crtDramaProjectStoryboardDao.update(entity, wrapper);
|
|
|
|
-
|
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ // [db] 更新分集记录
|
|
|
|
+ crtDramaProjectStoryboardDao.update(entity, wrapper);
|
|
|
|
+
|
|
|
|
|
|
|
|
|
|
// [db] 获取基础模型 (从项目配置)
|
|
// [db] 获取基础模型 (从项目配置)
|
|
@@ -117,16 +130,13 @@ public class CrtGenerateServiceImpl implements CrtGenerateService {
|
|
CrtModel modelDetail = crtModelDao.selectById(model_id);
|
|
CrtModel modelDetail = crtModelDao.selectById(model_id);
|
|
String model_name = modelDetail.getModel_name();
|
|
String model_name = modelDetail.getModel_name();
|
|
|
|
|
|
-
|
|
|
|
// 风格 Lora?
|
|
// 风格 Lora?
|
|
// 风格 Lora (阙值)?
|
|
// 风格 Lora (阙值)?
|
|
|
|
|
|
-
|
|
|
|
// ===========================================================================================================
|
|
// ===========================================================================================================
|
|
|
|
|
|
|
|
|
|
|
|
|
|
-
|
|
|
|
// -- 前端生成的UUID ---------------------------------------------
|
|
// -- 前端生成的UUID ---------------------------------------------
|
|
String client_id = Convert.toStr(UUID.randomUUID());
|
|
String client_id = Convert.toStr(UUID.randomUUID());
|
|
|
|
|
|
@@ -535,4 +545,33 @@ public class CrtGenerateServiceImpl implements CrtGenerateService {
|
|
return resp;
|
|
return resp;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ // 短剧创作-获取分集生图记录
|
|
|
|
+ @Override
|
|
|
|
+ public PageEntity selectGenerateImage(CrtDramaProjectStoryboard crtDramaProjectStoryboard) {
|
|
|
|
+ PageUtils.startPage(); // 分页
|
|
|
|
+
|
|
|
|
+ Long drama_project_storyboard_id = crtDramaProjectStoryboard.getDrama_project_storyboard_id();
|
|
|
|
+
|
|
|
|
+ LambdaQueryWrapper<CrtGenerateImage> wrapper = new LambdaQueryWrapper<>();
|
|
|
|
+ wrapper.eq(CrtGenerateImage::getDrama_project_storyboard_id, drama_project_storyboard_id);
|
|
|
|
+ wrapper.orderByDesc(CrtGenerateImage::getCreate_time);
|
|
|
|
+ List<CrtGenerateImage> list = crtGenerateImageDao.selectList(wrapper);
|
|
|
|
+
|
|
|
|
+ // 加入缩略图
|
|
|
|
+ if (!list.isEmpty()) {
|
|
|
|
+ // 1) 完成分页实体渲染
|
|
|
|
+ PageEntity pageEntity = new PageInfoResult(list).toEntity();
|
|
|
|
+ // 2) 分页列表格式化
|
|
|
|
+ list = list.stream().map(item -> {
|
|
|
|
+ item.setUrl_thumb(UploadUtil.getImageThumbUrl(item.getUrl(), item.getTarget(), 100, null, StyleEnums.THUMB_BACKGROUND.getValue()));
|
|
|
|
+ return item;
|
|
|
|
+ }).collect(Collectors.toList());
|
|
|
|
+ // 3) 分页实体重新赋值
|
|
|
|
+ List<Object> objectList = list.stream().map(item -> (Object) item).collect(Collectors.toList());
|
|
|
|
+ pageEntity.setList(objectList);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ return new PageInfoResult(list).toEntity();
|
|
|
|
+ }
|
|
|
|
+
|
|
}
|
|
}
|