From 5c87778c13e3e33bb30edfcc344e5e69754bc9bf Mon Sep 17 00:00:00 2001 From: 张洋洋 <10611411+yang-yang-z@user.noreply.gitee.com> Date: 星期二, 18 二月 2025 18:04:12 +0800 Subject: [PATCH] [add]服务发布 --- src/main/java/com/se/simu/controller/SimuController.java | 137 ++++++++++++++++++++++++++++++++------------- 1 files changed, 97 insertions(+), 40 deletions(-) diff --git a/src/main/java/com/se/simu/controller/SimuController.java b/src/main/java/com/se/simu/controller/SimuController.java index d58c7a1..9374580 100644 --- a/src/main/java/com/se/simu/controller/SimuController.java +++ b/src/main/java/com/se/simu/controller/SimuController.java @@ -27,6 +27,7 @@ import java.net.URL; import java.net.URLEncoder; import java.nio.charset.StandardCharsets; +import java.text.SimpleDateFormat; import java.util.*; import java.util.stream.Collectors; @@ -336,7 +337,7 @@ return fail("闃叉睕鑼冨洿涓嶈兘涓虹┖", false); } } - if (StringUtils.isEmpty(vo.getSemUrl())){ + if (StringUtils.isEmpty(vo.getSemUrl())) { return fail("sem鏂囦欢鐢熸垚璺緞涓嶈兘涓虹┖锛�", false); } List<GridDto> dtos = new ArrayList<>(); @@ -344,7 +345,7 @@ dtos.add(new GridDto(vo.getMaxy(), vo.getMinx())); dtos.add(new GridDto(vo.getMaxy(), vo.getMaxx())); dtos.add(new GridDto(vo.getMiny(), vo.getMaxx())); - createSem(tableName, dtos, vo.getSemUrl()); + createSem(tableName, dtos, vo); // 寮�濮嬫ā鎷熻绠� boolean flag = simuFilesService.createByfiles(vo); return success(flag, flag ? "鎴愬姛" : "澶辫触"); @@ -353,41 +354,90 @@ } } - public R<Boolean> createSem(String tableName, List<GridDto> dtos, String semUrl) throws Exception { - boolean ends = semUrl.endsWith("\\"); - if (!ends) { - semUrl = semUrl + "\\"; + @ApiOperation(value = "鑾峰彇鐐硅矾寰�") + @GetMapping("/getPointUrl") + public R<String> getPointUrl(@RequestParam("id") Integer id) throws Exception{ + SimuPo po = simuService.getSimuById(id); + String token = EntityLibraryUtils.login(); + if (po != null) { + return success(po.getPointUrl().replace("{token}",token)); } - File file = new File(semUrl); + return success(null); + } + + @ApiOperation(value = "鑾峰彇绾胯矾寰�") + @GetMapping("/getLineUrl") + public R<String> getLineUrl(@RequestParam("id") Integer id) throws Exception{ + SimuPo po = simuService.getSimuById(id); + String token = EntityLibraryUtils.login(); + if (po != null) { + return success(po.getLinkUrl().replace("{token}",token)); + } + return success(null); + } + + public R<Boolean> createSem(String tableName, List<GridDto> dtos, CreateFilesSimuVo vo) throws Exception { + String name = vo.getSemUrl(); + vo.setSemUrl(inPath + "\\" + vo.getSemUrl()); + boolean ends = vo.getSemUrl().endsWith("\\"); + if (!ends) { + vo.setSemUrl(vo.getSemUrl() + "\\"); + } + File file = new File(vo.getSemUrl()); if (!file.exists()) { file.mkdirs(); } - //闄嶉洦鏂囦欢鐢熸垚 - saveZarr(tableName,semUrl); String token = EntityLibraryUtils.login(); + //闄嶉洦鏂囦欢鐢熸垚 + saveZarr(tableName, vo.getSemUrl()); //绠$偣鐢熸垚 - pointTosem(dtos, token,semUrl); + pointTosem(dtos, token, vo.getSemUrl()); //绠$嚎鐢熸垚 - lineToSem(dtos, token,semUrl); - //鍦板舰鐢熸垚 - terrainToSem(dtos,semUrl); + lineToSem(dtos, token, vo.getSemUrl()); //鑼冨洿鐢熸垚 - gridToCityJson(dtos,semUrl); + gridToCityJson(dtos, vo.getSemUrl()); //娌虫祦鐢熸垚 - riverToSem(semUrl); + riverToSem(vo.getSemUrl()); //鍦熷湴鍒╃敤鐢熸垚 - landuseToSem(semUrl); + landuseToSem(vo.getSemUrl()); + //鍦板舰鐢熸垚 + terrainToSem(dtos, vo.getSemUrl()); + String bbox = ""; + //鐢熸垚鐐瑰拰绾跨殑瀹炰綋搴撴ā鍨嬪苟淇濆瓨璺緞 + vo.setPointName(name + "-point"); + vo.setLinkName(name + "-line"); + JSONArray min = ProjectionToGeographicUtil.get4548Point(dtos.get(0).getLon(), dtos.get(0).getLat()); + JSONArray max = ProjectionToGeographicUtil.get4548Point(dtos.get(2).getLon(), dtos.get(2).getLat()); + bbox = bbox + min.getDouble(0) + "," + min.getDouble(1) + "," + max.getDouble(0) + "," + max.getDouble(1); + JSONObject point = getModule("layerQueryPointParams.json"); + String pointUrl = assemble(vo.getPointName(), point.getString("layerid"), bbox, token); + vo.setPointName(pointUrl); + JSONObject link = getModule("layerQueryParams.json"); + String linkUrl = assemble(vo.getLinkName(), link.getString("layerid"), bbox, token); + vo.setLinkName(linkUrl); return success(true); } - @ApiOperation(value = "tarr鏂囦欢缁勮") - @GetMapping(value = "/saveZarr", produces = "application/json; charset=UTF-8") - public R<String> saveZarr(@RequestParam("name") String tableName,String semUrl) throws Exception { + + public String assemble(String name, String layerid, String bbox, String token) throws Exception { + JSONObject jsonObject = EntityLibraryUtils.createAssemble(name, token); + String packageid = jsonObject.getString("packageid"); + EntityLibraryUtils.addAssemble(layerid, token, packageid, bbox); + JSONObject result = EntityLibraryUtils.submitAssemble(token, packageid); + Random random = new Random(); + int randomNumber = random.nextInt(90000) + 10000; + String url = "http://106.120.22.26:8024/geo-service/package/3d/normal/85257774fdb64e5f99f6778696cad02a/" + packageid + "/" + layerid + "//l0/tileset.json?r=" + randomNumber + "&token={token}"; + return url; + } + + public R<String> saveZarr(String tableName, String semUrl) throws Exception { List<String> list = CsvToSQLiteUtils.getNameList(tableName); String path = outPath + "\\"; String rainfall = "rainfall\\"; String basePath = path + tableName + "\\" + rainfall; JSONObject jsonObject = getModule("rainfallmodule.json"); + String startTime = null; + String endTime = null; for (String src : list ) { File directories = new File(basePath); @@ -398,6 +448,12 @@ System.out.println("Directories already exist."); } List<StationRainVo> stationRainVos = CsvToSQLiteUtils.getList(tableName, src); + if (startTime == null) { + startTime = stationRainVos.get(0).getDatetime(); + } + if (endTime == null) { + endTime = stationRainVos.get(stationRainVos.size() - 1).getDatetime(); + } ZarrUtils.saveZarrRainfall(basePath + src, stationRainVos); ZarrUtils.saveZarrTime(basePath + src, stationRainVos); ZipUtils.toZarr(basePath + src, basePath + src + ".zip"); @@ -440,10 +496,24 @@ fileWriter.write(jsonObject.toJSONString()); fileWriter.close(); SemUtils.cityJsonToSem(path + tableName + "\\闄嶉洦閲�.json", semUrl + "raingage.sem"); + getConfigJson(startTime, endTime, semUrl); return success(semUrl + "raingage.sem"); } - public R<String> pointTosem(List<GridDto> dtos, String token,String semUrl) throws Exception { + public void getConfigJson(String startTime, String endTime, String semUrl) throws Exception { + SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm"); + Date start = sdf.parse(startTime); + Date end = sdf.parse(endTime); + SimpleDateFormat simpleDateFormat = new SimpleDateFormat("MM/dd/yyyy HH:mm:ss"); + JSONObject jsonObject = getModule("config.json"); + jsonObject.put("start_datetime", simpleDateFormat.format(start)); + jsonObject.put("end_datetime", simpleDateFormat.format(end)); + FileWriter fileWriter = new FileWriter(semUrl + "\\config.json"); + fileWriter.write(jsonObject.toJSONString()); + fileWriter.close(); + } + + public R<String> pointTosem(List<GridDto> dtos, String token, String semUrl) throws Exception { String path = outPath + "\\point\\"; String publicKey = EntityLibraryUtils.getPublicKey(); JSONArray jsonArrayList = EntityLibraryUtils.getPointInfo(dtos, token); @@ -512,9 +582,8 @@ return success(semUrl + "node.sem"); } - @ApiOperation(value = "绠$偣杞琧ityjson") - @GetMapping(value = "/pointToCityJson", produces = "application/json; charset=UTF-8") - public R<String> pointToCityJson(@RequestParam("shpPath") String shpPath) throws Exception { + + public R<String> pointToCityJson(String shpPath) throws Exception { String path = outPath + "\\point\\"; List<Map<String, Object>> list = ShpReadUtils.readPointShp(shpPath); JSONObject jsonObject = getModule("pointmodule.json"); @@ -561,7 +630,7 @@ return success(filePatn + "node.sem"); } - public R<String> lineToSem(List<GridDto> dtos, String token,String semUrl) throws Exception { + public R<String> lineToSem(List<GridDto> dtos, String token, String semUrl) throws Exception { String path = outPath + "\\line\\"; String publicKey = EntityLibraryUtils.getPublicKey(); JSONArray jsonArrayList = EntityLibraryUtils.getLineInfo(dtos, token); @@ -656,9 +725,7 @@ return success(semUrl + "link.sem"); } - @ApiOperation(value = "绠$嚎杞琧ityjson") - @GetMapping(value = "/lineToCityJson", produces = "application/json; charset=UTF-8") - public R<String> lineToCityJson(@RequestParam("shpPath") String shpPath) throws Exception { + public R<String> lineToCityJson(String shpPath) throws Exception { String path = outPath + "\\line\\"; List<Map<String, Object>> list = ShpReadUtils.readPointShp(shpPath); JSONObject jsonObject = getModule("linemodule.json"); @@ -709,9 +776,7 @@ return success(filePatn + "link.sem"); } - @ApiOperation(value = "鍦板舰杞瑂em") - @PostMapping(value = "/terrainToSem", produces = "application/json; charset=UTF-8") - public R<String> terrainToSem(@RequestBody List<GridDto> dtos,String semUrl) throws Exception { + public R<String> terrainToSem(List<GridDto> dtos, String semUrl) throws Exception { long times = System.currentTimeMillis(); String path = outPath + "\\terrain\\" + times + "\\"; File dirFile = new File(path + "appearance"); @@ -752,9 +817,7 @@ return success(semUrl + "terrain.sem"); } - @ApiOperation(value = "鍦板舰杞琧ityjson") - @GetMapping(value = "/terrainToCityJson", produces = "application/json; charset=UTF-8") - public R<String> terrainToCityJson(@RequestParam("tifPath") String tifPath) throws Exception { + public R<String> terrainToCityJson(String tifPath) throws Exception { long times = System.currentTimeMillis(); String path = outPath + "\\terrain\\" + times + "\\"; File dirFile = new File(path + "appearance"); @@ -777,9 +840,7 @@ return success(filePatn + "terrain.sem"); } - @ApiOperation(value = "grid杞琧ityjson") - @PostMapping(value = "/gridToCityJson", produces = "application/json; charset=UTF-8") - public R<String> gridToCityJson(@RequestBody List<GridDto> dtos,String semUrl) throws Exception { + public R<String> gridToCityJson(List<GridDto> dtos, String semUrl) throws Exception { long times = System.currentTimeMillis(); String path = outPath + "\\grid\\" + times + "\\"; File dirFile = new File(path); @@ -804,8 +865,6 @@ return success(semUrl + "grid.sem"); } - @ApiOperation(value = "river杞瑂em") - @GetMapping(value = "/riverToSem", produces = "application/json; charset=UTF-8") public R<String> riverToSem(String semUrl) throws Exception { long times = System.currentTimeMillis(); String path = outPath + "\\river\\" + times + "\\"; @@ -821,8 +880,6 @@ return success(semUrl + "river.sem"); } - @ApiOperation(value = "landuse杞瑂em") - @GetMapping(value = "/landuseToSem", produces = "application/json; charset=UTF-8") public R<String> landuseToSem(String semUrl) throws Exception { long times = System.currentTimeMillis(); String path = outPath + "\\landuse\\" + times + "\\"; -- Gitblit v1.9.3