From a0eae3ecda7b70468c60a0079db6c4609c29939d Mon Sep 17 00:00:00 2001 From: 无关风月 <443237572@qq.com> Date: 星期四, 17 四月 2025 09:36:22 +0800 Subject: [PATCH] Merge branch 'dev' of http://120.76.84.145:10101/gitblit/r/java/JiaDianHuiShou --- ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OrderController.java | 129 +++++++++++++++++++++++++++++++++++++++---- 1 files changed, 117 insertions(+), 12 deletions(-) diff --git a/ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OrderController.java b/ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OrderController.java index 688ba80..3583d1e 100644 --- a/ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OrderController.java +++ b/ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OrderController.java @@ -1,6 +1,7 @@ package com.ruoyi.worker.controller; +import cn.afterturn.easypoi.cache.manager.IFileLoader; import com.alibaba.fastjson2.JSONObject; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.ruoyi.common.core.constant.Constants; @@ -32,14 +33,20 @@ import java.io.IOException; import java.nio.file.Files; import java.nio.file.Paths; +import java.time.Duration; +import java.time.LocalDateTime; +import java.time.format.DateTimeFormatter; import java.util.ArrayList; import java.util.HashSet; import java.util.List; import java.util.Map; import java.util.Optional; import java.util.Set; +import java.util.concurrent.TimeUnit; import java.util.stream.Collectors; import javax.annotation.Resource; + +import lombok.Synchronized; import org.springframework.transaction.annotation.Transactional; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PostMapping; @@ -78,11 +85,11 @@ /** * linux服务器保存订单轨迹文件夹 */ - // private static final String BASE_PATH = "/usr/local/coordinate/"; - private static final String BASE_PATH = "F:/DeskTop/coordinate/"; - // private static final String BASE_MARKER_PATH = "/usr/local/marker/"; + private static final String BASE_PATH = "/usr/local/coordinate/"; +// private static final String BASE_PATH = "F:/DeskTop/coordinate/"; + private static final String BASE_MARKER_PATH = "/usr/local/marker/"; // private static final String BASE_PATH = "D:/Desktop/coordinate/"; - private static final String BASE_MARKER_PATH = "F:/DeskTop/marker/"; +// private static final String BASE_MARKER_PATH = "F:/DeskTop/marker/"; /** * 师傅端-获取订单列表 * @@ -281,7 +288,7 @@ } return orderClient.orderSubmit(orderSubmitRequest); } - + private static final double EARTH_RADIUS_METERS = 6371000.0; /** * 师傅端-定时调度记录师傅所走路线经纬度 * @@ -294,11 +301,22 @@ @ApiImplicitParam(value = "经度", name = "longitude", dataType = "Integer", required = true), @ApiImplicitParam(value = "纬度", name = "latitude", dataType = "Integer", required = true) }) + @Synchronized public R<Boolean> coordinate(@RequestParam Double longitude, @RequestParam Double latitude) { + + System.err.println("调用记录经纬度"+ LocalDateTime.now()); + LoginUserInfo loginWorker = tokenService.getLoginUserByWorker(); if (null == loginWorker) { return R.loginExpire("登录失效!"); } + Object cacheObject2 = redisService.getCacheObject("LOCK" + loginWorker.getUserid()); + if (cacheObject2!=null){ + return R.ok(); + }else { + redisService.setCacheObject("LOCK" + loginWorker.getUserid(),"1", 10L, TimeUnit.SECONDS); + } + // 获取当天时间 String today = DateUtils.dateTimeNow("yyyy-MM-dd"); Integer workerId = loginWorker.getUserid(); @@ -337,7 +355,6 @@ // 读取订单ID的JSON文件内容 try { String jsonContent = new String(Files.readAllBytes(Paths.get(jsonFilePath))); - System.out.println("JSON 文件内容:" + jsonContent); List<ServeCoordinate> coordinate = JSONObject.parseObject(jsonContent, List.class); // 订单轨迹信息 ServeCoordinate data = new ServeCoordinate(); @@ -355,7 +372,81 @@ return R.fail(e.getMessage()); } } + + + //拿到三十分钟之前的时间,并已 yyyy-MM-dd HH:mm格式存储 + // 当前时间 + LocalDateTime now = LocalDateTime.now(); + + // 减去三十分钟 + LocalDateTime thirtyMinutesAgo = now.minusMinutes(5); + + // 定义日期时间格式 + DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm"); + + // 格式化时间 + String formattedTime = thirtyMinutesAgo.format(formatter); + String nowStr = now.format(formatter); + + + redisService.setCacheObject("MARK:"+workerId+":"+nowStr,longitude + "," + latitude, 10L, TimeUnit.MINUTES); + + String cacheObject = redisService.getCacheObject("MARK:" + workerId + ":" + formattedTime); + if (cacheObject!=null){ + + String cacheObject1 = redisService.getCacheObject("TIME:" + workerId); + if (cacheObject1==null){ + cacheObject1 = "2000-09-06 20:24:10.740"; + } + // 定义日期时间格式 + DateTimeFormatter formatter1 = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss.SSS"); + + // 解析字符串为 LocalDateTime + LocalDateTime localDateTime = LocalDateTime.parse(cacheObject1, formatter1); + if (isWithinTwoMinutes(localDateTime, now)){ + //计算两点之间的距离 + String[] split = cacheObject.split(","); + String longitude1 = split[0]; + String latitude1 = split[1]; + double longitude1Double = Double.parseDouble(longitude1); + double latitude1Double = Double.parseDouble(latitude1); + double lat1Rad = Math.toRadians(latitude); + double lon1Rad = Math.toRadians(longitude); + double lat2Rad = Math.toRadians(latitude1Double); + double lon2Rad = Math.toRadians(longitude1Double); + + // 计算经纬度差值 + double dlon = lon2Rad - lon1Rad; + double dlat = lat2Rad - lat1Rad; + + // Haversine 公式 + double a = Math.pow(Math.sin(dlat / 2), 2) + + Math.cos(lat1Rad) * Math.cos(lat2Rad) * + Math.pow(Math.sin(dlon / 2), 2); + double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a)); + // 计算距离 + double distance = EARTH_RADIUS_METERS * c; + System.err.println("-----当前距离"+distance); + //如果超出一定范围,存入Mark文件 + if (distance<50){ + redisService.setCacheObject("TIME:"+workerId,LocalDateTime.now(), 10L, TimeUnit.MINUTES); + marker(longitude,latitude); + } + } + } + + + redisService.deleteObject("LOCK" + loginWorker.getUserid()); return R.ok(); + } + + public static boolean isWithinTwoMinutes(LocalDateTime dateTime1, LocalDateTime dateTime2) { + // 计算两个时间之间的差值 + Duration duration = Duration.between(dateTime1, dateTime2); + + // 检查差值是否小于等于2分钟 + long minutes = Math.abs(duration.toMinutes()); + return minutes >= 5; } /** * 师傅端-定时调度记录师傅当天的轨迹标点 @@ -370,14 +461,15 @@ @ApiImplicitParam(value = "纬度", name = "latitude", dataType = "Integer", required = true) }) public R<Boolean> marker(@RequestParam Double longitude, @RequestParam Double latitude) { + System.err.println("调用标点"+ LocalDateTime.now()); LoginUserInfo loginWorker = tokenService.getLoginUserByWorker(); if (null == loginWorker) { return R.loginExpire("登录失效!"); } // 获取当天时间 String today = DateUtils.dateTimeNow("yyyy-MM-dd"); - Integer workerId = 1; - // Integer workerId = loginWorker.getUserid(); +// Integer workerId = 1; + Integer workerId = loginWorker.getUserid(); ServeCoordinate serveCoordinate = new ServeCoordinate(); serveCoordinate.setWorkerId(workerId); serveCoordinate.setDate(today); @@ -413,7 +505,6 @@ // 读取订单ID的JSON文件内容 try { String jsonContent = new String(Files.readAllBytes(Paths.get(jsonFilePath))); - System.out.println("JSON 文件内容:" + jsonContent); List<ServeCoordinate> coordinate = JSONObject.parseObject(jsonContent, List.class); // 订单轨迹信息 ServeCoordinate data = new ServeCoordinate(); @@ -433,8 +524,18 @@ } return R.ok(); } +// @ApiOperation(value = "算经纬度", tags = {"师傅端-订单列表"}) +// @GetMapping(value = "/distance") +// @ApiImplicitParams({ +// @ApiImplicitParam(value = "经度", name = "longitude", dataType = "Integer", required = true), +// @ApiImplicitParam(value = "纬度", name = "latitude", dataType = "Integer", required = true) +// }) +// public R<Boolean> distance(@RequestParam Double longitude1, @RequestParam Double latitude1,@RequestParam Double longitude2, @RequestParam Double latitude2) { +// +// +// } - @ApiOperation(value = "上传经纬度", tags = {"师傅端-首页"}) + @ApiOperation(value = "上传经纬度", tags = {"师傅端-首页[2.0]"}) @GetMapping(value = "/putLocation") @ApiImplicitParams({ @ApiImplicitParam(value = "workId", name = "workId", dataType = "int", required = true), @@ -444,10 +545,14 @@ public R<Object> orderNavigation(@RequestParam Integer workId, @RequestParam String longitude, @RequestParam String latitude) { Result<String> address = GaoDeMapUtil.getCityCode(longitude, latitude); - System.err.println(address.getDatas()); + String cityCode = address.getDatas(); + System.err.println("城市code"+cityCode); + String provinceCode = cityCode.substring(0, 2) + "0000"; + System.err.println("省份code"+provinceCode); Set<Integer> strings = new HashSet<>(); strings.add(workId); - redisService.setCacheSet("workerLocation:"+address.getDatas()+":", strings); + redisService.setCacheSet("workerLocation:"+cityCode+":", strings); + redisService.setCacheSet("workerLocation:"+provinceCode+":", strings); redisService.setCacheObject("work:"+workId+":", longitude+","+latitude); return R.ok(); -- Gitblit v1.7.1