From 6cbb420754e6e29fa134a6afca4514b8dfd62918 Mon Sep 17 00:00:00 2001
From: vincentlu <t1341870251@gmail.com>
Date: 星期二, 13 一月 2026 16:14:49 +0800
Subject: [PATCH] #

---
 zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/LaneServiceImpl.java |   74 +++++++++++++++++++++++++++++++++++-
 1 files changed, 71 insertions(+), 3 deletions(-)

diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/LaneServiceImpl.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/LaneServiceImpl.java
index a2a1288..ae91f79 100644
--- a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/LaneServiceImpl.java
+++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/LaneServiceImpl.java
@@ -1,12 +1,80 @@
 package com.zy.acs.manager.manager.service.impl;
 
-import com.zy.acs.manager.manager.mapper.LaneMapper;
-import com.zy.acs.manager.manager.entity.Lane;
-import com.zy.acs.manager.manager.service.LaneService;
+import com.alibaba.fastjson.JSON;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.zy.acs.framework.common.Cools;
+import com.zy.acs.framework.common.SnowflakeIdWorker;
+import com.zy.acs.framework.exception.CoolException;
+import com.zy.acs.manager.core.domain.LaneDto;
+import com.zy.acs.manager.core.service.MapService;
+import com.zy.acs.manager.manager.entity.Lane;
+import com.zy.acs.manager.manager.enums.StatusType;
+import com.zy.acs.manager.manager.mapper.LaneMapper;
+import com.zy.acs.manager.manager.service.LaneService;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+import java.util.ArrayList;
+import java.util.Date;
+import java.util.List;
 
 @Service("laneService")
 public class LaneServiceImpl extends ServiceImpl<LaneMapper, Lane> implements LaneService {
 
+    @Autowired
+    private SnowflakeIdWorker snowflakeIdWorker;
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public List<Lane> batchSaveByLaneDtoList(Long zonedId, List<LaneDto> laneDtoList) {
+        List<Lane> lanes = new ArrayList<>();
+        if (Cools.isEmpty(laneDtoList)) {
+            return lanes;
+        }
+        Date now = new Date();
+        for (LaneDto laneDto : laneDtoList) {
+            Lane lane = new Lane();
+            if (null != zonedId) {
+                lane.setZoneId(zonedId);
+            }
+            lane.setHashCode(laneDto.getHashCode());
+            lane.setUuid(String.valueOf(snowflakeIdWorker.nextId()).substring(3));
+            if (!Cools.isEmpty(laneDto.getCodes())) {
+                lane.setCodes(JSON.toJSONString(laneDto.getCodes()));
+            }
+            lane.setStatus(StatusType.ENABLE.val);
+            lane.setCreateTime(now);
+            lane.setUpdateTime(now);
+            if (!this.save(lane)) {
+                throw new CoolException("failed to save lane");
+            } else {
+                lanes.add(lane);
+                laneDto.setLaneId(lane.getId());
+            }
+        }
+        return lanes;
+    }
+
+    @Override
+    public Double getLaneDirection(LaneDto laneDto) {
+        if (null == laneDto) {
+            return null;
+        }
+        Lane lane = this.getById(laneDto.getLaneId());
+        if (null == lane) {
+            return null;
+        }
+        Integer entryAngle = lane.getEntryAngle();
+        if (null == entryAngle) {
+            return null;
+        }
+        if (entryAngle < 0) {
+            return null;
+        }
+        double entryAngleDouble = entryAngle.doubleValue();
+        return MapService.mapToNearest(entryAngleDouble);
+//        return entryAngleDouble;
+    }
+
 }

--
Gitblit v1.9.1