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