123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264 |
- package com.fdkankan.fusion.service.impl;
- import cn.hutool.core.io.FileUtil;
- import com.alibaba.fastjson.JSONArray;
- import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
- import com.fdkankan.fusion.common.FilePath;
- import com.fdkankan.fusion.common.ResultCode;
- import com.fdkankan.fusion.common.util.*;
- import com.fdkankan.fusion.entity.CaseNumEntity;
- import com.fdkankan.fusion.entity.Model;
- import com.fdkankan.fusion.exception.BusinessException;
- import com.fdkankan.fusion.httpClient.client.FdKKClient;
- 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 lombok.extern.slf4j.Slf4j;
- import org.apache.commons.lang3.StringUtils;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.beans.factory.annotation.Value;
- import org.springframework.stereotype.Service;
- import javax.annotation.Resource;
- import java.io.File;
- import java.sql.BatchUpdateException;
- import java.util.*;
- import java.util.stream.Collectors;
- /**
- * <p>
- * 服务实现类
- * </p>
- *
- * @author
- * @since 2022-07-27
- */
- @Service
- @Slf4j
- public class CaseNumServiceImpl extends ServiceImpl<ICaseNumMapper, CaseNumEntity> implements ICaseNumService {
- @Autowired
- UploadToOssUtil uploadToOssUtil;
- @Value("${upload.query-path}")
- private String queryPath;
- @Value("${spring.profiles.active}")
- private String environment;
- @Autowired
- IModelService modelService;
- @Autowired
- IFusionNumService fusionNumService;
- @Autowired
- ICaseViewService caseViewService;
- @Autowired
- IFusionMeterService fusionMeterService;
- @Autowired
- IFusionGuidePathService fusionGuidePathService;
- @Autowired
- ICaseTagService caseTagService;
- @Autowired
- ICaseTagPointService caseTagPointService;
- // @Autowired
- //ThreadService threadService;
- @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,param.getType());
- if(model.getModelId() != null && StringUtils.isNotBlank(model.getModelGlbUrl()) && StringUtils.isNotBlank(model.getModelSize())){
- continue;
- }
- model.setModelDateType("obj");
- model.setType(param.getType());
- model.setModelType("pointcloud"); //深时点云类型
- model.setCreateStatus(1);
- if(param.getType() == 0 || param.getType() == 1 || param.getType() == 4 || param.getType() == 6 || param.getType() == 8){ //看看,看见
- String mesh3DtilesPath = String.format(FilePath.OBJ_OSS_PATH,num) + "/images/3dtiles/tileset.json";
- String sizePath = String.format(FilePath.OBJ_OSS_PATH,num) + "/images/3dtiles";
- if(uploadToOssUtil.existKey(mesh3DtilesPath)){
- model.setModelDateType("b3dm");
- model.setModelType("b3dm");
- model.setModelGlbUrl(JSONArray.toJSONString(Arrays.asList(queryPath +mesh3DtilesPath)));
- model.setModelSize(FileWriterUtil.setFileSize(uploadToOssUtil.getSize( sizePath)));
- }else {
- model.setModelObjUrl(String.format(FilePath.OBJ_LOCAL_PATH,environment ,num) +"/mesh.obj");
- model.setModelGlbUrl(getGlbUrl(param.getType(),num,model));
- model.setModelType("glb");
- }
- }
- model.setNum(num);
- 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 || type == 4 || type == 6 || type == 8){ //看看,看见
- String objPath = String.format(FilePath.OBJ_LOCAL_PATH ,environment,num);
- ShellUtil.yunDownload(String.format(FilePath.OBJ_OSS_PATH, num)+"/data/mesh" ,objPath);
- List<String> localGlbPaths = new ArrayList<>();
- List<String> ossGlbPaths = new ArrayList<>();
- File localFile = new File(objPath);
- this.toGlB(localFile,localGlbPaths);
- Long modelSize = 0L;
- if(localGlbPaths.size() >0){
- for (String localGlbPath : localGlbPaths) {
- String ossGlbPath = localGlbPath.replace(FilePath.LOCAL_BASE_PATH,"fusion/");
- uploadToOssUtil.uploadOss(localGlbPath,ossGlbPath);
- if(ossGlbPath.contains("lod_")){
- if(ossGlbPath.contains("lod_0")){
- ossGlbPaths.add(queryPath +ossGlbPath);
- modelSize += uploadToOssUtil.getSize(ossGlbPath);
- }
- continue;
- }
- modelSize += uploadToOssUtil.getSize(ossGlbPath);
- ossGlbPaths.add(queryPath +ossGlbPath);
- }
- model.setModelSize(FileWriterUtil.setFileSize(modelSize));
- try {
- FileUtil.del(objPath);
- }catch (Exception e){
- log.info("删除失败:{}",e);
- }
- return JSONArray.toJSONString(ossGlbPaths);
- }
- try {
- Thread.sleep(2000L);
- FileUtil.del(objPath);
- }catch (Exception e){
- log.info("删除失败:{}",e);
- }
- }
- return null;
- }
- private void toGlB(File localFile, List<String> localGlbPath) {
- File[] files = localFile.listFiles();
- for (File file : files) {
- if(file.isDirectory()){
- toGlB(file,localGlbPath);
- }
- if(file.getName().contains(".obj")){
- String glbPath = OBJToGLBUtil.objToGlb(file.getPath(),file.getPath().replace(".obj",".glb") );
- localGlbPath.add(glbPath);
- }
- }
- }
- private List<String> updateByNumList(Integer caseId, List<SceneNumParam> sceneNumParam) {
- List<String> addList = new ArrayList<>();
- for (SceneNumParam param : sceneNumParam) {
- Integer type = param.getType();
- List<String> numList = param.getNumList();
- LambdaQueryWrapper<CaseNumEntity> wrapper = new LambdaQueryWrapper<>();
- wrapper.eq(CaseNumEntity::getCaseId,caseId);
- wrapper.eq(CaseNumEntity::getNumType,type);
- List<CaseNumEntity> list = this.list(wrapper);
- List<String> hanNumList = list.parallelStream().map(CaseNumEntity::getNum).collect(Collectors.toList());
- List<String> delList = new ArrayList<>();
- for (String num : hanNumList) {
- if(!numList.contains(num)){
- delList.add(num);
- }
- }
- for (String num : numList) {
- if(!hanNumList.contains(num)){
- addList.add(num);
- }
- }
- this.deleteByNum(caseId,delList,param.getType());
- }
- return addList;
- }
- @Override
- public void deleteByNum(Integer caseId, List<String> delList,Integer type) {
- if(delList.size() >0){
- LambdaQueryWrapper<CaseNumEntity> wrapper = new LambdaQueryWrapper<>();
- wrapper.eq(CaseNumEntity::getCaseId,caseId);
- wrapper.eq(CaseNumEntity::getNumType,type);
- wrapper.in(CaseNumEntity::getNum,delList);
- this.remove(wrapper);
- fusionNumService.deleteByNumList(caseId,delList,true,type);
- }
- }
- @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);
- }
- }
|