123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223 |
- package com.fdkankan.fusion.service.impl;
- import cn.hutool.core.io.FileUtil;
- import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
- import com.fdkankan.fusion.common.FilePath;
- import com.fdkankan.fusion.common.util.FileWriterUtil;
- import com.fdkankan.fusion.common.util.OBJToGLBUtil;
- import com.fdkankan.fusion.common.util.UploadToOssUtil;
- import com.fdkankan.fusion.entity.CaseNumEntity;
- import com.fdkankan.fusion.entity.Model;
- import com.fdkankan.fusion.mapper.ICaseNumMapper;
- import com.fdkankan.fusion.request.SceneNumParam;
- import com.fdkankan.fusion.service.*;
- import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.beans.factory.annotation.Value;
- import org.springframework.stereotype.Service;
- import java.io.File;
- import java.util.*;
- import java.util.stream.Collectors;
- /**
- * <p>
- * 服务实现类
- * </p>
- *
- * @author
- * @since 2022-07-27
- */
- @Service
- public class CaseNumServiceImpl extends ServiceImpl<ICaseNumMapper, CaseNumEntity> implements ICaseNumService {
- @Autowired
- UploadToOssUtil uploadToOssUtil;
- @Value("${local.obj_path}")
- private String OBJ_PATH;
- @Value("${local.glb_path}")
- private String GLB_PATH;
- @Value("${upload.query-path}")
- private String queryPath;
- @Autowired
- IModelService modelService;
- @Autowired
- IFusionNumService fusionNumService;
- @Autowired
- ICaseViewService caseViewService;
- @Autowired
- IFusionMeterService fusionMeterService;
- @Autowired
- IFusionGuidePathService fusionGuidePathService;
- @Autowired
- ICaseTagService caseTagService;
- @Autowired
- ICaseTagPointService caseTagPointService;
- @Override
- public List<CaseNumEntity> getByCaseId(Integer caseId) {
- LambdaQueryWrapper<CaseNumEntity> wrapper = new LambdaQueryWrapper<>();
- wrapper.eq(CaseNumEntity::getCaseId,caseId);
- return this.list(wrapper);
- }
- @Override
- public void addBatch(Integer caseId, List<SceneNumParam> sceneNumParam) {
- List<String> addNumList = this.updateByNumList(caseId, sceneNumParam);
- if(addNumList == null || addNumList.size()<=0){
- return;
- }
- List<CaseNumEntity> newCaseNums = new ArrayList<>();
- List<Model> modelList = new ArrayList<>();
- for (SceneNumParam param : sceneNumParam) {
- List<String> numList = param.getNumList();
- HashSet<String> setNum = new HashSet<>(numList);
- for (String num : setNum) {
- if(!addNumList.contains(num)){
- continue;
- }
- CaseNumEntity caseNumEntity = new CaseNumEntity();
- caseNumEntity.setCaseId(caseId);
- caseNumEntity.setNumType(param.getType());
- caseNumEntity.setNum(num);
- newCaseNums.add(caseNumEntity);
- if(param.getType() == 3){ //用户上传三维模型跳过
- continue;
- }
- Model model = modelService.getIsNullNewByNum(num);
- model.setModelDateType("obj");
- model.setType(param.getType());
- model.setModelType("pointcloud"); //深时点云类型
- if(param.getType() != 2){ //不为深时
- model.setModelObjUrl(String.format(OBJ_PATH ,num) +"/mesh.obj");
- model.setModelGlbUrl(getGlbUrl(param.getType(),num,model));
- model.setModelType("glb");
- }
- model.setNum(num);
- model.setCreateStatus(1);
- modelList.add(model);
- }
- }
- if(newCaseNums.size() >0){
- this.saveBatch(newCaseNums);
- }
- if(modelList.size() >0){
- modelService.saveOrUpdateBatch(modelList);
- }
- }
- private String getGlbUrl(Integer type, String num,Model model) {
- if(type == 0 || type == 1){ //看看,看见
- String objPath = String.format(OBJ_PATH ,num);
- String glbPath = String.format(GLB_PATH,num) +"/mesh.glb";
- String glbOssPath = String.format(FilePath.GLB_OSS_PATH , num);
- // if(uploadToOssUtil.existKey(glbOssPath)){
- // return queryPath + "/"+glbOssPath;
- // }
- List<String> fileList = uploadToOssUtil.listKeysFromAli(String.format(FilePath.OBJ_OSS_PATH, num));
- for (String fileName : fileList) {
- File file = new File(objPath);
- if(!file.exists()){
- file.mkdirs();
- }
- String[] split = fileName.split("/");
- String localPath = objPath +"/"+split[split.length-1];
- uploadToOssUtil.downFormAli(fileName,localPath);
- }
- OBJToGLBUtil.objToGlb(objPath,glbPath );
- File file = new File(glbPath);
- if(file!=null){
- model.setModelSize(FileWriterUtil.setFileSize(file.length()));
- }
- uploadToOssUtil.uploadOss(glbPath,glbOssPath);
- FileUtil.del(objPath);
- return queryPath + "/"+glbOssPath;
- }
- return null;
- }
- private List<String> updateByNumList(Integer caseId, List<SceneNumParam> sceneNumParam) {
- List<String> updateNumList = new ArrayList<>();
- for (SceneNumParam param : sceneNumParam) {
- List<String> numList = param.getNumList();
- updateNumList.addAll(numList);
- }
- if(updateNumList.size()<=0){
- deleteByCaseId(caseId);
- return null;
- }
- LambdaQueryWrapper<CaseNumEntity> wrapper = new LambdaQueryWrapper<>();
- wrapper.eq(CaseNumEntity::getCaseId,caseId);
- List<CaseNumEntity> list = this.list(wrapper);
- List<String> hanNumList = list.parallelStream().map(CaseNumEntity::getNum).collect(Collectors.toList());
- List<String> delList = new ArrayList<>();
- List<String> addList = new ArrayList<>();
- for (String num : hanNumList) {
- if(!updateNumList.contains(num)){
- delList.add(num);
- }
- }
- for (String num : updateNumList) {
- if(!hanNumList.contains(num)){
- addList.add(num);
- }
- }
- this.deleteByNum(caseId,delList);
- return addList;
- }
- @Override
- public void deleteByNum(Integer caseId, List<String> delList) {
- if(delList.size() >0){
- LambdaQueryWrapper<CaseNumEntity> wrapper = new LambdaQueryWrapper<>();
- wrapper.eq(CaseNumEntity::getCaseId,caseId);
- wrapper.in(CaseNumEntity::getNum,delList);
- this.remove(wrapper);
- fusionNumService.deleteByNumList(caseId,delList,true);
- }
- }
- @Override
- public void deleteByCaseId(Integer caseId) {
- LambdaQueryWrapper<CaseNumEntity> wrapper = new LambdaQueryWrapper<>();
- wrapper.eq(CaseNumEntity::getCaseId,caseId);
- this.remove(wrapper);
- fusionNumService.deleteByCaseId(caseId);
- caseViewService.deleteByCaseId(caseId);
- fusionGuidePathService.deleteByCaseId(caseId);
- fusionMeterService.deleteByCaseId(caseId);
- caseTagService.deletePointByCaseId(caseId);
- }
- @Override
- public HashMap<Integer, List<String>> getTypeMap(Integer caseId) {
- List<CaseNumEntity> caseNumList = this.getByCaseId(caseId);
- HashMap<Integer,List<String>> typeMap = new HashMap<>();
- for (CaseNumEntity caseNumEntity : caseNumList) {
- List<String> numList ;
- if(typeMap.get(caseNumEntity.getNumType()) == null){
- numList = new ArrayList<>();
- }else {
- numList = typeMap.get(caseNumEntity.getNumType());
- }
- numList.add(caseNumEntity.getNum());
- typeMap.put(caseNumEntity.getNumType(),numList);
- }
- return typeMap;
- }
- @Override
- public List<CaseNumEntity> getByNum(String num) {
- LambdaQueryWrapper<CaseNumEntity> wrapper = new LambdaQueryWrapper<>();
- wrapper.eq(CaseNumEntity::getNum,num);
- return this.list(wrapper);
- }
- }
|