diff --git a/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/CTCLogicLoop.java b/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/CTCLogicLoop.java index f53f6796d..a9038e796 100644 --- a/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/CTCLogicLoop.java +++ b/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/CTCLogicLoop.java @@ -5,9 +5,7 @@ import club.joylink.rtss.simulation.cbtc.CI.CiApiService; import club.joylink.rtss.simulation.cbtc.CTC.data.*; import club.joylink.rtss.simulation.cbtc.Simulation; import club.joylink.rtss.simulation.cbtc.data.SimulationDataRepository; -import club.joylink.rtss.simulation.cbtc.data.map.Section; -import club.joylink.rtss.simulation.cbtc.data.map.Signal; -import club.joylink.rtss.simulation.cbtc.data.map.Station; +import club.joylink.rtss.simulation.cbtc.data.map.*; import club.joylink.rtss.simulation.cbtc.data.support.SectionPosition; import club.joylink.rtss.simulation.cbtc.data.vo.TrainInfo; import club.joylink.rtss.simulation.cbtc.data.vr.VirtualRealityTrain; @@ -62,9 +60,14 @@ public class CTCLogicLoop { LocalDateTime correctSystemTime = simulation.getCorrectSystemTime(); for (RouteSequence routeSequence : simulation.getCtcRepository().getRouteSequenceMap().values()) { for (RouteSequence.Line line : routeSequence.getLines()) { - if (line.isAutoTrigger()) { - if (line.getRoute() != null && correctSystemTime.toLocalTime().isAfter(line.getPlanTime())) { - ciApiService.settingRoute(simulation, line.getRouteCode()); + Route route = line.getRoute(); + if (!line.isTriggered()) { + if (route != null) { + if (route.isLock()) { + line.setTriggered(true); + } else if (line.isAutoTrigger() && correctSystemTime.toLocalTime().isAfter(line.getPlanTime())) { + ciApiService.settingRoute(simulation, line.getRouteCode()); + } } } } @@ -111,19 +114,33 @@ public class CTCLogicLoop { map.put("trackView", vo); list.add(map); } - SocketMessageVO message = SocketMessageFactory.buildCtcRouteSequenceMessage(simulation.getId(), list); + SocketMessageVO message = SocketMessageFactory.buildCtcBusyBoardMessage(simulation.getId(), list); stompMessageService.sendToUser(simulation.getSimulationUserIds(), message); } private void sendTrackViewMessage(Simulation simulation) { -// CtcRepository ctcRepository = simulation.getCtcRepository(); -// for (CtcStationRunPlanLog runPlan : ctcRepository.getAllRunPlanList()) { -// CtcStationRunPlanLog.RunPlanItem arriveRunPlan = runPlan.getArriveRunPlan(); -// if (arriveRunPlan != null) { -// RouteSequence.Line routeSequenceLine = ctcRepository.getRouteSequenceLine(runPlan.getStation().getCode(), arriveRunPlan.getTripNumber(), false); -// -// } -// } + List> list = new ArrayList<>(); + CtcRepository ctcRepository = simulation.getCtcRepository(); + for (RouteSequence routeSequence : ctcRepository.getRouteSequenceMap().values()) { + TrackViewVO trackViewVO = new TrackViewVO(routeSequence.getStationCode()); + Map map = new HashMap<>(); + map.put("stationCode", routeSequence.getStationCode()); + map.put("trackView", trackViewVO); + for (RouteSequence.Line line : routeSequence.getLines()) { + if (line.isDeparture()) { + trackViewVO.addDepartureLine(line); + } else { + trackViewVO.addReceivingLine(line); + } + } + Station station = routeSequence.getStation(); + Map sectionOccupiedMap = station.getAllStandList().stream().map(Stand::getSection) + .collect(Collectors.toMap(MapElement::getCode, Section::isOccupied)); + trackViewVO.getSectionOccupiedMap().putAll(sectionOccupiedMap); + list.add(map); + } + SocketMessageVO message = SocketMessageFactory.buildCtcBusyBoardMessage(simulation.getId(), list); + stompMessageService.sendToUser(simulation.getSimulationUserIds(), message); } private void sendAllRouteSequenceMessage(Simulation simulation) { @@ -135,7 +152,7 @@ public class CTCLogicLoop { map.put("routeSequence", vo); list.add(map); } - SocketMessageVO message = SocketMessageFactory.buildCtcRouteSequenceMessage(simulation.getId(), list); + SocketMessageVO message = SocketMessageFactory.buildCtcBusyBoardMessage(simulation.getId(), list); stompMessageService.sendToUser(simulation.getSimulationUserIds(), message); } @@ -168,7 +185,7 @@ public class CTCLogicLoop { } } } - SocketMessageVO message = SocketMessageFactory.buildCtcRouteSequenceMessage(simulation.getId(), list); + SocketMessageVO message = SocketMessageFactory.buildCtcBusyBoardMessage(simulation.getId(), list); stompMessageService.sendToUser(simulation.getSimulationUserIds(), message); } diff --git a/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/CTCService.java b/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/CTCService.java index 6a720a546..ecc53276a 100644 --- a/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/CTCService.java +++ b/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/CTCService.java @@ -16,12 +16,10 @@ public class CTCService { @Autowired private CTCLogicLoop ctcLogicLoop; - public void runPlanItemUpdate(Simulation simulation, Station station, CtcStationRunPlanLog.RunPlanItem item, boolean departure) { CtcRepository ctcRepository = simulation.getCtcRepository(); - ctcRepository.deleteRouteSequenceLine(station.getCode(), item); - RouteSequence.Line line = RouteSequence.buildLine(item, departure); - ctcRepository.addRouteSequenceLine(station.getCode(), line); + RouteSequence.Line routeSequenceLine = ctcRepository.getRouteSequenceLine(station.getCode(), item.getTripNumber(), departure); + routeSequenceLine.updateRoute(); } /** diff --git a/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/data/CtcRepository.java b/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/data/CtcRepository.java index 4095491d9..b32d281f3 100644 --- a/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/data/CtcRepository.java +++ b/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/data/CtcRepository.java @@ -77,6 +77,7 @@ public class CtcRepository { public void reset() { routeSequenceMap.clear(); routeSequenceVOMap.clear(); + trackViewVOMap.clear(); // 编辑区清空 this.simulationRunPlanEditAreaMap.clear(); // 仿真运行数据直接清空 @@ -205,4 +206,8 @@ public class CtcRepository { RouteSequence routeSequence = routeSequenceMap.get(stationCode); routeSequence.addLine(line); } + + public TrackViewVO getTrackViewVO(String stationCode) { + return trackViewVOMap.computeIfAbsent(stationCode, k -> new TrackViewVO()); + } } diff --git a/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/data/RouteSequence.java b/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/data/RouteSequence.java index 34a5390b5..2e4a684db 100644 --- a/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/data/RouteSequence.java +++ b/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/data/RouteSequence.java @@ -98,7 +98,7 @@ public class RouteSequence { } int id = idGenerator.getAndIncrement(); LocalTime planTime = item.getPlanTime().minusMinutes(9); - return new Line(String.valueOf(id), item, false, departure, planTime, planTime, route); + return new Line(String.valueOf(id), item, departure, planTime, planTime, route); } public Line findLine(String id) { @@ -189,10 +189,32 @@ public class RouteSequence { private LocalTime planTime; private Route route; + /** + * 进路是否已经触发过 + */ + @Setter + private boolean triggered; + + public Line(String id, CtcStationRunPlanLog.RunPlanItem item, boolean departure, LocalTime startTime, LocalTime planTime, Route route) { + this.id = id; + this.item = item; + this.departure = departure; + this.startTime = startTime; + this.planTime = planTime; + this.route = route; + } + public String getTripNumber() { return this.item.getTripNumber(); } + public boolean isSetting() { + if (route != null) { + return route.isSetting(); + } + return false; + } + public Section getTrack() { return this.item.getTrackSection(); } @@ -206,6 +228,15 @@ public class RouteSequence { } } + public String getTrackCode() { + Section track = getTrack(); + if (track == null) { + return null; + } else { + return track.getCode(); + } + } + private boolean isRight() { return this.item.isRight(); } @@ -213,5 +244,36 @@ public class RouteSequence { public String getRouteCode() { return route == null ? null : route.getCode(); } + + public void updateRoute() { + boolean right = isRight(); + Signal startSignal; + Signal endSignal; + Route route = null; + Section trackSection = getTrack(); + if (trackSection != null) { + if (departure) { //发车 + startSignal = trackSection.getSignalOf(right); //股道的同向信号机作为发车进路的起始信号机 + if (startSignal == null || !startSignal.isShunting2()) //没有出站信号机的股道不生成进路序列 + startSignal = null; + endSignal = item.getStationDirection().getSignal(); + } else { //接车 + startSignal = item.getStationDirection().getSignal(); + Signal tempEndSignal = trackSection.getSignalOf(!right); + if (tempEndSignal == null || !tempEndSignal.isShunting2()) + endSignal = null; + else + endSignal = tempEndSignal; //股道的反向信号机作为接车进路终点信号机 + } + if (startSignal != null && endSignal != null) { + route = startSignal.getRouteList().stream() + .filter(r -> Objects.equals(r.getDestination(), endSignal)) + .findAny().orElse(null); + BusinessExceptionAssertEnum.SYSTEM_EXCEPTION.assertNotNull(route, + String.format("车次[%s]的[%s]进路找不到", item.getTripNumber(), departure ? "发车" : "接车")); + this.route = route; + } + } + } } } diff --git a/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/data/RouteSequenceVO.java b/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/data/RouteSequenceVO.java index e241e1586..1029ddb41 100644 --- a/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/data/RouteSequenceVO.java +++ b/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/data/RouteSequenceVO.java @@ -97,6 +97,11 @@ public class RouteSequenceVO { */ private boolean autoTrigger; + /** + * 是否发车 + */ + private boolean departure; + // /** // * 方向 // */ @@ -117,14 +122,30 @@ public class RouteSequenceVO { */ private String routeCode; + /** + * 状态。(0/1/2分别代表等待、正在触发、触发完成) + */ + private String status; + private static final String WAIT = "0"; + private static final String SETTING = "1"; + private static final String TRIGGERED = "2"; + public LineVO(RouteSequence.Line line) { id = line.getId(); tripNumber = line.getTripNumber(); trackName = line.getTrackName(); autoTrigger = line.isAutoTrigger(); + departure = line.isDeparture(); startTime = line.getStartTime(); planTime = line.getPlanTime(); routeCode = line.getRouteCode(); + if (line.isTriggered()) { + status = TRIGGERED; + } else if (line.isSetting()) { + status = SETTING; + } else { + status = WAIT; + } } /** @@ -144,6 +165,10 @@ public class RouteSequenceVO { autoTrigger = line.isAutoTrigger(); map.put("autoTrigger", autoTrigger); } + if (!Objects.equals(departure, line.isDeparture())) { + departure = line.isDeparture(); + map.put("departure", departure); + } if (!Objects.equals(startTime, line.getStartTime())) { startTime = line.getStartTime(); map.put("startTime", startTime); @@ -156,8 +181,17 @@ public class RouteSequenceVO { routeCode = line.getRouteCode(); map.put("routeCode", line.getRouteCode()); } + if (line.isTriggered()) { + status = TRIGGERED; + } else if (line.isSetting()) { + status = SETTING; + } else { + status = WAIT; + } if (!CollectionUtils.isEmpty(map)) { + map.put("id", id); + map.put("status", status); return map; } return null; diff --git a/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/data/TrackViewVO.java b/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/data/TrackViewVO.java index 71eaccc09..e693fc23a 100644 --- a/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/data/TrackViewVO.java +++ b/src/main/java/club/joylink/rtss/simulation/cbtc/CTC/data/TrackViewVO.java @@ -5,32 +5,54 @@ import com.fasterxml.jackson.annotation.JsonIgnore; import lombok.Getter; import lombok.NoArgsConstructor; import lombok.Setter; +import org.springframework.util.CollectionUtils; import org.springframework.util.StringUtils; -import java.util.ArrayList; -import java.util.HashMap; -import java.util.List; -import java.util.Map; +import java.util.*; +/** + * 股道视图。 + * 注意:里面看起来没有被调用的方法不要删,用于序列化 + */ @Getter @Setter @NoArgsConstructor public class TrackViewVO { private String stationCode; - private final Map sectionAndTrackInfo = new HashMap<>(); + private final Map sectionOccupiedMap = new HashMap<>(); + + private final Map> trackLineMap = new HashMap<>(); + + public TrackViewVO(String stationCode) { + this.stationCode = stationCode; + } + + public void addLine(Line line) { + String trackCode = line.getTrackCode(); + List lines = trackLineMap.computeIfAbsent(trackCode, k -> new ArrayList<>()); + lines.add(line); + } + + public TrackViewVO.Line findLine(String trackCode, String tripNumber) { + List lines = trackLineMap.get(trackCode); + if (CollectionUtils.isEmpty(lines)) + return null; + return lines.stream() + .filter(line -> Objects.equals(line.getTripNumber(), tripNumber)) + .findAny().orElse(null); + } public void addReceivingLine(RouteSequence.Line receivingRoute) { Section track = receivingRoute.getTrack(); if (track == null) return; - TrackInfo trackInfo = sectionAndTrackInfo.computeIfAbsent(track.getCode(), k -> new TrackInfo(track)); - Line trackViewLine = trackInfo.findLine(receivingRoute.getTripNumber()); - if (trackViewLine == null) { - Line line = Line.buildReceivingLine(receivingRoute); - trackInfo.addLine(line); + Line line = findLine(track.getCode(), receivingRoute.getTripNumber()); + if (line != null) { + line.setReceivingRoute(receivingRoute); } else { - trackViewLine.setReceivingRoute(receivingRoute); + Line newLine = Line.buildReceivingLine(receivingRoute); + addLine(newLine); } } @@ -38,57 +60,57 @@ public class TrackViewVO { Section track = departureRoute.getTrack(); if (track == null) return; - TrackInfo trackInfo = sectionAndTrackInfo.computeIfAbsent(track.getCode(), k -> new TrackInfo(track)); - Line trackViewLine = trackInfo.findLine(departureRoute.getTripNumber()); - if (trackViewLine == null) { - Line line = Line.buildDepartureLine(departureRoute); - trackInfo.addLine(line); + Line line = findLine(track.getCode(), departureRoute.getTripNumber()); + if (line != null) { + line.setDepartureRoute(departureRoute); } else { - trackViewLine.setDepartureRoute(departureRoute); + Line newLine = Line.buildDepartureLine(departureRoute); + addLine(newLine); } } - public static class TrackInfo { - @JsonIgnore - private Section track; - - private final List lines = new ArrayList<>(); - - @JsonIgnore - private final Map tripLineMap = new HashMap<>(); - - public TrackInfo(Section track) { - this.track = track; - } - - public boolean isOccupied() { - return this.track.isOccupied(); - } - - public Line findLine(String tripNumber) { - return tripLineMap.get(tripNumber); - } - - public void addLine(Line line) { - lines.add(line); - tripLineMap.put(line.getTripNumber(), line); - } - } +// @Getter +// public static class TrackInfo { +// @JsonIgnore +// private Section track; +// +// private final List lines = new ArrayList<>(); +// +// @JsonIgnore +// private final Map tripLineMap = new HashMap<>(); +// +// public TrackInfo(Section track) { +// this.track = track; +// } +// +// public boolean isOccupied() { +// return this.track.isOccupied(); +// } +// +// public Line findLine(String tripNumber) { +// return tripLineMap.get(tripNumber); +// } +// +// public void addLine(Line line) { +// lines.add(line); +// tripLineMap.put(line.getTripNumber(), line); +// } +// } @Getter @Setter public static class Line { - private String tripNumber; - - private String trainType; - - private String trainDistanceInfo; +// private String tripNumber; +// +// private String trainType; +// +// private String trainDistanceInfo; // private Process process; // private boolean receivingNotice; - private boolean receivingRouteLock; +// private boolean receivingRouteLock; @JsonIgnore private RouteSequence.Line receivingRoute; @@ -97,7 +119,7 @@ public class TrackViewVO { // private boolean departureNotice; - private boolean departureRouteLock; +// private boolean departureRouteLock; @JsonIgnore private RouteSequence.Line departureRoute; @@ -114,36 +136,56 @@ public class TrackViewVO { public static Line buildReceivingLine(RouteSequence.Line receivingRoute) { Line line = new Line(); - line.setTripNumber(receivingRoute.getTripNumber()); line.setReceivingRoute(receivingRoute); return line; } public static Line buildDepartureLine(RouteSequence.Line departureRoute) { Line line = new Line(); - line.setTripNumber(departureRoute.getTripNumber()); line.setDepartureRoute(departureRoute); return line; } - public void updateRouteLock() { - if (!receivingRouteLock) { - if (receivingRoute != null && receivingRoute.getRoute().isLock()) { - receivingRouteLock = true; - } + public String getTripNumber() { + if (receivingRoute != null) { + return receivingRoute.getTripNumber(); } - if (!departureRouteLock) { - if (departureRoute != null && departureRoute.getRoute().isLock()) { - departureRouteLock = true; - } + if (departureRoute != null) { + return departureRoute.getTripNumber(); } + return null; + } + + public boolean isReceivingRouteLock() { + if (receivingRoute != null) { + return receivingRoute.isTriggered(); + } + return false; + } + + public boolean isDepartureRouteLock() { + if (departureRoute != null) { + return departureRoute.isTriggered(); + } + return false; + } + + @JsonIgnore + public String getTrackCode() { + if (receivingRoute != null) { + return receivingRoute.getTrackCode(); + } + if (departureRoute != null) { + return departureRoute.getTrackCode(); + } + return null; } public Process getProcess() { if (isDeparture()) { return Process.FINISH; } - if (departureRouteLock) { + if (isDepartureRouteLock()) { return Process.DEPARTURE; } if (isDepartureNotice()) { @@ -152,7 +194,7 @@ public class TrackViewVO { if (isArrive()) { return Process.DEPARTURE_BLOCK; } - if (receivingRouteLock) { + if (isReceivingRouteLock()) { return Process.ARRIVE; } if (isReceivingNotice()) { diff --git a/src/main/java/club/joylink/rtss/vo/client/factory/SocketMessageFactory.java b/src/main/java/club/joylink/rtss/vo/client/factory/SocketMessageFactory.java index e6b0d3998..98355be43 100644 --- a/src/main/java/club/joylink/rtss/vo/client/factory/SocketMessageFactory.java +++ b/src/main/java/club/joylink/rtss/vo/client/factory/SocketMessageFactory.java @@ -415,8 +415,8 @@ public class SocketMessageFactory { /** * CTC进路序列消息 */ - public static SocketMessageVO buildCtcRouteSequenceMessage(String simulationId, - Object message) { + public static SocketMessageVO buildCtcBusyBoardMessage(String simulationId, + Object message) { return build(WebSocketMessageType.Simulation_RailCtcStatus, simulationId, message); } }