Merge remote-tracking branch 'origin/dev/dev-ltx' into dev/dev
This commit is contained in:
@@ -10,5 +10,9 @@ public class CommonConstants {
|
|||||||
|
|
||||||
public static final int CONN_TIMEOUT = 30000; // (milliseconds)
|
public static final int CONN_TIMEOUT = 30000; // (milliseconds)
|
||||||
|
|
||||||
|
public static final String OUTFIT = "Outfit";
|
||||||
|
public static final String TRYON = "Try-on";
|
||||||
|
public static final String GENAI = "Gen-AI";
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -78,4 +78,28 @@ public class StyleController {
|
|||||||
return ApiResponse.success(styleService.getOutfitResult(requestIDs));
|
return ApiResponse.success(styleService.getOutfitResult(requestIDs));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 设置喜欢的风格
|
||||||
|
*/
|
||||||
|
@Operation(summary = "设置喜欢的outfit", description = "将指定风格设置为收藏")
|
||||||
|
@PostMapping("/set-favorite/{styleId}")
|
||||||
|
public ApiResponse<Void> setFavoriteStyle(
|
||||||
|
@Parameter(description = "风格ID", required = true)
|
||||||
|
@PathVariable Long styleId) {
|
||||||
|
styleService.setFavoriteStyle(styleId);
|
||||||
|
return ApiResponse.success();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 取消喜欢的风格
|
||||||
|
*/
|
||||||
|
@Operation(summary = "取消喜欢的outfit", description = "取消指定风格的收藏")
|
||||||
|
@PostMapping("/cancel-favorite/{styleId}")
|
||||||
|
public ApiResponse<Void> cancelFavoriteStyle(
|
||||||
|
@Parameter(description = "风格ID", required = true)
|
||||||
|
@PathVariable Long styleId) {
|
||||||
|
styleService.cancelFavoriteStyle(styleId);
|
||||||
|
return ApiResponse.success();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -1,10 +1,14 @@
|
|||||||
package com.aida.lanecarford.controller;
|
package com.aida.lanecarford.controller;
|
||||||
|
|
||||||
import com.aida.lanecarford.common.ApiResponse;
|
import com.aida.lanecarford.common.ApiResponse;
|
||||||
|
import com.aida.lanecarford.common.constant.CommonConstants;
|
||||||
|
import com.aida.lanecarford.dto.HistoricalDTO;
|
||||||
import com.aida.lanecarford.entity.Suggestion;
|
import com.aida.lanecarford.entity.Suggestion;
|
||||||
import com.aida.lanecarford.entity.TryOnEffect;
|
import com.aida.lanecarford.entity.TryOnEffect;
|
||||||
import com.aida.lanecarford.service.TryOnEffectService;
|
import com.aida.lanecarford.service.TryOnEffectService;
|
||||||
import com.aida.lanecarford.vo.TryOnResultVo;
|
import com.aida.lanecarford.vo.BaseVO;
|
||||||
|
import com.aida.lanecarford.vo.OutfitHisVO;
|
||||||
|
import com.aida.lanecarford.vo.TryOnResultVO;
|
||||||
import io.netty.util.internal.StringUtil;
|
import io.netty.util.internal.StringUtil;
|
||||||
import io.swagger.v3.oas.annotations.Operation;
|
import io.swagger.v3.oas.annotations.Operation;
|
||||||
import io.swagger.v3.oas.annotations.Parameter;
|
import io.swagger.v3.oas.annotations.Parameter;
|
||||||
@@ -32,29 +36,25 @@ public class TryOnEffectController {
|
|||||||
|
|
||||||
@Operation(summary = "生成试穿效果", description = "根据服装,模特照片生成试穿效果,其中styleId是必选,当二次生成时,要带上相关参数,比如顾客照片")
|
@Operation(summary = "生成试穿效果", description = "根据服装,模特照片生成试穿效果,其中styleId是必选,当二次生成时,要带上相关参数,比如顾客照片")
|
||||||
@PostMapping("/generate")
|
@PostMapping("/generate")
|
||||||
public ApiResponse<TryOnResultVo> generateTryOnEffect(
|
public ApiResponse<TryOnResultVO> generateTryOnEffect(
|
||||||
@Parameter(description = "试穿效果请求参数", required = true)
|
@Parameter(description = "试穿效果请求参数", required = true)
|
||||||
@Valid @RequestBody TryOnEffect tryOnEffectDto) {
|
@Valid @RequestBody TryOnEffect tryOnEffectDto) {
|
||||||
TryOnResultVo tryOnResultVo = tryOnEffectService.generateTryOnEffect(tryOnEffectDto);
|
TryOnResultVO tryOnResultVo = tryOnEffectService.generateTryOnEffect(tryOnEffectDto);
|
||||||
return ApiResponse.success(tryOnResultVo);
|
return ApiResponse.success(tryOnResultVo);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Operation(summary = "获取收藏的试穿效果", description = "对应library页面点击details后的显示,参数为进店记录id")
|
@Operation(summary = "获取历史生成记录", description = "根据type,进店记录id,是否收藏来决定返回的数据")
|
||||||
@GetMapping("/favorites/{visitRecordId}")
|
@GetMapping("/getHistoricals")
|
||||||
public ApiResponse<List<TryOnResultVo>> getFavoriteTryOnEffects(
|
public ApiResponse<List<? extends BaseVO>> getHistoricals(
|
||||||
@Parameter(description = "进店记录ID", required = true)
|
|
||||||
@PathVariable Long visitRecordId) {
|
|
||||||
List<TryOnResultVo> tryOnResultVos = tryOnEffectService.getFavoriteTryOnEffects(visitRecordId);
|
|
||||||
return ApiResponse.success(tryOnResultVos);
|
|
||||||
}
|
|
||||||
|
|
||||||
@GetMapping("/style/{styleId}")
|
|
||||||
@Operation(summary = "获取某套服装的所有生成结果", description = "对应customize your look页面点击finish后的显示")
|
|
||||||
public ApiResponse<List<TryOnResultVo>> getTryOnEffectsByStyleId(
|
|
||||||
@Parameter(description = "服装ID", required = true)
|
@Parameter(description = "服装ID", required = true)
|
||||||
@PathVariable Long styleId) {
|
@RequestBody HistoricalDTO historicalDTO) {
|
||||||
List<TryOnResultVo> tryOnResultVos = tryOnEffectService.getTryOnEffectsByStyleId(styleId);
|
if (CommonConstants.OUTFIT.equals(historicalDTO.getType())){
|
||||||
return ApiResponse.success(tryOnResultVos);
|
List<OutfitHisVO> outfitHisVOS = tryOnEffectService.getOutfitHistoricals(historicalDTO);
|
||||||
|
return ApiResponse.success(outfitHisVOS);
|
||||||
|
}else {
|
||||||
|
List<TryOnResultVO> tryOnResultVos = tryOnEffectService.getTryOnHistoricals(historicalDTO);
|
||||||
|
return ApiResponse.success(tryOnResultVos);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
17
src/main/java/com/aida/lanecarford/dto/HistoricalDTO.java
Normal file
17
src/main/java/com/aida/lanecarford/dto/HistoricalDTO.java
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
package com.aida.lanecarford.dto;
|
||||||
|
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
public class HistoricalDTO {
|
||||||
|
@Schema(description = "进店记录ID",example = "1")
|
||||||
|
private Long visitRecordId;
|
||||||
|
|
||||||
|
@Schema(description = "类型",example = "Outfit , Try-on , Gen-AI")
|
||||||
|
private String type;
|
||||||
|
|
||||||
|
@Schema(description = "是否是收藏",example = "true")
|
||||||
|
private Boolean isLibrary;
|
||||||
|
|
||||||
|
}
|
||||||
@@ -1,6 +1,7 @@
|
|||||||
package com.aida.lanecarford.entity;
|
package com.aida.lanecarford.entity;
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.annotation.*;
|
import com.baomidou.mybatisplus.annotation.*;
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
@@ -76,4 +77,11 @@ public class Style extends BaseEntity {
|
|||||||
private String errorMessage;
|
private String errorMessage;
|
||||||
|
|
||||||
// 注意:createdTime、updatedTime 字段已在 BaseEntity 中定义
|
// 注意:createdTime、updatedTime 字段已在 BaseEntity 中定义
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 是否喜欢(0-否,1-是)
|
||||||
|
*/
|
||||||
|
@Schema(description = "是否喜欢(0-否,1-是)", example = "1", required = false)
|
||||||
|
@TableField("is_favorite")
|
||||||
|
private Integer isFavorite;
|
||||||
}
|
}
|
||||||
@@ -19,4 +19,16 @@ public interface StyleService extends IService<Style> {
|
|||||||
|
|
||||||
List<OutfitResultVO> getOutfitResult(List<String> requestIDs);
|
List<OutfitResultVO> getOutfitResult(List<String> requestIDs);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 设置风格为收藏
|
||||||
|
* @param styleId 风格ID
|
||||||
|
*/
|
||||||
|
void setFavoriteStyle(Long styleId);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 取消风格的收藏
|
||||||
|
* @param styleId 风格ID
|
||||||
|
*/
|
||||||
|
void cancelFavoriteStyle(Long styleId);
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -1,8 +1,10 @@
|
|||||||
package com.aida.lanecarford.service;
|
package com.aida.lanecarford.service;
|
||||||
|
|
||||||
|
import com.aida.lanecarford.dto.HistoricalDTO;
|
||||||
import com.aida.lanecarford.entity.Suggestion;
|
import com.aida.lanecarford.entity.Suggestion;
|
||||||
import com.aida.lanecarford.entity.TryOnEffect;
|
import com.aida.lanecarford.entity.TryOnEffect;
|
||||||
import com.aida.lanecarford.vo.TryOnResultVo;
|
import com.aida.lanecarford.vo.OutfitHisVO;
|
||||||
|
import com.aida.lanecarford.vo.TryOnResultVO;
|
||||||
import com.baomidou.mybatisplus.extension.service.IService;
|
import com.baomidou.mybatisplus.extension.service.IService;
|
||||||
import jakarta.validation.Valid;
|
import jakarta.validation.Valid;
|
||||||
|
|
||||||
@@ -16,9 +18,9 @@ import java.util.List;
|
|||||||
*/
|
*/
|
||||||
public interface TryOnEffectService extends IService<TryOnEffect> {
|
public interface TryOnEffectService extends IService<TryOnEffect> {
|
||||||
|
|
||||||
TryOnResultVo generateTryOnEffect(@Valid TryOnEffect tryOnEffectDto);
|
TryOnResultVO generateTryOnEffect(@Valid TryOnEffect tryOnEffectDto);
|
||||||
|
|
||||||
List<TryOnResultVo> getFavoriteTryOnEffects(Long visitRecordId);
|
List<TryOnResultVO> getFavoriteTryOnEffects(Long visitRecordId);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 设置试穿效果为收藏
|
* 设置试穿效果为收藏
|
||||||
@@ -32,7 +34,7 @@ public interface TryOnEffectService extends IService<TryOnEffect> {
|
|||||||
*/
|
*/
|
||||||
void cancelFavoriteTryOnEffect(Long tryOnId);
|
void cancelFavoriteTryOnEffect(Long tryOnId);
|
||||||
|
|
||||||
List<TryOnResultVo> getTryOnEffectsByStyleId(Long styleId);
|
List<TryOnResultVO> getTryOnEffectsByStyleId(Long styleId);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 添加意见建议
|
* 添加意见建议
|
||||||
@@ -44,4 +46,8 @@ public interface TryOnEffectService extends IService<TryOnEffect> {
|
|||||||
String reFace(Long customerPhotoId);
|
String reFace(Long customerPhotoId);
|
||||||
|
|
||||||
String generateUrl(String prompt, String tryonUrl);
|
String generateUrl(String prompt, String tryonUrl);
|
||||||
|
|
||||||
|
List<TryOnResultVO> getTryOnHistoricals(HistoricalDTO historicalDTO);
|
||||||
|
|
||||||
|
List<OutfitHisVO> getOutfitHistoricals(HistoricalDTO historicalDTO);
|
||||||
}
|
}
|
||||||
@@ -4,6 +4,7 @@ import com.aida.lanecarford.common.constant.CommonConstants;
|
|||||||
import com.aida.lanecarford.common.constant.RedisURIConstants;
|
import com.aida.lanecarford.common.constant.RedisURIConstants;
|
||||||
import com.aida.lanecarford.common.enums.StatusEnum;
|
import com.aida.lanecarford.common.enums.StatusEnum;
|
||||||
import com.aida.lanecarford.common.enums.StylistPathEnum;
|
import com.aida.lanecarford.common.enums.StylistPathEnum;
|
||||||
|
import com.aida.lanecarford.common.response.ResultEnum;
|
||||||
import com.aida.lanecarford.dto.OutfitCallbackDTO;
|
import com.aida.lanecarford.dto.OutfitCallbackDTO;
|
||||||
import com.aida.lanecarford.dto.RequestOutfitDTO;
|
import com.aida.lanecarford.dto.RequestOutfitDTO;
|
||||||
import com.aida.lanecarford.entity.OutfitRequest;
|
import com.aida.lanecarford.entity.OutfitRequest;
|
||||||
@@ -206,4 +207,38 @@ public class StyleServiceImpl extends ServiceImpl<StyleMapper, Style> implements
|
|||||||
return resultVOS;
|
return resultVOS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setFavoriteStyle(Long styleId) {
|
||||||
|
if (styleId == null) {
|
||||||
|
throw new BusinessException("Style ID is required", "风格ID不能为空", ResultEnum.PARAMETER_ERROR.getCode());
|
||||||
|
}
|
||||||
|
|
||||||
|
Style style = this.getById(styleId);
|
||||||
|
if (style == null) {
|
||||||
|
throw new BusinessException("Style not found", "风格不存在", ResultEnum.FAIL.getCode());
|
||||||
|
}
|
||||||
|
|
||||||
|
// 设置为收藏
|
||||||
|
style.setIsFavorite(1);
|
||||||
|
this.updateById(style);
|
||||||
|
log.info("风格ID: {} 已设置为收藏", styleId);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void cancelFavoriteStyle(Long styleId) {
|
||||||
|
if (styleId == null) {
|
||||||
|
throw new BusinessException("Style ID is required", "风格ID不能为空", ResultEnum.PARAMETER_ERROR.getCode());
|
||||||
|
}
|
||||||
|
|
||||||
|
Style style = this.getById(styleId);
|
||||||
|
if (style == null) {
|
||||||
|
throw new BusinessException("Style not found", "风格不存在", ResultEnum.FAIL.getCode());
|
||||||
|
}
|
||||||
|
|
||||||
|
// 取消收藏
|
||||||
|
style.setIsFavorite(0);
|
||||||
|
this.updateById(style);
|
||||||
|
log.info("风格ID: {} 已取消收藏", styleId);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -6,6 +6,7 @@ import com.aida.lanecarford.config.MinioConfig;
|
|||||||
import com.aida.lanecarford.config.FaceSwapConfig;
|
import com.aida.lanecarford.config.FaceSwapConfig;
|
||||||
import com.aida.lanecarford.common.response.ResultEnum;
|
import com.aida.lanecarford.common.response.ResultEnum;
|
||||||
import com.aida.lanecarford.common.constant.MinioFileConstants;
|
import com.aida.lanecarford.common.constant.MinioFileConstants;
|
||||||
|
import com.aida.lanecarford.dto.HistoricalDTO;
|
||||||
import com.aida.lanecarford.entity.*;
|
import com.aida.lanecarford.entity.*;
|
||||||
import com.aida.lanecarford.exception.BusinessException;
|
import com.aida.lanecarford.exception.BusinessException;
|
||||||
import com.aida.lanecarford.mapper.CustomerMapper;
|
import com.aida.lanecarford.mapper.CustomerMapper;
|
||||||
@@ -16,7 +17,8 @@ import com.aida.lanecarford.service.*;
|
|||||||
import com.aida.lanecarford.entity.Suggestion;
|
import com.aida.lanecarford.entity.Suggestion;
|
||||||
import com.aida.lanecarford.util.MinioUtil;
|
import com.aida.lanecarford.util.MinioUtil;
|
||||||
import com.aida.lanecarford.util.StringListConverter;
|
import com.aida.lanecarford.util.StringListConverter;
|
||||||
import com.aida.lanecarford.vo.TryOnResultVo;
|
import com.aida.lanecarford.vo.OutfitHisVO;
|
||||||
|
import com.aida.lanecarford.vo.TryOnResultVO;
|
||||||
import com.alibaba.fastjson.JSON;
|
import com.alibaba.fastjson.JSON;
|
||||||
import com.alibaba.fastjson.JSONArray;
|
import com.alibaba.fastjson.JSONArray;
|
||||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||||
@@ -59,7 +61,7 @@ public class TryOnEffectServiceImpl extends ServiceImpl<TryOnEffectMapper, TryOn
|
|||||||
private final OutfitRequestMapper outfitRequestMapper;
|
private final OutfitRequestMapper outfitRequestMapper;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public TryOnResultVo generateTryOnEffect(TryOnEffect tryOnEffectDto) {
|
public TryOnResultVO generateTryOnEffect(TryOnEffect tryOnEffectDto) {
|
||||||
Integer isRegenerated = tryOnEffectDto.getIsRegenerated();
|
Integer isRegenerated = tryOnEffectDto.getIsRegenerated();
|
||||||
String toAIlogicalUrl = null;
|
String toAIlogicalUrl = null;
|
||||||
String prompt = null;
|
String prompt = null;
|
||||||
@@ -140,8 +142,8 @@ public class TryOnEffectServiceImpl extends ServiceImpl<TryOnEffectMapper, TryOn
|
|||||||
tryOnEffectDto.setGenerationStatus("completed");
|
tryOnEffectDto.setGenerationStatus("completed");
|
||||||
this.saveOrUpdate(tryOnEffectDto);
|
this.saveOrUpdate(tryOnEffectDto);
|
||||||
|
|
||||||
TryOnResultVo tryOnResultVo = new TryOnResultVo();
|
TryOnResultVO tryOnResultVo = new TryOnResultVO();
|
||||||
tryOnResultVo.setTryOnId(tryOnEffectDto.getId());
|
tryOnResultVo.setId(tryOnEffectDto.getId());
|
||||||
|
|
||||||
tryOnResultVo.setTryOnUrl(minioUtil.convertToPresignedUrl(aiRreultlogicalUrl, CommonConstants.MINIO_PATH_TIMEOUT));
|
tryOnResultVo.setTryOnUrl(minioUtil.convertToPresignedUrl(aiRreultlogicalUrl, CommonConstants.MINIO_PATH_TIMEOUT));
|
||||||
|
|
||||||
@@ -150,15 +152,15 @@ public class TryOnEffectServiceImpl extends ServiceImpl<TryOnEffectMapper, TryOn
|
|||||||
|
|
||||||
//library页面点击details后的显示
|
//library页面点击details后的显示
|
||||||
@Override
|
@Override
|
||||||
public List<TryOnResultVo> getFavoriteTryOnEffects(Long visitRecordId) {
|
public List<TryOnResultVO> getFavoriteTryOnEffects(Long visitRecordId) {
|
||||||
List<TryOnEffect> tryOnEffects = this.list(new LambdaQueryWrapper<TryOnEffect>()
|
List<TryOnEffect> tryOnEffects = this.list(new LambdaQueryWrapper<TryOnEffect>()
|
||||||
.eq(TryOnEffect::getVisitRecordId, visitRecordId)
|
.eq(TryOnEffect::getVisitRecordId, visitRecordId)
|
||||||
.eq(TryOnEffect::getIsFavorite, 1)
|
.eq(TryOnEffect::getIsFavorite, 1)
|
||||||
.orderByAsc(TryOnEffect::getCreatedTime));
|
.orderByDesc(TryOnEffect::getCreatedTime));
|
||||||
List<TryOnResultVo> tryOnResultVos = new ArrayList<>();
|
List<TryOnResultVO> tryOnResultVos = new ArrayList<>();
|
||||||
for (TryOnEffect tryOnEffect : tryOnEffects) {
|
for (TryOnEffect tryOnEffect : tryOnEffects) {
|
||||||
TryOnResultVo tryOnResultVo = new TryOnResultVo();
|
TryOnResultVO tryOnResultVo = new TryOnResultVO();
|
||||||
tryOnResultVo.setTryOnId(tryOnEffect.getId());
|
tryOnResultVo.setId(tryOnEffect.getId());
|
||||||
// 使用新的API获取预签名URL,数据库存储的是逻辑URL
|
// 使用新的API获取预签名URL,数据库存储的是逻辑URL
|
||||||
tryOnResultVo.setTryOnUrl(minioUtil.convertToPresignedUrl(
|
tryOnResultVo.setTryOnUrl(minioUtil.convertToPresignedUrl(
|
||||||
tryOnEffect.getResultImageUrl(),
|
tryOnEffect.getResultImageUrl(),
|
||||||
@@ -255,16 +257,82 @@ public class TryOnEffectServiceImpl extends ServiceImpl<TryOnEffectMapper, TryOn
|
|||||||
return minioUtil.convertToPresignedUrl(aiRreultlogicalUrl, CommonConstants.MINIO_PATH_TIMEOUT);
|
return minioUtil.convertToPresignedUrl(aiRreultlogicalUrl, CommonConstants.MINIO_PATH_TIMEOUT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<TryOnResultVO> getTryOnHistoricals(HistoricalDTO historicalDTO) {
|
||||||
|
LambdaQueryWrapper<TryOnEffect> tryOnEffectLambdaQueryWrapper = new LambdaQueryWrapper<TryOnEffect>()
|
||||||
|
.orderByDesc(TryOnEffect::getCreatedTime);
|
||||||
|
if (historicalDTO.getVisitRecordId() != null){
|
||||||
|
tryOnEffectLambdaQueryWrapper.eq(TryOnEffect::getVisitRecordId, historicalDTO.getVisitRecordId());
|
||||||
|
}
|
||||||
|
if (historicalDTO.getIsLibrary() != null||historicalDTO.getIsLibrary()){
|
||||||
|
tryOnEffectLambdaQueryWrapper.eq(TryOnEffect::getIsFavorite,1);
|
||||||
|
}
|
||||||
|
if (CommonConstants.TRYON.equals(historicalDTO.getType())){
|
||||||
|
tryOnEffectLambdaQueryWrapper.eq(TryOnEffect::getIsRegenerated, 0);
|
||||||
|
}else if (CommonConstants.GENAI.equals(historicalDTO.getType())){
|
||||||
|
tryOnEffectLambdaQueryWrapper.eq(TryOnEffect::getIsRegenerated, 1);
|
||||||
|
}
|
||||||
|
List<TryOnEffect> tryOnEffects = this.list(tryOnEffectLambdaQueryWrapper);
|
||||||
|
List<TryOnResultVO> tryOnResultVos = new ArrayList<>();
|
||||||
|
for (TryOnEffect tryOnEffect : tryOnEffects) {
|
||||||
|
TryOnResultVO tryOnResultVo = new TryOnResultVO();
|
||||||
|
tryOnResultVo.setId(tryOnEffect.getId());
|
||||||
|
tryOnResultVo.setTryOnUrl(minioUtil.convertToPresignedUrl(
|
||||||
|
tryOnEffect.getResultImageUrl(),
|
||||||
|
CommonConstants.MINIO_PATH_TIMEOUT
|
||||||
|
));
|
||||||
|
// 如果是原始效果,则获取对应的style图片
|
||||||
|
if (tryOnEffect.getIsRegenerated() == 0) {
|
||||||
|
LambdaQueryWrapper<Style> styleLambdaQueryWrapper = new LambdaQueryWrapper<>();
|
||||||
|
styleLambdaQueryWrapper.eq(Style::getId, tryOnEffect.getStyleId()).select(Style::getStyleImageUrl);
|
||||||
|
Style style = styleService.getOne(styleLambdaQueryWrapper);
|
||||||
|
tryOnResultVo.setStyleUrl(minioUtil.convertToPresignedUrl(
|
||||||
|
style.getStyleImageUrl(),
|
||||||
|
CommonConstants.MINIO_PATH_TIMEOUT
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
tryOnResultVo.setIsRegenerated(tryOnEffect.getIsRegenerated());
|
||||||
|
tryOnResultVo.setIsFavorite(tryOnEffect.getIsFavorite());
|
||||||
|
tryOnResultVos.add(tryOnResultVo);
|
||||||
|
}
|
||||||
|
return tryOnResultVos;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<OutfitHisVO> getOutfitHistoricals(HistoricalDTO historicalDTO) {
|
||||||
|
LambdaQueryWrapper<Style> styleLambdaQueryWrapper = new LambdaQueryWrapper<Style>().orderByDesc(Style::getCreatedTime);
|
||||||
|
if (historicalDTO.getVisitRecordId() != null){
|
||||||
|
styleLambdaQueryWrapper.eq(Style::getVisitRecordId, historicalDTO.getVisitRecordId());
|
||||||
|
}
|
||||||
|
if (historicalDTO.getIsLibrary() != null||historicalDTO.getIsLibrary()){
|
||||||
|
styleLambdaQueryWrapper.eq(Style::getIsFavorite, 1);
|
||||||
|
}
|
||||||
|
List<Style> styles = styleService.list(styleLambdaQueryWrapper);
|
||||||
|
List<OutfitHisVO> outfitHisVos = new ArrayList<>();
|
||||||
|
for (Style style : styles) {
|
||||||
|
OutfitHisVO outfitHisVo = new OutfitHisVO();
|
||||||
|
outfitHisVo.setId(style.getId());
|
||||||
|
outfitHisVo.setUrl(minioUtil.convertToPresignedUrl(
|
||||||
|
style.getStyleImageUrl(),
|
||||||
|
CommonConstants.MINIO_PATH_TIMEOUT
|
||||||
|
));
|
||||||
|
outfitHisVo.setIsFavorite(style.getIsFavorite());
|
||||||
|
outfitHisVos.add(outfitHisVo);
|
||||||
|
}
|
||||||
|
return outfitHisVos;
|
||||||
|
}
|
||||||
|
|
||||||
//目前用于customize your look页面点击finish后的显示
|
//目前用于customize your look页面点击finish后的显示
|
||||||
@Override
|
@Override
|
||||||
public List<TryOnResultVo> getTryOnEffectsByStyleId(Long styleId) {
|
public List<TryOnResultVO> getTryOnEffectsByStyleId(Long styleId) {
|
||||||
List<TryOnEffect> tryOnEffects = this.list(new LambdaQueryWrapper<TryOnEffect>()
|
List<TryOnEffect> tryOnEffects = this.list(new LambdaQueryWrapper<TryOnEffect>()
|
||||||
.eq(TryOnEffect::getStyleId, styleId)
|
.eq(TryOnEffect::getStyleId, styleId)
|
||||||
.orderByAsc(TryOnEffect::getCreatedTime));
|
.orderByDesc(TryOnEffect::getCreatedTime));
|
||||||
List<TryOnResultVo> tryOnResultVos = new ArrayList<>();
|
List<TryOnResultVO> tryOnResultVos = new ArrayList<>();
|
||||||
for (TryOnEffect tryOnEffect : tryOnEffects) {
|
for (TryOnEffect tryOnEffect : tryOnEffects) {
|
||||||
TryOnResultVo tryOnResultVo = new TryOnResultVo();
|
TryOnResultVO tryOnResultVo = new TryOnResultVO();
|
||||||
tryOnResultVo.setTryOnId(tryOnEffect.getId());
|
tryOnResultVo.setId(tryOnEffect.getId());
|
||||||
// 使用新的API获取预签名URL,数据库存储的是逻辑URL
|
// 使用新的API获取预签名URL,数据库存储的是逻辑URL
|
||||||
tryOnResultVo.setTryOnUrl(minioUtil.convertToPresignedUrl(
|
tryOnResultVo.setTryOnUrl(minioUtil.convertToPresignedUrl(
|
||||||
tryOnEffect.getResultImageUrl(),
|
tryOnEffect.getResultImageUrl(),
|
||||||
@@ -402,7 +470,7 @@ public class TryOnEffectServiceImpl extends ServiceImpl<TryOnEffectMapper, TryOn
|
|||||||
return processGoogleAPIResponse(response);
|
return processGoogleAPIResponse(response);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
log.error("调用Google API失败: {}", e.getMessage(), e);
|
log.error("调用Google API失败: {}", e.getMessage(), e);
|
||||||
throw new BusinessException("Google API call failed", "Google API调用失败", ResultEnum.ERROR.getCode());
|
throw new BusinessException("Generation timed out. Please try again later.", "生成超时,请稍后再试", ResultEnum.ERROR.getCode());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
15
src/main/java/com/aida/lanecarford/vo/BaseVO.java
Normal file
15
src/main/java/com/aida/lanecarford/vo/BaseVO.java
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
package com.aida.lanecarford.vo;
|
||||||
|
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
public class BaseVO implements Serializable {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 10007L;
|
||||||
|
|
||||||
|
@Schema(description = "ID")
|
||||||
|
private Long id;
|
||||||
|
}
|
||||||
11
src/main/java/com/aida/lanecarford/vo/OutfitHisVO.java
Normal file
11
src/main/java/com/aida/lanecarford/vo/OutfitHisVO.java
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
package com.aida.lanecarford.vo;
|
||||||
|
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
public class OutfitHisVO extends BaseVO {
|
||||||
|
|
||||||
|
private String url;
|
||||||
|
|
||||||
|
private Integer isFavorite;
|
||||||
|
}
|
||||||
@@ -3,9 +3,7 @@ package com.aida.lanecarford.vo;
|
|||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
public class TryOnResultVo {
|
public class TryOnResultVO extends BaseVO {
|
||||||
|
|
||||||
private Long tryOnId;
|
|
||||||
|
|
||||||
private String tryOnUrl;
|
private String tryOnUrl;
|
||||||
|
|
||||||
@@ -71,6 +71,7 @@ CREATE TABLE `styles` (
|
|||||||
`style_image_url` varchar(500) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '风格图片URL',
|
`style_image_url` varchar(500) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '风格图片URL',
|
||||||
`python_request_id` varchar(100) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT 'Python请求ID',
|
`python_request_id` varchar(100) COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT 'Python请求ID',
|
||||||
`generation_status` tinyint DEFAULT '0' COMMENT '生成状态(0-处理中,1-已完成,2-失败)',
|
`generation_status` tinyint DEFAULT '0' COMMENT '生成状态(0-处理中,1-已完成,2-失败)',
|
||||||
|
`is_favorite` tinyint DEFAULT '0' COMMENT '是否喜欢(0-否,1-是)',
|
||||||
`items` json DEFAULT NULL COMMENT '单品唯一标识',
|
`items` json DEFAULT NULL COMMENT '单品唯一标识',
|
||||||
`error_message` text COLLATE utf8mb4_unicode_ci COMMENT '错误信息',
|
`error_message` text COLLATE utf8mb4_unicode_ci COMMENT '错误信息',
|
||||||
`created_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
|
`created_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
|
||||||
|
|||||||
Reference in New Issue
Block a user