openatc-components 0.3.94 → 0.3.96

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (498) hide show
  1. package/.babelrc +18 -18
  2. package/.editorconfig +9 -9
  3. package/.eslintignore +5 -5
  4. package/.eslintrc.js +31 -31
  5. package/.postcssrc.js +10 -10
  6. package/README.md +30 -30
  7. package/build/build.js +41 -41
  8. package/build/check-versions.js +54 -54
  9. package/build/package.config.js +58 -58
  10. package/build/package.dev.config.js +107 -107
  11. package/build/package.prod.config.js +160 -160
  12. package/build/utils.js +101 -101
  13. package/build/vue-loader.conf.js +22 -22
  14. package/build/webpack.base.conf.js +114 -114
  15. package/build/webpack.dev.conf.js +95 -95
  16. package/build/webpack.prod.conf.js +149 -149
  17. package/config/dev.env.js +8 -8
  18. package/config/index.js +94 -94
  19. package/config/prod.env.js +5 -5
  20. package/config/test.env.js +7 -7
  21. package/index.html +12 -12
  22. package/package/kisscomps/components/BoardCard/BoardCard.vue +117 -121
  23. package/package/kisscomps/components/BoardCard/index.js +2 -2
  24. package/package/kisscomps/components/ChannelRealtimeIntersection/ChannelRealtimeIntersection.vue +123 -123
  25. package/package/kisscomps/components/ChannelRealtimeIntersection/index.js +2 -2
  26. package/package/kisscomps/components/Channelization/Channelization.vue +584 -584
  27. package/package/kisscomps/components/Channelization/index.js +2 -2
  28. package/package/kisscomps/components/ChannelizationFlowStatistic/ChannelizationFlowStatistic.vue +360 -360
  29. package/package/kisscomps/components/ChannelizationFlowStatistic/index.js +2 -2
  30. package/package/kisscomps/components/ChannelizationWithInterface/ChannelizationWithInterface.vue +518 -518
  31. package/package/kisscomps/components/ChannelizationWithInterface/index.js +2 -2
  32. package/package/kisscomps/components/CommonKanban/CommonKanban.vue +132 -132
  33. package/package/kisscomps/components/CommonKanban/index.js +2 -2
  34. package/package/kisscomps/components/DirectionListConfiguration/DirectionListConfiguration.vue +456 -456
  35. package/package/kisscomps/components/DirectionListConfiguration/index.js +2 -2
  36. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-east-bottom.vue +41 -41
  37. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-east-top.vue +60 -60
  38. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-ewped.vue +105 -105
  39. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-north-left.vue +60 -60
  40. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-north-right.vue +60 -60
  41. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-snped.vue +105 -105
  42. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-south-left.vue +60 -60
  43. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-south-right.vue +60 -60
  44. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-west-bottom.vue +60 -60
  45. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-west-top.vue +60 -60
  46. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-xlped.vue +30 -30
  47. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-xrped.vue +30 -30
  48. package/package/kisscomps/components/DirectionListConfiguration/svg/pedSvg.vue +78 -78
  49. package/package/kisscomps/components/DrawChannelization/drawsvg/basicCoordInfo.vue +181 -181
  50. package/package/kisscomps/components/DrawChannelization/drawsvg/channelizationElements.vue +255 -255
  51. package/package/kisscomps/components/DrawChannelization/drawsvg/detectorAssociatedComponent.vue +152 -152
  52. package/package/kisscomps/components/DrawChannelization/drawsvg/drawElement/TextBox.vue +91 -91
  53. package/package/kisscomps/components/DrawChannelization/drawsvg/drawElement/crossMap.vue +194 -194
  54. package/package/kisscomps/components/DrawChannelization/drawsvg/drawElement/editText.vue +108 -108
  55. package/package/kisscomps/components/DrawChannelization/drawsvg/firstImportCrossmap.vue +51 -51
  56. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/countdownSvg.vue +236 -236
  57. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorChart.vue +247 -247
  58. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorIconSvg.vue +210 -210
  59. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/laneIcon.vue +72 -72
  60. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/motorwayIconSvg.vue +467 -467
  61. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/pedroadIconSvg.vue +230 -230
  62. package/package/kisscomps/components/DrawChannelization/drawsvg/importDialog.vue +74 -74
  63. package/package/kisscomps/components/DrawChannelization/drawsvg/index.draw.vue +1005 -1005
  64. package/package/kisscomps/components/DrawChannelization/drawsvg/index.vue +110 -110
  65. package/package/kisscomps/components/DrawChannelization/drawsvg/laneEditPanel.vue +707 -707
  66. package/package/kisscomps/components/DrawChannelization/drawsvg/overlapAssociatedComponent.vue +172 -172
  67. package/package/kisscomps/components/DrawChannelization/drawsvg/phaseAssociatedComponent.vue +172 -172
  68. package/package/kisscomps/components/DrawChannelization/drawsvg/table.vue +99 -99
  69. package/package/kisscomps/components/DrawChannelization/drawsvg/utils/loadutils.js +87 -87
  70. package/package/kisscomps/components/DrawChannelization/drawsvg/utils/phaseDataModel.js +32 -32
  71. package/package/kisscomps/components/DrawChannelization/drawsvg/utils/phasePos.json +20 -20
  72. package/package/kisscomps/components/DrawChannelization/index.js +2 -2
  73. package/package/kisscomps/components/DrawChannelization/phaseDataMgr.js +278 -278
  74. package/package/kisscomps/components/ExpendConfig/ExpendConfig.vue +118 -118
  75. package/package/kisscomps/components/ExpendConfig/index.js +2 -2
  76. package/package/kisscomps/components/FaultDetailModal/FaultDetailModal.vue +178 -178
  77. package/package/kisscomps/components/FaultDetailModal/index.js +2 -2
  78. package/package/kisscomps/components/IntersectionDirectionSelection/IntersectionDirectionSelection.vue +158 -158
  79. package/package/kisscomps/components/IntersectionDirectionSelection/index.js +2 -2
  80. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/CrossRoadsSvg.vue +629 -629
  81. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/CustomRoadsSvg.vue +46 -46
  82. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionEWSvg.vue +447 -447
  83. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionSNSvg.vue +341 -341
  84. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampEastSvg.vue +497 -497
  85. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampNorthSvg.vue +353 -353
  86. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampSouthSvg.vue +359 -359
  87. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampWestSvg.vue +443 -443
  88. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkClickSvg.vue +1302 -1302
  89. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkSvg.vue +1190 -1190
  90. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeEastRoadsSvg.vue +498 -498
  91. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeNorthRoadsSvg.vue +484 -484
  92. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeSouthRoadsSvg.vue +488 -488
  93. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeWestRoadsSvg.vue +566 -566
  94. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LCrossRoadsSvg.vue +640 -640
  95. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeEastRoadsSvg.vue +497 -497
  96. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeNorthRoadsSvg.vue +486 -486
  97. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeSouthRoadsSvg.vue +490 -490
  98. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeWestRoadsSvg.vue +575 -575
  99. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/refreshSvg.vue +63 -63
  100. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/busMapSvg.vue +50 -50
  101. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/eastBusSvg.vue +167 -167
  102. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/northBusSvg.vue +168 -168
  103. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/southBusSvg.vue +168 -168
  104. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/westBusSvg.vue +169 -169
  105. package/package/kisscomps/components/IntersectionMap/crossDirection/crossDiagram.vue +1377 -1372
  106. package/package/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/LphaseIconSvg.vue +197 -197
  107. package/package/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/phaseIconSvg.vue +196 -196
  108. package/package/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/rampPhaseIconSvg.vue +122 -122
  109. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.json +196 -196
  110. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.left.json +196 -196
  111. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.json +115 -115
  112. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.left.json +115 -115
  113. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/rampPos.json +52 -52
  114. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/sidePos.json +219 -219
  115. package/package/kisscomps/components/IntersectionMap/crossDirection/utils.js +84 -84
  116. package/package/kisscomps/components/IntersectionMap/index.js +2 -2
  117. package/package/kisscomps/components/IntersectionMap/intersectionmap.vue +220 -211
  118. package/package/kisscomps/components/IntersectionWithInterface/IntersectionWithInterface.vue +534 -530
  119. package/package/kisscomps/components/IntersectionWithInterface/index.js +2 -2
  120. package/package/kisscomps/components/KanBan/index.js +2 -2
  121. package/package/kisscomps/components/KanBan/kanban.vue +231 -231
  122. package/package/kisscomps/components/MessageBox/index.vue +96 -96
  123. package/package/kisscomps/components/OverLap/OverLap.vue +237 -237
  124. package/package/kisscomps/components/OverLap/index.js +2 -2
  125. package/package/kisscomps/components/OverviewComponent/index.js +2 -2
  126. package/package/kisscomps/components/OverviewComponent/index.vue +804 -804
  127. package/package/kisscomps/components/PatternOptimize/PatternOptimize.vue +272 -272
  128. package/package/kisscomps/components/PatternOptimize/index.js +2 -2
  129. package/package/kisscomps/components/PatternStatus/PatternStatus.vue +1664 -1729
  130. package/package/kisscomps/components/PatternStatus/index.js +2 -2
  131. package/package/kisscomps/components/PatternWalkSvg/PatternWalkSvg.vue +423 -423
  132. package/package/kisscomps/components/PatternWalkSvg/index.js +2 -2
  133. package/package/kisscomps/components/PhaseDirectionSelect/PhaseDirectionSelect.vue +126 -126
  134. package/package/kisscomps/components/PhaseDirectionSelect/index.js +2 -2
  135. package/package/kisscomps/components/PhaseDirectionText/PhaseDirectionText.vue +106 -106
  136. package/package/kisscomps/components/PhaseDirectionText/index.js +2 -2
  137. package/package/kisscomps/components/PhaseLegend/PhaseLegend.vue +286 -286
  138. package/package/kisscomps/components/PhaseLegend/index.js +2 -2
  139. package/package/kisscomps/components/PhaseMarker/index.js +6 -6
  140. package/package/kisscomps/components/PhaseMarker/phasemarker.vue +215 -215
  141. package/package/kisscomps/components/PhaseMarker/svg/patternSvg.vue +121 -121
  142. package/package/kisscomps/components/PhaseMarker/svg/phase.vue +60 -60
  143. package/package/kisscomps/components/PhaseMarker/svg/phaseCount.vue +62 -62
  144. package/package/kisscomps/components/PhaseMarker/svg/phaseCountCycle.vue +62 -62
  145. package/package/kisscomps/components/PhaseMarker/svg/phaseSvg.vue +117 -117
  146. package/package/kisscomps/components/PhasePedSelect/index.js +2 -2
  147. package/package/kisscomps/components/PhasePedSelect/index.vue +206 -206
  148. package/package/kisscomps/components/SchemeConfig/SchemeConfig.vue +976 -959
  149. package/package/kisscomps/components/SchemeConfig/azimuthlocking/index.vue +364 -364
  150. package/package/kisscomps/components/SchemeConfig/azimuthlocking/utils.js +92 -92
  151. package/package/kisscomps/components/SchemeConfig/closePhaselControlModal/index.vue +214 -214
  152. package/package/kisscomps/components/SchemeConfig/index.js +2 -2
  153. package/package/kisscomps/components/SchemeConfig/lockingPhaselControlModal/index.vue +237 -237
  154. package/package/kisscomps/components/SchemeConfig/manualControlModal/index.vue +235 -235
  155. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/controlModelGroup.vue +129 -129
  156. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/icon.vue +438 -438
  157. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/index.vue +861 -861
  158. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/othersIcon.vue +151 -151
  159. package/package/kisscomps/components/SchemeConfig/priorityControl/index.vue +215 -215
  160. package/package/kisscomps/components/SchemeConfig/priorityControl/utils.js +163 -163
  161. package/package/kisscomps/components/SchemeConfig/realtimeStatusModal/index.vue +303 -283
  162. package/package/kisscomps/components/SchemeConfig/tentativeplancontrolmodal/index.vue +1207 -1207
  163. package/package/kisscomps/components/SelectCrossPhase/index.vue +418 -418
  164. package/package/kisscomps/components/SelectCrossPhase/utils.js +142 -142
  165. package/package/kisscomps/components/StageBord/StageBord.vue +303 -303
  166. package/package/kisscomps/components/StageBord/index.js +2 -2
  167. package/package/kisscomps/components/StageStatus/StageStatus.vue +341 -341
  168. package/package/kisscomps/components/StageStatus/index.js +2 -2
  169. package/package/kisscomps/components/Stages/index.vue +319 -319
  170. package/package/kisscomps/components/SvgIcon/SvgIcon.vue +53 -53
  171. package/package/kisscomps/components/SvgIcon/index.js +2 -2
  172. package/package/kisscomps/components/XRDDirSelector/XRDDirSelector.vue +1041 -1041
  173. package/package/kisscomps/components/XRDDirSelector/index.js +2 -2
  174. package/package/kisscomps/components/XiaoKanban/DirSelector.vue +356 -356
  175. package/package/kisscomps/components/XiaoKanban/index.vue +122 -122
  176. package/package/kisscomps/components/overView/index.vue +699 -699
  177. package/package/kisscomps/components/patternConfig/index.js +2 -2
  178. package/package/kisscomps/components/patternConfig/index.vue +798 -798
  179. package/package/kisscomps/components/patternConfig/pattern/patternTable.vue +599 -599
  180. package/package/kisscomps/components/patternConfig/pattern/planChart/model/coordinationModel.js +665 -665
  181. package/package/kisscomps/components/patternConfig/planContent.vue +604 -604
  182. package/package/kisscomps/components/patternConfig/planMenu.vue +329 -329
  183. package/package/kisscomps/components/patternConfig/utils.js +152 -152
  184. package/package/kisscomps/components/patternList/index.js +2 -2
  185. package/package/kisscomps/components/patternList/patternList.vue +590 -594
  186. package/package/kisscomps/index.js +129 -127
  187. package/package/kissui.min.js +1 -1
  188. package/package.json +126 -126
  189. package/src/App.vue +24 -24
  190. package/src/EdgeMgr/EdgeModelBase.js +16 -16
  191. package/src/EdgeMgr/controller/crossDiagramMgr.js +125 -125
  192. package/src/api/authapi.js +31 -31
  193. package/src/api/config.js +21 -21
  194. package/src/api/control.js +110 -110
  195. package/src/api/cross.js +49 -49
  196. package/src/api/device.js +135 -135
  197. package/src/api/fault.js +66 -66
  198. package/src/api/index.js +24 -24
  199. package/src/api/login.js +46 -46
  200. package/src/api/optimize.js +72 -72
  201. package/src/api/param.js +165 -165
  202. package/src/api/passwdAssest.js +101 -101
  203. package/src/api/route.js +171 -171
  204. package/src/api/template.js +27 -27
  205. package/src/assets/font/LICENSE.txt +202 -202
  206. package/src/assets/font/font.css +6 -6
  207. package/src/i18n/index.js +26 -26
  208. package/src/i18n/language/en.js +1468 -1461
  209. package/src/i18n/language/index.js +25 -25
  210. package/src/i18n/language/zh.js +1468 -1461
  211. package/src/icons/demo_index.html +8445 -8445
  212. package/src/icons/iconfont.css +1451 -1451
  213. package/src/icons/iconfont.json +2522 -2522
  214. package/src/icons/index.js +20 -20
  215. package/src/icons/svg/azimuthlocking.svg +26 -26
  216. package/src/icons/svg/bendi.svg +110 -110
  217. package/src/icons/svg/bujin.svg +36 -36
  218. package/src/icons/svg/connectBlue.svg +7 -7
  219. package/src/icons/svg/currentvolume.svg +0 -0
  220. package/src/icons/svg/custom-BRTlane.svg +40 -40
  221. package/src/icons/svg/custom-buslane.svg +40 -40
  222. package/src/icons/svg/custom-detector.svg +12 -12
  223. package/src/icons/svg/custom-east-bottom.svg +32 -32
  224. package/src/icons/svg/custom-east-top.svg +32 -32
  225. package/src/icons/svg/custom-ewped.svg +35 -35
  226. package/src/icons/svg/custom-nonmotorizedlane.svg +40 -40
  227. package/src/icons/svg/custom-north-left.svg +32 -32
  228. package/src/icons/svg/custom-north-right.svg +32 -32
  229. package/src/icons/svg/custom-peddetector.svg +17 -17
  230. package/src/icons/svg/custom-snped.svg +35 -35
  231. package/src/icons/svg/custom-south-left.svg +32 -32
  232. package/src/icons/svg/custom-south-right.svg +32 -32
  233. package/src/icons/svg/custom-tramlane.svg +40 -40
  234. package/src/icons/svg/custom-vehiclebranch.svg +40 -40
  235. package/src/icons/svg/custom-vehiclemainroad.svg +41 -41
  236. package/src/icons/svg/custom-west-bottom.svg +32 -32
  237. package/src/icons/svg/custom-west-top.svg +32 -32
  238. package/src/icons/svg/custom-xlped.svg +14 -14
  239. package/src/icons/svg/custom-xrped.svg +14 -14
  240. package/src/icons/svg/cutRed.svg +7 -7
  241. package/src/icons/svg/cycle.svg +0 -0
  242. package/src/icons/svg/dingzhouqi.svg +34 -34
  243. package/src/icons/svg/ganyingkongzhi.svg +30 -30
  244. package/src/icons/svg/guandeng.svg +81 -81
  245. package/src/icons/svg/huangshan.svg +71 -71
  246. package/src/icons/svg/maincontrol.svg +0 -0
  247. package/src/icons/svg/manualcontrolbackground.svg +51 -51
  248. package/src/icons/svg/manualcontrolbackground1.svg +62 -62
  249. package/src/icons/svg/manualcontrolbackgrounden.svg +62 -62
  250. package/src/icons/svg/model.svg +0 -0
  251. package/src/icons/svg/phasediff.svg +0 -0
  252. package/src/icons/svg/prioritycontrol.svg +21 -21
  253. package/src/icons/svg/quanhong.svg +86 -86
  254. package/src/icons/svg/shanghe.svg +11 -11
  255. package/src/icons/svg/shoudong.svg +103 -103
  256. package/src/icons/svg/tentativeplan.svg +28 -28
  257. package/src/icons/svg/time.svg +0 -0
  258. package/src/icons/svg/wuxianlan.svg +46 -46
  259. package/src/icons/svg/xiala.svg +11 -11
  260. package/src/icons/svg/xingrenguojie.svg +33 -33
  261. package/src/icons/svg/xitong.svg +89 -89
  262. package/src/icons/svg/youxian.svg +41 -41
  263. package/src/icons/svg/zizhukongzhi.svg +43 -43
  264. package/src/kisscomps/components/BoardCard/BoardCard.vue +117 -121
  265. package/src/kisscomps/components/BoardCard/index.js +2 -2
  266. package/src/kisscomps/components/ChannelRealtimeIntersection/ChannelRealtimeIntersection.vue +123 -123
  267. package/src/kisscomps/components/ChannelRealtimeIntersection/index.js +2 -2
  268. package/src/kisscomps/components/Channelization/Channelization.vue +584 -584
  269. package/src/kisscomps/components/Channelization/index.js +2 -2
  270. package/src/kisscomps/components/ChannelizationFlowStatistic/ChannelizationFlowStatistic.vue +360 -360
  271. package/src/kisscomps/components/ChannelizationFlowStatistic/index.js +2 -2
  272. package/src/kisscomps/components/ChannelizationWithInterface/ChannelizationWithInterface.vue +518 -518
  273. package/src/kisscomps/components/ChannelizationWithInterface/index.js +2 -2
  274. package/src/kisscomps/components/CommonKanban/CommonKanban.vue +132 -132
  275. package/src/kisscomps/components/CommonKanban/index.js +2 -2
  276. package/src/kisscomps/components/DirectionListConfiguration/DirectionListConfiguration.vue +456 -456
  277. package/src/kisscomps/components/DirectionListConfiguration/index.js +2 -2
  278. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-east-bottom.vue +41 -41
  279. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-east-top.vue +60 -60
  280. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-ewped.vue +105 -105
  281. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-north-left.vue +60 -60
  282. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-north-right.vue +60 -60
  283. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-snped.vue +105 -105
  284. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-south-left.vue +60 -60
  285. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-south-right.vue +60 -60
  286. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-west-bottom.vue +60 -60
  287. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-west-top.vue +60 -60
  288. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-xlped.vue +30 -30
  289. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-xrped.vue +30 -30
  290. package/src/kisscomps/components/DirectionListConfiguration/svg/pedSvg.vue +78 -78
  291. package/src/kisscomps/components/DrawChannelization/drawsvg/basicCoordInfo.vue +181 -181
  292. package/src/kisscomps/components/DrawChannelization/drawsvg/channelizationElements.vue +255 -255
  293. package/src/kisscomps/components/DrawChannelization/drawsvg/detectorAssociatedComponent.vue +152 -152
  294. package/src/kisscomps/components/DrawChannelization/drawsvg/drawElement/TextBox.vue +91 -91
  295. package/src/kisscomps/components/DrawChannelization/drawsvg/drawElement/crossMap.vue +194 -194
  296. package/src/kisscomps/components/DrawChannelization/drawsvg/drawElement/editText.vue +108 -108
  297. package/src/kisscomps/components/DrawChannelization/drawsvg/firstImportCrossmap.vue +51 -51
  298. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/countdownSvg.vue +236 -236
  299. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorChart.vue +247 -247
  300. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorIconSvg.vue +210 -210
  301. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/laneIcon.vue +72 -72
  302. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/motorwayIconSvg.vue +467 -467
  303. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/pedroadIconSvg.vue +230 -230
  304. package/src/kisscomps/components/DrawChannelization/drawsvg/importDialog.vue +74 -74
  305. package/src/kisscomps/components/DrawChannelization/drawsvg/index.draw.vue +1005 -1005
  306. package/src/kisscomps/components/DrawChannelization/drawsvg/index.vue +110 -110
  307. package/src/kisscomps/components/DrawChannelization/drawsvg/laneEditPanel.vue +707 -707
  308. package/src/kisscomps/components/DrawChannelization/drawsvg/overlapAssociatedComponent.vue +172 -172
  309. package/src/kisscomps/components/DrawChannelization/drawsvg/phaseAssociatedComponent.vue +172 -172
  310. package/src/kisscomps/components/DrawChannelization/drawsvg/table.vue +99 -99
  311. package/src/kisscomps/components/DrawChannelization/drawsvg/utils/loadutils.js +87 -87
  312. package/src/kisscomps/components/DrawChannelization/drawsvg/utils/phaseDataModel.js +32 -32
  313. package/src/kisscomps/components/DrawChannelization/drawsvg/utils/phasePos.json +20 -20
  314. package/src/kisscomps/components/DrawChannelization/index.js +2 -2
  315. package/src/kisscomps/components/DrawChannelization/phaseDataMgr.js +278 -278
  316. package/src/kisscomps/components/ExpendConfig/ExpendConfig.vue +118 -118
  317. package/src/kisscomps/components/ExpendConfig/index.js +2 -2
  318. package/src/kisscomps/components/FaultDetailModal/FaultDetailModal.vue +178 -178
  319. package/src/kisscomps/components/FaultDetailModal/index.js +2 -2
  320. package/src/kisscomps/components/IntersectionDirectionSelection/IntersectionDirectionSelection.vue +158 -158
  321. package/src/kisscomps/components/IntersectionDirectionSelection/index.js +2 -2
  322. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/CrossRoadsSvg.vue +629 -629
  323. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/CustomRoadsSvg.vue +46 -46
  324. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionEWSvg.vue +447 -447
  325. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionSNSvg.vue +341 -341
  326. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampEastSvg.vue +497 -497
  327. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampNorthSvg.vue +353 -353
  328. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampSouthSvg.vue +359 -359
  329. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampWestSvg.vue +443 -443
  330. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkClickSvg.vue +1302 -1302
  331. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkSvg.vue +1190 -1190
  332. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeEastRoadsSvg.vue +498 -498
  333. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeNorthRoadsSvg.vue +484 -484
  334. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeSouthRoadsSvg.vue +488 -488
  335. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeWestRoadsSvg.vue +566 -566
  336. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LCrossRoadsSvg.vue +640 -640
  337. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeEastRoadsSvg.vue +497 -497
  338. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeNorthRoadsSvg.vue +486 -486
  339. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeSouthRoadsSvg.vue +490 -490
  340. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeWestRoadsSvg.vue +575 -575
  341. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/refreshSvg.vue +63 -63
  342. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/busMapSvg.vue +50 -50
  343. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/eastBusSvg.vue +167 -167
  344. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/northBusSvg.vue +168 -168
  345. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/southBusSvg.vue +168 -168
  346. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/westBusSvg.vue +169 -169
  347. package/src/kisscomps/components/IntersectionMap/crossDirection/crossDiagram.vue +1377 -1372
  348. package/src/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/LphaseIconSvg.vue +197 -197
  349. package/src/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/phaseIconSvg.vue +196 -196
  350. package/src/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/rampPhaseIconSvg.vue +122 -122
  351. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.json +196 -196
  352. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.left.json +196 -196
  353. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.json +115 -115
  354. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.left.json +115 -115
  355. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/rampPos.json +52 -52
  356. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/sidePos.json +219 -219
  357. package/src/kisscomps/components/IntersectionMap/crossDirection/utils.js +84 -84
  358. package/src/kisscomps/components/IntersectionMap/index.js +2 -2
  359. package/src/kisscomps/components/IntersectionMap/intersectionmap.vue +220 -211
  360. package/src/kisscomps/components/IntersectionWithInterface/IntersectionWithInterface.vue +534 -530
  361. package/src/kisscomps/components/IntersectionWithInterface/index.js +2 -2
  362. package/src/kisscomps/components/KanBan/index.js +2 -2
  363. package/src/kisscomps/components/KanBan/kanban.vue +231 -231
  364. package/src/kisscomps/components/MessageBox/index.vue +96 -96
  365. package/src/kisscomps/components/OverLap/OverLap.vue +237 -237
  366. package/src/kisscomps/components/OverLap/index.js +2 -2
  367. package/src/kisscomps/components/OverviewComponent/index.js +2 -0
  368. package/src/kisscomps/components/OverviewComponent/index.vue +804 -0
  369. package/src/kisscomps/components/PatternOptimize/PatternOptimize.vue +272 -272
  370. package/src/kisscomps/components/PatternOptimize/index.js +2 -2
  371. package/src/kisscomps/components/PatternStatus/PatternStatus.vue +1664 -1729
  372. package/src/kisscomps/components/PatternStatus/index.js +2 -2
  373. package/src/kisscomps/components/PatternWalkSvg/PatternWalkSvg.vue +423 -423
  374. package/src/kisscomps/components/PatternWalkSvg/index.js +2 -2
  375. package/src/kisscomps/components/PhaseDirectionSelect/PhaseDirectionSelect.vue +126 -126
  376. package/src/kisscomps/components/PhaseDirectionSelect/index.js +2 -2
  377. package/src/kisscomps/components/PhaseDirectionText/PhaseDirectionText.vue +106 -106
  378. package/src/kisscomps/components/PhaseDirectionText/index.js +2 -2
  379. package/src/kisscomps/components/PhaseLegend/PhaseLegend.vue +286 -286
  380. package/src/kisscomps/components/PhaseLegend/index.js +2 -2
  381. package/src/kisscomps/components/PhaseMarker/index.js +6 -6
  382. package/src/kisscomps/components/PhaseMarker/phasemarker.vue +215 -215
  383. package/src/kisscomps/components/PhaseMarker/svg/patternSvg.vue +121 -121
  384. package/src/kisscomps/components/PhaseMarker/svg/phase.vue +60 -60
  385. package/src/kisscomps/components/PhaseMarker/svg/phaseCount.vue +62 -62
  386. package/src/kisscomps/components/PhaseMarker/svg/phaseCountCycle.vue +62 -62
  387. package/src/kisscomps/components/PhaseMarker/svg/phaseSvg.vue +117 -117
  388. package/src/kisscomps/components/PhasePedSelect/index.js +2 -2
  389. package/src/kisscomps/components/PhasePedSelect/index.vue +206 -206
  390. package/src/kisscomps/components/SchemeConfig/SchemeConfig.vue +976 -959
  391. package/src/kisscomps/components/SchemeConfig/azimuthlocking/index.vue +364 -364
  392. package/src/kisscomps/components/SchemeConfig/azimuthlocking/utils.js +92 -92
  393. package/src/kisscomps/components/SchemeConfig/closePhaselControlModal/index.vue +214 -214
  394. package/src/kisscomps/components/SchemeConfig/index.js +2 -2
  395. package/src/kisscomps/components/SchemeConfig/lockingPhaselControlModal/index.vue +237 -237
  396. package/src/kisscomps/components/SchemeConfig/manualControlModal/index.vue +235 -235
  397. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/controlModelGroup.vue +129 -129
  398. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/icon.vue +438 -438
  399. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/index.vue +861 -861
  400. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/othersIcon.vue +151 -151
  401. package/src/kisscomps/components/SchemeConfig/priorityControl/index.vue +215 -215
  402. package/src/kisscomps/components/SchemeConfig/priorityControl/utils.js +163 -163
  403. package/src/kisscomps/components/SchemeConfig/realtimeStatusModal/index.vue +303 -283
  404. package/src/kisscomps/components/SchemeConfig/tentativeplancontrolmodal/index.vue +1207 -1207
  405. package/src/kisscomps/components/SelectCrossPhase/index.vue +418 -418
  406. package/src/kisscomps/components/SelectCrossPhase/utils.js +142 -142
  407. package/src/kisscomps/components/StageBord/StageBord.vue +303 -303
  408. package/src/kisscomps/components/StageBord/index.js +2 -2
  409. package/src/kisscomps/components/StageStatus/StageStatus.vue +341 -341
  410. package/src/kisscomps/components/StageStatus/index.js +2 -2
  411. package/src/kisscomps/components/Stages/index.vue +319 -319
  412. package/src/kisscomps/components/SvgIcon/SvgIcon.vue +53 -53
  413. package/src/kisscomps/components/SvgIcon/index.js +2 -2
  414. package/src/kisscomps/components/XRDDirSelector/XRDDirSelector.vue +1041 -1041
  415. package/src/kisscomps/components/XRDDirSelector/index.js +2 -2
  416. package/src/kisscomps/components/XiaoKanban/DirSelector.vue +356 -356
  417. package/src/kisscomps/components/XiaoKanban/index.vue +122 -122
  418. package/src/kisscomps/components/overView/index.vue +699 -699
  419. package/src/kisscomps/components/patternConfig/index.js +2 -2
  420. package/src/kisscomps/components/patternConfig/index.vue +798 -798
  421. package/src/kisscomps/components/patternConfig/pattern/patternTable.vue +599 -599
  422. package/src/kisscomps/components/patternConfig/pattern/planChart/model/coordinationModel.js +665 -665
  423. package/src/kisscomps/components/patternConfig/planContent.vue +604 -604
  424. package/src/kisscomps/components/patternConfig/planMenu.vue +329 -329
  425. package/src/kisscomps/components/patternConfig/utils.js +152 -152
  426. package/src/kisscomps/components/patternList/index.js +2 -2
  427. package/src/kisscomps/components/patternList/patternList.vue +590 -594
  428. package/src/kisscomps/index.js +129 -127
  429. package/src/lib/publicjs/ArryListUtil.js +38 -38
  430. package/src/lib/publicjs/HttpurlMgr.js +45 -45
  431. package/src/lib/publicjs/KissApi.js +158 -158
  432. package/src/lib/publicjs/KissWSSub/Heartcheck.js +128 -128
  433. package/src/lib/publicjs/KissWSSub/KissWsSub.js +91 -91
  434. package/src/lib/publicjs/KissWSSub/KissWsSubByType.js +152 -152
  435. package/src/lib/publicjs/KissWSSub/SimuWsSubByType.js +44 -44
  436. package/src/lib/publicjs/KissWSSub/Sub.js +51 -51
  437. package/src/lib/publicjs/KissWSSub/SubChannel.js +119 -119
  438. package/src/lib/publicjs/basecomponents.js +65 -65
  439. package/src/lib/publicjs/localStorage.js +112 -112
  440. package/src/lib/publicjs/objdeepcopy.js +32 -32
  441. package/src/lib/publicjs/pageScroll.js +30 -30
  442. package/src/lib/publicjs/passwdAssest.js +101 -101
  443. package/src/lib/publicjs/styleclassfactory.js +32 -32
  444. package/src/main.js +51 -51
  445. package/src/router/index.js +63 -63
  446. package/src/store/getters.js +16 -16
  447. package/src/store/index.js +26 -26
  448. package/src/store/modules/globalParam.js +67 -67
  449. package/src/utils/ControlFormat.js +68 -68
  450. package/src/utils/RingDataModel.js +331 -331
  451. package/src/utils/auth.js +199 -199
  452. package/src/utils/conflct.js +268 -268
  453. package/src/utils/conflictList.js +87 -87
  454. package/src/utils/dateFormat.js +41 -41
  455. package/src/utils/errorcode.js +227 -227
  456. package/src/utils/fault.js +196 -196
  457. package/src/utils/faultcode.js +209 -209
  458. package/src/utils/index.js +69 -69
  459. package/src/utils/pedphasedesc.js +119 -119
  460. package/src/utils/phaseList.js +203 -203
  461. package/src/utils/phasedesc.js +144 -144
  462. package/src/utils/responseMessage.js +21 -21
  463. package/src/utils/validate.js +43 -43
  464. package/src/views/customchannelization.vue +49 -49
  465. package/src/views/home.1.vue +479 -479
  466. package/src/views/home.vue +93 -93
  467. package/src/views/intersection.vue +521 -521
  468. package/src/views/intersection2.vue +328 -328
  469. package/src/views/overView.vue +41 -41
  470. package/src/views/patternConfig.vue +14792 -14792
  471. package/src/views/schemeconfig.vue +206 -206
  472. package/static/apiconfig.json +451 -451
  473. package/static/styles/channelizatioon.scss +433 -433
  474. package/static/styles/common.scss +30 -30
  475. package/static/styles/commonkanban.scss +168 -168
  476. package/static/styles/dark/index.scss +2 -2
  477. package/static/styles/dark/theme/element-dark.scss +44 -44
  478. package/static/styles/index.scss +84 -84
  479. package/static/styles/intersection.scss +190 -190
  480. package/static/styles/light/index.scss +2 -2
  481. package/static/styles/light/theme/element-light.scss +44 -44
  482. package/static/styles/overview.scss +146 -146
  483. package/static/styles/patternConfig.scss +56 -56
  484. package/static/styles/phasePedSelect.scss +71 -71
  485. package/static/styles/schemeconfig.scss +549 -549
  486. package/static/styles/stages.scss +57 -57
  487. package/static/styles/uiComponents.scss +57 -57
  488. package/static/styles/xiaokanban.scss +61 -61
  489. package/static/token.json +2 -2
  490. package/test/e2e/custom-assertions/elementCount.js +27 -27
  491. package/test/e2e/nightwatch.conf.js +46 -46
  492. package/test/e2e/runner.js +48 -48
  493. package/test/e2e/specs/test.js +19 -19
  494. package/test/unit/.eslintrc +7 -7
  495. package/test/unit/jest.conf.js +30 -30
  496. package/test/unit/setup.js +3 -3
  497. package/test/unit/specs/HelloWorld.spec.js +11 -11
  498. package/package/kissui.js +0 -216608
@@ -1,665 +1,665 @@
1
- /**
2
- * Copyright (c) 2020 kedacom
3
- * OpenATC is licensed under Mulan PSL v2.
4
- * You can use this software according to the terms and conditions of the Mulan PSL v2.
5
- * You may obtain a copy of Mulan PSL v2 at:
6
- * http://license.coscl.org.cn/MulanPSL2
7
- * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
8
- * EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
9
- * MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
10
- * See the Mulan PSL v2 for more details.
11
- **/
12
- /**
13
- * @Description: Coordination Echarts表格图
14
- * @Author: yangdongyang
15
- * @Date: Create in 11:27 2019/11/26
16
- * @Modified By:
17
- */
18
- import echarts from 'echarts'
19
- import { getTheme } from '../../../../utils/auth'
20
- export default class CoordinationModel {
21
- constructor () {
22
- this.rourte = {}
23
- this.greenwave = []
24
- }
25
- getMaxY () {
26
- let rourte = this.rourte
27
- let maxY = 0
28
- if (Object.keys(rourte).length === 0) return maxY
29
- for (let devs of rourte.devs) {
30
- for (let pattern of devs.patternList) {
31
- if (pattern.cycle > maxY) {
32
- maxY = pattern.cycle
33
- }
34
- }
35
- }
36
- return maxY
37
- }
38
- getMaxX () {
39
- let rourte = this.rourte
40
- let maxX = 0
41
- if (Object.keys(rourte).length === 0) return maxX
42
- for (let devs of rourte.devs) {
43
- maxX = maxX + devs.distance
44
- }
45
- return maxX
46
- }
47
- getInitBarData () {
48
- let rourte = this.rourte
49
- let data = []
50
- let xDistance = 0 // 表示该路口到起点的距离
51
- for (let devs of rourte.devs) {
52
- xDistance = xDistance + devs.distance
53
- let list = [xDistance, 0]
54
- data.push(list)
55
- }
56
- return data
57
- }
58
- getXName (val) {
59
- let rourte = this.rourte
60
- let xDistance = 0 // 表示该路口到起点的距离
61
- let xName = ''
62
- for (let devs of rourte.devs) {
63
- xDistance = xDistance + devs.distance
64
- if (xDistance === val) {
65
- xName = devs.agentid + '(' + val + ')'
66
- }
67
- }
68
- return xName
69
- }
70
- getCycleNum () {
71
- let rourte = this.rourte
72
- let minCycle = 99999
73
- for (let devs of rourte.devs) {
74
- let cycle = devs.patternList[0].cycle
75
- if (cycle < minCycle) {
76
- minCycle = cycle
77
- }
78
- }
79
- let maxValue = this.getMaxY()
80
- let cycleNum = Math.ceil(maxValue * 3 / minCycle)
81
- return cycleNum
82
- }
83
- getSeries () {
84
- let _vue = this
85
- let seriesList = []
86
- let dataTemplate = this.getInitBarData()
87
- let obj = {
88
- type: 'bar',
89
- clickable: false,
90
- stack: '信号灯0',
91
- barWidth: 6,
92
- silent: true,
93
- itemStyle: {
94
- color: '#009f3c'
95
- },
96
- data: dataTemplate,
97
- label: {
98
- show: true,
99
- position: 'bottom',
100
- offset: [0, 5],
101
- color: getTheme() === 'light' ? '#666666' : '#B9BABF',
102
- formatter: function (val) {
103
- return _vue.getXName(val.data[0])
104
- }
105
- }
106
- }
107
- seriesList.push(obj)
108
- let allInterList = []
109
- let forwardCycleDta = this.getForwardIntersectionCycle()
110
- let backCycleDta = this.getBackIntersectionCycle()
111
- allInterList.push(backCycleDta)
112
- allInterList.push(forwardCycleDta)
113
- let cycleNum = this.getCycleNum() // 计算时距图上显示几个周期(以周期最小的路口计算)
114
- for (let s = 0; s < allInterList.length; s++) {
115
- for (let t = 0; t < cycleNum; t++) {
116
- for (let i = 0; i < 4; i++) {
117
- let tempObj = {}
118
- tempObj.type = 'bar'
119
- tempObj.clickable = false
120
- tempObj.stack = '信号灯' + s
121
- tempObj.barWidth = 6
122
- tempObj.silent = true
123
- tempObj.itemStyle = {}
124
- tempObj.data = []
125
- if (i % 2 !== 0) {
126
- tempObj.itemStyle.color = '#009f3c'
127
- } else {
128
- tempObj.itemStyle.color = '#ca0d0d'
129
- }
130
- for (let cycle of allInterList[s]) {
131
- let cycleList = []
132
- cycleList[0] = cycle.distance
133
- cycleList[1] = cycle.value[i]
134
- tempObj.data.push(cycleList)
135
- }
136
- seriesList.push(tempObj)
137
- }
138
- for (let cyc of allInterList[s]) {
139
- let addCycle = cyc.cycle
140
- let val = cyc.value
141
- cyc.value = this.calculationNewCycle(val, addCycle)
142
- }
143
- }
144
- }
145
- let newSeriesList = seriesList.reverse()
146
- // 画时距图阴影部分
147
- let customList = []
148
- let dir = this.rourte.direction
149
- if (dir === 'up') {
150
- let forwardCustomData = this.getCustomData('forward') // 获取正向阴影面积的数据
151
- customList.push(forwardCustomData)
152
- } else if (dir === 'down') {
153
- let backCustomData = this.getCustomData('back') // 获取反向阴影部分面积数据
154
- customList.push(backCustomData)
155
- } else if (dir === 'all') {
156
- let forwardCustomData = this.getCustomData('forward') // 获取正向阴影面积的数据
157
- let backCustomData = this.getCustomData('back') // 获取反向阴影部分面积数据
158
- customList.push(forwardCustomData)
159
- customList.push(backCustomData)
160
- }
161
- for (let customl of customList) {
162
- for (let custom of customl) {
163
- let data = []
164
- data.push(custom)
165
- let customObj = {}
166
- customObj.type = 'custom'
167
- customObj.renderItem = this.renderItem
168
- customObj.silent = true
169
- customObj.data = data // data数据格式为[n1,n2,n3,n4,n5,n6]n1到n4为阴影面的四个带你的y坐标,n5和n6分别表示x轴上的两点
170
- newSeriesList.push(customObj)
171
- }
172
- }
173
- // 画时距图虚线部分
174
- if (this.greenwave.length > 0) {
175
- let allLine = []
176
- let dir = this.rourte.direction
177
- let greenwave = this.greenwave
178
- let upGreenware = greenwave.filter(ele => ele.type === 'up')
179
- let downGreenware = greenwave.filter(ele => ele.type === 'down')
180
- if (dir === 'down') {
181
- let lineDataBack = this.getLineData('down', downGreenware)
182
- allLine.push(lineDataBack)
183
- } else if (dir === 'up') {
184
- let lineDataFoward = this.getLineData('up', upGreenware)
185
- allLine.push(lineDataFoward)
186
- } else if (dir === 'all') {
187
- let lineDataFoward = this.getLineData('down', downGreenware)
188
- let lineDataBack = this.getLineData('up', upGreenware)
189
- allLine.push(lineDataFoward)
190
- allLine.push(lineDataBack)
191
- }
192
- // let lineData = this.getLineData()
193
- for (let lineData of allLine) {
194
- for (let line of lineData) {
195
- let lineObj = {
196
- lineStyle: {
197
- normal: {
198
- color: '#009f3c',
199
- width: 1,
200
- type: 'dashed'
201
- }
202
- }
203
- }
204
- lineObj.name = '最优通行方案'
205
- lineObj.type = 'line'
206
- lineObj.data = line
207
- newSeriesList.push(lineObj)
208
- }
209
- }
210
- // for (let line of lineData) {
211
- // let lineObj = {
212
- // lineStyle: {
213
- // normal: {
214
- // color: '#009f3c',
215
- // width: 1,
216
- // type: 'dashed'
217
- // }
218
- // }
219
- // }
220
- // lineObj.name = '最优通行方案'
221
- // lineObj.type = 'line'
222
- // lineObj.data = line
223
- // newSeriesList.push(lineObj)
224
- // }
225
- }
226
- return newSeriesList
227
- }
228
- getLineData (direction, greenwave) {
229
- let data = []
230
- let rourte = this.rourte
231
- // let greenwave = this.greenwave
232
- if (greenwave.length === 0) return data
233
- let routeList = rourte.devs
234
- let firstXLine = routeList[0].distance // 虚线起点的x坐标
235
- let lastXLine = this.getMaxX() // 虚线终点的x坐标
236
- let firstYLine = greenwave[0].start // 虚线起点的y坐标
237
- let firstYLine2 = greenwave[0].width + firstYLine // 第二条虚线起点的y坐标
238
- let speed = greenwave[0].speed
239
- let lastYLine = 0
240
- if (direction === 'down') {
241
- lastYLine = Number(((lastXLine - firstXLine) / (speed * 1000 / 3600)).toFixed(2)) * (-1) + firstYLine // 下行虚线终点的y坐标
242
- } else if (direction === 'up') {
243
- lastYLine = Number(((lastXLine - firstXLine) / (speed * 1000 / 3600)).toFixed(2)) + firstYLine // 上行虚线终点的y坐标
244
- }
245
- let lastYLine2 = lastYLine + greenwave[0].width // 第二条虚线终点的y坐标
246
- let maxY = this.getMaxY() * 3
247
- let firstDevCycle = rourte.devs[0].patternList[0].cycle
248
- let lineNum = Math.ceil(maxY / firstDevCycle)
249
- for (let i = 0; i < lineNum; i++) { // 根据周期画出多段虚线
250
- let dataList = []
251
- let tempList = []
252
- let addNum = firstDevCycle * i
253
- tempList[0] = firstXLine
254
- tempList[1] = firstYLine + addNum
255
- dataList.push(tempList)
256
- tempList = []
257
- tempList[0] = lastXLine
258
- tempList[1] = lastYLine + addNum
259
- dataList.push(tempList)
260
- data.push(dataList)
261
- tempList = []
262
- dataList = []
263
- tempList[0] = firstXLine
264
- tempList[1] = firstYLine2 + addNum
265
- dataList.push(tempList)
266
- tempList = []
267
- tempList[0] = lastXLine
268
- tempList[1] = lastYLine2 + addNum
269
- dataList.push(tempList)
270
- data.push(dataList)
271
- }
272
- return data
273
- }
274
- getCustomData (direction) {
275
- let rourte = this.rourte
276
- let customList = []
277
- let routeList = rourte.devs
278
- if (routeList.length === 1) return customList // 如果只有一个路口则不画阴影部分
279
- let speed = 0
280
- if (direction === 'forward') {
281
- speed = rourte.upspeed
282
- }
283
- if (direction === 'back') {
284
- speed = rourte.downspeed
285
- }
286
- let dist = 0 // 计算每个路口到原点的距离
287
- for (let i = 0; i < routeList.length - 1; i++) {
288
- dist = dist + routeList[i].distance
289
- if (direction === 'forward') {
290
- let customArea = this.getCustomArea(routeList[i], routeList[i + 1], speed, dist, 'forward')
291
- let firstDistance = dist // 表示第一个路口距离原点的距离
292
- let secondDistance = dist + routeList[i + 1].distance // 表示第二个路口到原点的距离
293
- for (let area of customArea) {
294
- area.push(firstDistance)
295
- area.push(secondDistance)
296
- customList.push(area)
297
- }
298
- }
299
- if (direction === 'back') {
300
- let firstDistance = dist // 表示第一个路口距离原点的距离
301
- let secondDistance = dist + routeList[i + 1].distance // 表示第二个路口到原点的距离
302
- let customArea = this.getCustomArea(routeList[i + 1], routeList[i], speed, secondDistance, 'back')
303
- for (let area of customArea) {
304
- area.push(secondDistance)
305
- area.push(firstDistance)
306
- customList.push(area)
307
- }
308
- }
309
- }
310
- return customList
311
- }
312
- getCustomArea (intersection1, intersection2, speed, dist, direction) {
313
- speed = (speed * 1000 / 3600).toFixed(2)
314
- let maxY = this.getMaxY()
315
- let intersectionCycle1
316
- let intersectionCycle2
317
- let distance
318
- if (direction === 'forward') {
319
- let rings1 = this.getByRingById(intersection1.forwardphaseid, intersection1.patternList[0].rings)
320
- let rings2 = this.getByRingById(intersection2.forwardphaseid, intersection2.patternList[0].rings)
321
- intersectionCycle1 = this.getCycleData(intersection1.forwardphaseid, rings1, intersection1.patternList[0].cycle, intersection1.patternList[0].offset)
322
- intersectionCycle2 = this.getCycleData(intersection2.forwardphaseid, rings2, intersection2.patternList[0].cycle, intersection2.patternList[0].offset)
323
- distance = intersection2.distance
324
- }
325
- if (direction === 'back') {
326
- let rings3 = this.getByRingById(intersection1.backphaseid, intersection1.patternList[0].rings)
327
- let rings4 = this.getByRingById(intersection2.backphaseid, intersection2.patternList[0].rings)
328
- intersectionCycle1 = this.getCycleData(intersection1.backphaseid, rings3, intersection1.patternList[0].cycle, intersection1.patternList[0].offset)
329
- intersectionCycle2 = this.getCycleData(intersection2.backphaseid, rings4, intersection2.patternList[0].cycle, intersection2.patternList[0].offset)
330
- distance = intersection1.distance
331
- }
332
- let intersectionList1 = this.getGreenAreaList(intersectionCycle1, maxY, intersection1.patternList[0].cycle) // 获取第一个路口绿色部分的集合
333
- let intersectionList2 = this.getGreenAreaList(intersectionCycle2, maxY, intersection2.patternList[0].cycle) // 获取第二个路口绿色部分的集合
334
- let time = parseInt(distance / speed) // 时间 = 距离 / 速度
335
- let customAreaList
336
- if (direction === 'forward') {
337
- customAreaList = this.getCustomAreaList(intersectionList1, intersectionList2, time, maxY, speed, dist, 'forward')
338
- }
339
- if (direction === 'back') {
340
- customAreaList = this.getCustomAreaList(intersectionList1, intersectionList2, time, maxY, speed, dist, 'back')
341
- }
342
- return customAreaList
343
- }
344
- getCustomAreaList (intlist1, intlist2, time, maxY, speed, dist, direction) {
345
- let shadowList = []
346
- for (let int1 of intlist1) {
347
- let shadow = []
348
- for (let int2 of intlist2) {
349
- let min = int1[0] + time
350
- let max = int1[1] + time
351
- if (min === int2[0] && max === int2[1]) {
352
- shadow = [int1[0], int1[1], int2[1], int2[0]]
353
- } else if (min < int2[0] && max >= int2[1]) {
354
- shadow = [int2[0] - time, int2[1] - time, int2[1], int2[0]]
355
- } else if (min >= int2[0] && max < int2[1]) {
356
- shadow = [int1[0], int1[1], int1[1] + time, int1[0] + time]
357
- } else if (min >= int2[0] && min < int2[1]) {
358
- shadow = [int1[0], int2[1] - time, int2[1], int1[0] + time]
359
- } else if (max > int2[0] && max <= int2[1]) {
360
- shadow = [int2[0] - time, int1[1], int1[1] + time, int2[0]]
361
- }
362
- }
363
- shadow = this.checkIsOverY(shadow, maxY, speed, dist, direction) // 检验所取数值是否大于y轴最大值,即阴影部分是否溢出
364
- if (shadow.length !== 0) shadowList.push(shadow)
365
- }
366
- return shadowList
367
- }
368
- checkIsOverY (shadow, maxY, speed, dist, direction) {
369
- let maxValue = maxY * 3 // 计算y轴最大值
370
- if (shadow.length === 0) {
371
- return []
372
- } else if (shadow[0] >= maxValue || shadow[3] >= maxValue) {
373
- return []
374
- } else if (shadow[1] > maxValue && shadow[3] < maxValue) {
375
- return [shadow[0], maxValue, shadow[3] + (maxValue - shadow[0]), shadow[3]]
376
- } else if (shadow[2] > maxValue && shadow[3] < maxValue) { // 处理阴影面积部分溢出y轴的情况, return[n1, n2, n3, n4, n5], n1到n4为阴影面积四点的纵坐标值,n5为溢出点的横坐标值,n5对应的y轴value值为y轴最大值
377
- let xValue = (maxValue - shadow[1]) * speed
378
- if (shadow[1] > maxValue) {
379
- return [shadow[0], maxValue, maxValue, shadow[3]]
380
- } else {
381
- if (direction === 'forward') {
382
- return [shadow[0], shadow[1], maxValue, shadow[3], xValue + dist]
383
- } else if (direction === 'back') {
384
- return [shadow[0], shadow[1], maxValue, shadow[3], dist - xValue]
385
- }
386
- // return [shadow[0], shadow[1], maxValue, shadow[3], xValue + dist]
387
- }
388
- } else {
389
- return shadow
390
- }
391
- }
392
- getGreenAreaList (list, max, cycle) {
393
- let greenAreaList = []
394
- let cycleNum = Math.ceil(max * 3 / cycle)
395
- for (let i = 0; i < cycleNum; i++) {
396
- let tempList = []
397
- let tempList1 = []
398
- if (list[3] === 0) {
399
- let val1 = (cycle * i) + list[0]
400
- let val2 = (cycle * i) + list[1]
401
- tempList.push(val1)
402
- tempList.push(val2)
403
- greenAreaList.push(tempList)
404
- } else {
405
- if (i === 0) {
406
- let val1 = list[0]
407
- let val2 = list[1]
408
- let val3 = list[2]
409
- let val4 = list[3] + list[1]
410
- tempList.push(val1)
411
- tempList.push(val2)
412
- tempList1.push(val3)
413
- tempList1.push(val4)
414
- greenAreaList.push(tempList)
415
- greenAreaList.push(tempList1)
416
- } else {
417
- let val3 = (cycle * i) + list[2]
418
- let val4 = (cycle * i) + list[3] + list[1]
419
- tempList.push(val3)
420
- tempList.push(val4)
421
- greenAreaList.push(tempList)
422
- }
423
- }
424
- }
425
- return greenAreaList
426
- }
427
- getForwardIntersectionCycle () { // 获取正向每个路口的相位周期数组
428
- let rourte = this.rourte
429
- let list = []
430
- let distance = 0
431
- for (let devs of rourte.devs) {
432
- let ob = {}
433
- ob.name = devs.agentid
434
- distance = distance + devs.distance
435
- ob.distance = distance
436
- let cycle = devs.patternList[0].cycle
437
- ob.cycle = cycle
438
- let forwardphaseid = devs.forwardphaseid
439
- let rings = this.getByRingById(forwardphaseid, devs.patternList[0].rings)
440
- let offset = devs.patternList[0].offset
441
- ob.value = this.getCycleData(forwardphaseid, rings, cycle, offset)
442
- list.push(ob)
443
- }
444
- return list
445
- }
446
- getBackIntersectionCycle () { // 获取反向每个路口的相位周期数组
447
- let rourte = this.rourte
448
- let list = []
449
- let distance = 0
450
- for (let devs of rourte.devs) {
451
- let ob = {}
452
- ob.name = devs.agentid
453
- distance = distance + devs.distance
454
- ob.distance = distance
455
- let cycle = devs.patternList[0].cycle
456
- ob.cycle = cycle
457
- let backphaseid = devs.backphaseid
458
- let rings = this.getByRingById(backphaseid, devs.patternList[0].rings)
459
- let offset = devs.patternList[0].offset
460
- // ob.value = this.getCycleData(backphaseid, devs.patternList[0].rings, cycle, offset)
461
- ob.value = this.getCycleData(backphaseid, rings, cycle, offset)
462
- list.push(ob)
463
- }
464
- return list
465
- }
466
- calculationNewCycle (list, addNum) { // 将数组里的每个值加addnum
467
- let ll = []
468
- for (let li of list) {
469
- li = li + addNum
470
- ll.push(li)
471
- }
472
- return ll
473
- }
474
- getByRingById (phaseId, ringsList) {
475
- for (let rings of ringsList) {
476
- let ring = rings.filter(item => item.id === phaseId)
477
- if (ring.length > 0) {
478
- return rings
479
- }
480
- }
481
- return []
482
- }
483
- getCycleData (phaseid, rings, cycle, offset) {
484
- let tempList = [0, 0, 0, 0]
485
- let num = rings.length - 1
486
- if (rings.length === 0) return tempList
487
- let val = 0
488
- let greenNum = 0 // 表示时距图中一个周期绿色部分的高度
489
- for (let i = 0; i < rings.length; i++) {
490
- val = val + rings[i].value
491
- if (rings[i].id === phaseid) {
492
- greenNum = rings[i].value
493
- // tempList[1] = greenNum
494
- // tempList[2] = cycle
495
- if (i === 0) {
496
- tempList[1] = greenNum
497
- tempList[2] = cycle
498
- } else if (i === num) {
499
- tempList[0] = cycle - greenNum
500
- tempList[1] = cycle
501
- } else {
502
- tempList[0] = val - greenNum
503
- tempList[1] = val
504
- tempList[2] = cycle
505
- }
506
- }
507
- }
508
- // 根据offset对tempList数组进行调整
509
- if ((offset % cycle) !== 0) {
510
- let relativeOffset = offset % cycle
511
- let greenVal = tempList[1]
512
- if ((relativeOffset + greenVal) < cycle) {
513
- tempList[0] = relativeOffset + greenVal - greenNum
514
- tempList[1] = relativeOffset + greenVal
515
- tempList[2] = cycle
516
- tempList[3] = 0
517
- } else if ((relativeOffset + greenVal) === cycle) {
518
- tempList[0] = cycle - greenNum
519
- tempList[1] = cycle
520
- tempList[2] = 0
521
- tempList[3] = 0
522
- } else {
523
- let greenOffset = relativeOffset + greenVal - cycle
524
- // tempList[0] = 0
525
- // tempList[1] = greenOffset
526
- // tempList[2] = relativeOffset
527
- // tempList[3] = cycle
528
- if (greenOffset < greenNum) {
529
- tempList[0] = 0
530
- tempList[1] = greenOffset
531
- tempList[2] = relativeOffset + greenVal - greenNum
532
- tempList[3] = cycle
533
- } else if (greenOffset === greenNum) {
534
- tempList[0] = 0
535
- tempList[1] = greenNum
536
- tempList[2] = cycle
537
- tempList[3] = 0
538
- } else {
539
- tempList[0] = greenOffset - greenNum
540
- tempList[1] = greenOffset
541
- tempList[2] = cycle
542
- tempList[3] = 0
543
- }
544
- }
545
- }
546
- return tempList
547
- }
548
- renderItem (params, api) {
549
- if (params.context.rendered) {
550
- return
551
- }
552
- params.context.rendered = true
553
- var points = []
554
- if (!Number.isNaN(api.value(6))) { // 处理阴影面积溢出y轴的情况
555
- points.push(api.coord([api.value(5), api.value(0)]))
556
- points.push(api.coord([api.value(5), api.value(1)]))
557
- points.push(api.coord([api.value(4), api.value(2)]))
558
- points.push(api.coord([api.value(6), api.value(2)]))
559
- points.push(api.coord([api.value(6), api.value(3)]))
560
- } else { // 处理正常情况
561
- points.push(api.coord([api.value(4), api.value(0)]))
562
- points.push(api.coord([api.value(4), api.value(1)]))
563
- points.push(api.coord([api.value(5), api.value(2)]))
564
- points.push(api.coord([api.value(5), api.value(3)]))
565
- }
566
- return {
567
- type: 'polygon',
568
- shape: {
569
- // points: points
570
- points: echarts.graphic.clipPointsByRect(points, {
571
- x: params.coordSys.x,
572
- y: params.coordSys.y,
573
- width: params.coordSys.width,
574
- height: params.coordSys.height
575
- })
576
- },
577
- style: api.style({
578
- fill: 'rgba(0, 159, 60, 0.2)'
579
- // stroke: echarts.color.lift(color)
580
- })
581
- }
582
- }
583
- RenderOption () {
584
- return {
585
- // legend: {
586
- // data: ['红灯1', '绿灯1']
587
- // },
588
- tooltip: {
589
- // trigger: 'axis',
590
- axisPointer: {
591
- type: 'cross',
592
- label: {
593
- backgroundColor: '#6a7985'
594
- }
595
- },
596
- formatter: function (params) {
597
- return ''
598
- }
599
- },
600
- grid: {
601
- left: '3%',
602
- right: '4%',
603
- bottom: '3%',
604
- containLabel: true
605
- },
606
- xAxis: [
607
- {
608
- type: 'value',
609
- name: '距离(m)',
610
- nameGap: 5,
611
- axisTick: {
612
- show: false,
613
- alignWithLabel: false
614
- },
615
- splitLine: {
616
- show: false
617
- },
618
- axisLabel: { // 可以设置x轴的value格式
619
- formatter: function (val) {
620
- return ''
621
- },
622
- interval: 0
623
- // rotate: 30
624
- },
625
- nameTextStyle: {
626
- color: getTheme() === 'light' ? '#666666' : '#B9BABF'
627
- },
628
- min: -50,
629
- max: this.getMaxX() + 50
630
- }
631
- ],
632
- yAxis: [
633
- {
634
- type: 'value',
635
- name: '时间(s)',
636
- axisLine: {
637
- show: true,
638
- onZero: false
639
- },
640
- axisTick: {
641
- show: false
642
- },
643
- splitLine: {
644
- show: true,
645
- lineStyle: {
646
- color: getTheme() === 'light' ? '#DCDFE6' : '#30384d'
647
- }
648
- },
649
- nameTextStyle: {
650
- color: getTheme() === 'light' ? '#666666' : '#B9BABF'
651
- },
652
- axisLabel: {
653
- textStyle: {
654
- color: getTheme() === 'light' ? '#666666' : '#B9BABF'
655
- }
656
- },
657
- min: 0,
658
- max: this.getMaxY() * 3
659
- // show: false
660
- }
661
- ],
662
- series: this.getSeries()
663
- }
664
- }
665
- }
1
+ /**
2
+ * Copyright (c) 2020 kedacom
3
+ * OpenATC is licensed under Mulan PSL v2.
4
+ * You can use this software according to the terms and conditions of the Mulan PSL v2.
5
+ * You may obtain a copy of Mulan PSL v2 at:
6
+ * http://license.coscl.org.cn/MulanPSL2
7
+ * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
8
+ * EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
9
+ * MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
10
+ * See the Mulan PSL v2 for more details.
11
+ **/
12
+ /**
13
+ * @Description: Coordination Echarts表格图
14
+ * @Author: yangdongyang
15
+ * @Date: Create in 11:27 2019/11/26
16
+ * @Modified By:
17
+ */
18
+ import echarts from 'echarts'
19
+ import { getTheme } from '../../../../utils/auth'
20
+ export default class CoordinationModel {
21
+ constructor () {
22
+ this.rourte = {}
23
+ this.greenwave = []
24
+ }
25
+ getMaxY () {
26
+ let rourte = this.rourte
27
+ let maxY = 0
28
+ if (Object.keys(rourte).length === 0) return maxY
29
+ for (let devs of rourte.devs) {
30
+ for (let pattern of devs.patternList) {
31
+ if (pattern.cycle > maxY) {
32
+ maxY = pattern.cycle
33
+ }
34
+ }
35
+ }
36
+ return maxY
37
+ }
38
+ getMaxX () {
39
+ let rourte = this.rourte
40
+ let maxX = 0
41
+ if (Object.keys(rourte).length === 0) return maxX
42
+ for (let devs of rourte.devs) {
43
+ maxX = maxX + devs.distance
44
+ }
45
+ return maxX
46
+ }
47
+ getInitBarData () {
48
+ let rourte = this.rourte
49
+ let data = []
50
+ let xDistance = 0 // 表示该路口到起点的距离
51
+ for (let devs of rourte.devs) {
52
+ xDistance = xDistance + devs.distance
53
+ let list = [xDistance, 0]
54
+ data.push(list)
55
+ }
56
+ return data
57
+ }
58
+ getXName (val) {
59
+ let rourte = this.rourte
60
+ let xDistance = 0 // 表示该路口到起点的距离
61
+ let xName = ''
62
+ for (let devs of rourte.devs) {
63
+ xDistance = xDistance + devs.distance
64
+ if (xDistance === val) {
65
+ xName = devs.agentid + '(' + val + ')'
66
+ }
67
+ }
68
+ return xName
69
+ }
70
+ getCycleNum () {
71
+ let rourte = this.rourte
72
+ let minCycle = 99999
73
+ for (let devs of rourte.devs) {
74
+ let cycle = devs.patternList[0].cycle
75
+ if (cycle < minCycle) {
76
+ minCycle = cycle
77
+ }
78
+ }
79
+ let maxValue = this.getMaxY()
80
+ let cycleNum = Math.ceil(maxValue * 3 / minCycle)
81
+ return cycleNum
82
+ }
83
+ getSeries () {
84
+ let _vue = this
85
+ let seriesList = []
86
+ let dataTemplate = this.getInitBarData()
87
+ let obj = {
88
+ type: 'bar',
89
+ clickable: false,
90
+ stack: '信号灯0',
91
+ barWidth: 6,
92
+ silent: true,
93
+ itemStyle: {
94
+ color: '#009f3c'
95
+ },
96
+ data: dataTemplate,
97
+ label: {
98
+ show: true,
99
+ position: 'bottom',
100
+ offset: [0, 5],
101
+ color: getTheme() === 'light' ? '#666666' : '#B9BABF',
102
+ formatter: function (val) {
103
+ return _vue.getXName(val.data[0])
104
+ }
105
+ }
106
+ }
107
+ seriesList.push(obj)
108
+ let allInterList = []
109
+ let forwardCycleDta = this.getForwardIntersectionCycle()
110
+ let backCycleDta = this.getBackIntersectionCycle()
111
+ allInterList.push(backCycleDta)
112
+ allInterList.push(forwardCycleDta)
113
+ let cycleNum = this.getCycleNum() // 计算时距图上显示几个周期(以周期最小的路口计算)
114
+ for (let s = 0; s < allInterList.length; s++) {
115
+ for (let t = 0; t < cycleNum; t++) {
116
+ for (let i = 0; i < 4; i++) {
117
+ let tempObj = {}
118
+ tempObj.type = 'bar'
119
+ tempObj.clickable = false
120
+ tempObj.stack = '信号灯' + s
121
+ tempObj.barWidth = 6
122
+ tempObj.silent = true
123
+ tempObj.itemStyle = {}
124
+ tempObj.data = []
125
+ if (i % 2 !== 0) {
126
+ tempObj.itemStyle.color = '#009f3c'
127
+ } else {
128
+ tempObj.itemStyle.color = '#ca0d0d'
129
+ }
130
+ for (let cycle of allInterList[s]) {
131
+ let cycleList = []
132
+ cycleList[0] = cycle.distance
133
+ cycleList[1] = cycle.value[i]
134
+ tempObj.data.push(cycleList)
135
+ }
136
+ seriesList.push(tempObj)
137
+ }
138
+ for (let cyc of allInterList[s]) {
139
+ let addCycle = cyc.cycle
140
+ let val = cyc.value
141
+ cyc.value = this.calculationNewCycle(val, addCycle)
142
+ }
143
+ }
144
+ }
145
+ let newSeriesList = seriesList.reverse()
146
+ // 画时距图阴影部分
147
+ let customList = []
148
+ let dir = this.rourte.direction
149
+ if (dir === 'up') {
150
+ let forwardCustomData = this.getCustomData('forward') // 获取正向阴影面积的数据
151
+ customList.push(forwardCustomData)
152
+ } else if (dir === 'down') {
153
+ let backCustomData = this.getCustomData('back') // 获取反向阴影部分面积数据
154
+ customList.push(backCustomData)
155
+ } else if (dir === 'all') {
156
+ let forwardCustomData = this.getCustomData('forward') // 获取正向阴影面积的数据
157
+ let backCustomData = this.getCustomData('back') // 获取反向阴影部分面积数据
158
+ customList.push(forwardCustomData)
159
+ customList.push(backCustomData)
160
+ }
161
+ for (let customl of customList) {
162
+ for (let custom of customl) {
163
+ let data = []
164
+ data.push(custom)
165
+ let customObj = {}
166
+ customObj.type = 'custom'
167
+ customObj.renderItem = this.renderItem
168
+ customObj.silent = true
169
+ customObj.data = data // data数据格式为[n1,n2,n3,n4,n5,n6]n1到n4为阴影面的四个带你的y坐标,n5和n6分别表示x轴上的两点
170
+ newSeriesList.push(customObj)
171
+ }
172
+ }
173
+ // 画时距图虚线部分
174
+ if (this.greenwave.length > 0) {
175
+ let allLine = []
176
+ let dir = this.rourte.direction
177
+ let greenwave = this.greenwave
178
+ let upGreenware = greenwave.filter(ele => ele.type === 'up')
179
+ let downGreenware = greenwave.filter(ele => ele.type === 'down')
180
+ if (dir === 'down') {
181
+ let lineDataBack = this.getLineData('down', downGreenware)
182
+ allLine.push(lineDataBack)
183
+ } else if (dir === 'up') {
184
+ let lineDataFoward = this.getLineData('up', upGreenware)
185
+ allLine.push(lineDataFoward)
186
+ } else if (dir === 'all') {
187
+ let lineDataFoward = this.getLineData('down', downGreenware)
188
+ let lineDataBack = this.getLineData('up', upGreenware)
189
+ allLine.push(lineDataFoward)
190
+ allLine.push(lineDataBack)
191
+ }
192
+ // let lineData = this.getLineData()
193
+ for (let lineData of allLine) {
194
+ for (let line of lineData) {
195
+ let lineObj = {
196
+ lineStyle: {
197
+ normal: {
198
+ color: '#009f3c',
199
+ width: 1,
200
+ type: 'dashed'
201
+ }
202
+ }
203
+ }
204
+ lineObj.name = '最优通行方案'
205
+ lineObj.type = 'line'
206
+ lineObj.data = line
207
+ newSeriesList.push(lineObj)
208
+ }
209
+ }
210
+ // for (let line of lineData) {
211
+ // let lineObj = {
212
+ // lineStyle: {
213
+ // normal: {
214
+ // color: '#009f3c',
215
+ // width: 1,
216
+ // type: 'dashed'
217
+ // }
218
+ // }
219
+ // }
220
+ // lineObj.name = '最优通行方案'
221
+ // lineObj.type = 'line'
222
+ // lineObj.data = line
223
+ // newSeriesList.push(lineObj)
224
+ // }
225
+ }
226
+ return newSeriesList
227
+ }
228
+ getLineData (direction, greenwave) {
229
+ let data = []
230
+ let rourte = this.rourte
231
+ // let greenwave = this.greenwave
232
+ if (greenwave.length === 0) return data
233
+ let routeList = rourte.devs
234
+ let firstXLine = routeList[0].distance // 虚线起点的x坐标
235
+ let lastXLine = this.getMaxX() // 虚线终点的x坐标
236
+ let firstYLine = greenwave[0].start // 虚线起点的y坐标
237
+ let firstYLine2 = greenwave[0].width + firstYLine // 第二条虚线起点的y坐标
238
+ let speed = greenwave[0].speed
239
+ let lastYLine = 0
240
+ if (direction === 'down') {
241
+ lastYLine = Number(((lastXLine - firstXLine) / (speed * 1000 / 3600)).toFixed(2)) * (-1) + firstYLine // 下行虚线终点的y坐标
242
+ } else if (direction === 'up') {
243
+ lastYLine = Number(((lastXLine - firstXLine) / (speed * 1000 / 3600)).toFixed(2)) + firstYLine // 上行虚线终点的y坐标
244
+ }
245
+ let lastYLine2 = lastYLine + greenwave[0].width // 第二条虚线终点的y坐标
246
+ let maxY = this.getMaxY() * 3
247
+ let firstDevCycle = rourte.devs[0].patternList[0].cycle
248
+ let lineNum = Math.ceil(maxY / firstDevCycle)
249
+ for (let i = 0; i < lineNum; i++) { // 根据周期画出多段虚线
250
+ let dataList = []
251
+ let tempList = []
252
+ let addNum = firstDevCycle * i
253
+ tempList[0] = firstXLine
254
+ tempList[1] = firstYLine + addNum
255
+ dataList.push(tempList)
256
+ tempList = []
257
+ tempList[0] = lastXLine
258
+ tempList[1] = lastYLine + addNum
259
+ dataList.push(tempList)
260
+ data.push(dataList)
261
+ tempList = []
262
+ dataList = []
263
+ tempList[0] = firstXLine
264
+ tempList[1] = firstYLine2 + addNum
265
+ dataList.push(tempList)
266
+ tempList = []
267
+ tempList[0] = lastXLine
268
+ tempList[1] = lastYLine2 + addNum
269
+ dataList.push(tempList)
270
+ data.push(dataList)
271
+ }
272
+ return data
273
+ }
274
+ getCustomData (direction) {
275
+ let rourte = this.rourte
276
+ let customList = []
277
+ let routeList = rourte.devs
278
+ if (routeList.length === 1) return customList // 如果只有一个路口则不画阴影部分
279
+ let speed = 0
280
+ if (direction === 'forward') {
281
+ speed = rourte.upspeed
282
+ }
283
+ if (direction === 'back') {
284
+ speed = rourte.downspeed
285
+ }
286
+ let dist = 0 // 计算每个路口到原点的距离
287
+ for (let i = 0; i < routeList.length - 1; i++) {
288
+ dist = dist + routeList[i].distance
289
+ if (direction === 'forward') {
290
+ let customArea = this.getCustomArea(routeList[i], routeList[i + 1], speed, dist, 'forward')
291
+ let firstDistance = dist // 表示第一个路口距离原点的距离
292
+ let secondDistance = dist + routeList[i + 1].distance // 表示第二个路口到原点的距离
293
+ for (let area of customArea) {
294
+ area.push(firstDistance)
295
+ area.push(secondDistance)
296
+ customList.push(area)
297
+ }
298
+ }
299
+ if (direction === 'back') {
300
+ let firstDistance = dist // 表示第一个路口距离原点的距离
301
+ let secondDistance = dist + routeList[i + 1].distance // 表示第二个路口到原点的距离
302
+ let customArea = this.getCustomArea(routeList[i + 1], routeList[i], speed, secondDistance, 'back')
303
+ for (let area of customArea) {
304
+ area.push(secondDistance)
305
+ area.push(firstDistance)
306
+ customList.push(area)
307
+ }
308
+ }
309
+ }
310
+ return customList
311
+ }
312
+ getCustomArea (intersection1, intersection2, speed, dist, direction) {
313
+ speed = (speed * 1000 / 3600).toFixed(2)
314
+ let maxY = this.getMaxY()
315
+ let intersectionCycle1
316
+ let intersectionCycle2
317
+ let distance
318
+ if (direction === 'forward') {
319
+ let rings1 = this.getByRingById(intersection1.forwardphaseid, intersection1.patternList[0].rings)
320
+ let rings2 = this.getByRingById(intersection2.forwardphaseid, intersection2.patternList[0].rings)
321
+ intersectionCycle1 = this.getCycleData(intersection1.forwardphaseid, rings1, intersection1.patternList[0].cycle, intersection1.patternList[0].offset)
322
+ intersectionCycle2 = this.getCycleData(intersection2.forwardphaseid, rings2, intersection2.patternList[0].cycle, intersection2.patternList[0].offset)
323
+ distance = intersection2.distance
324
+ }
325
+ if (direction === 'back') {
326
+ let rings3 = this.getByRingById(intersection1.backphaseid, intersection1.patternList[0].rings)
327
+ let rings4 = this.getByRingById(intersection2.backphaseid, intersection2.patternList[0].rings)
328
+ intersectionCycle1 = this.getCycleData(intersection1.backphaseid, rings3, intersection1.patternList[0].cycle, intersection1.patternList[0].offset)
329
+ intersectionCycle2 = this.getCycleData(intersection2.backphaseid, rings4, intersection2.patternList[0].cycle, intersection2.patternList[0].offset)
330
+ distance = intersection1.distance
331
+ }
332
+ let intersectionList1 = this.getGreenAreaList(intersectionCycle1, maxY, intersection1.patternList[0].cycle) // 获取第一个路口绿色部分的集合
333
+ let intersectionList2 = this.getGreenAreaList(intersectionCycle2, maxY, intersection2.patternList[0].cycle) // 获取第二个路口绿色部分的集合
334
+ let time = parseInt(distance / speed) // 时间 = 距离 / 速度
335
+ let customAreaList
336
+ if (direction === 'forward') {
337
+ customAreaList = this.getCustomAreaList(intersectionList1, intersectionList2, time, maxY, speed, dist, 'forward')
338
+ }
339
+ if (direction === 'back') {
340
+ customAreaList = this.getCustomAreaList(intersectionList1, intersectionList2, time, maxY, speed, dist, 'back')
341
+ }
342
+ return customAreaList
343
+ }
344
+ getCustomAreaList (intlist1, intlist2, time, maxY, speed, dist, direction) {
345
+ let shadowList = []
346
+ for (let int1 of intlist1) {
347
+ let shadow = []
348
+ for (let int2 of intlist2) {
349
+ let min = int1[0] + time
350
+ let max = int1[1] + time
351
+ if (min === int2[0] && max === int2[1]) {
352
+ shadow = [int1[0], int1[1], int2[1], int2[0]]
353
+ } else if (min < int2[0] && max >= int2[1]) {
354
+ shadow = [int2[0] - time, int2[1] - time, int2[1], int2[0]]
355
+ } else if (min >= int2[0] && max < int2[1]) {
356
+ shadow = [int1[0], int1[1], int1[1] + time, int1[0] + time]
357
+ } else if (min >= int2[0] && min < int2[1]) {
358
+ shadow = [int1[0], int2[1] - time, int2[1], int1[0] + time]
359
+ } else if (max > int2[0] && max <= int2[1]) {
360
+ shadow = [int2[0] - time, int1[1], int1[1] + time, int2[0]]
361
+ }
362
+ }
363
+ shadow = this.checkIsOverY(shadow, maxY, speed, dist, direction) // 检验所取数值是否大于y轴最大值,即阴影部分是否溢出
364
+ if (shadow.length !== 0) shadowList.push(shadow)
365
+ }
366
+ return shadowList
367
+ }
368
+ checkIsOverY (shadow, maxY, speed, dist, direction) {
369
+ let maxValue = maxY * 3 // 计算y轴最大值
370
+ if (shadow.length === 0) {
371
+ return []
372
+ } else if (shadow[0] >= maxValue || shadow[3] >= maxValue) {
373
+ return []
374
+ } else if (shadow[1] > maxValue && shadow[3] < maxValue) {
375
+ return [shadow[0], maxValue, shadow[3] + (maxValue - shadow[0]), shadow[3]]
376
+ } else if (shadow[2] > maxValue && shadow[3] < maxValue) { // 处理阴影面积部分溢出y轴的情况, return[n1, n2, n3, n4, n5], n1到n4为阴影面积四点的纵坐标值,n5为溢出点的横坐标值,n5对应的y轴value值为y轴最大值
377
+ let xValue = (maxValue - shadow[1]) * speed
378
+ if (shadow[1] > maxValue) {
379
+ return [shadow[0], maxValue, maxValue, shadow[3]]
380
+ } else {
381
+ if (direction === 'forward') {
382
+ return [shadow[0], shadow[1], maxValue, shadow[3], xValue + dist]
383
+ } else if (direction === 'back') {
384
+ return [shadow[0], shadow[1], maxValue, shadow[3], dist - xValue]
385
+ }
386
+ // return [shadow[0], shadow[1], maxValue, shadow[3], xValue + dist]
387
+ }
388
+ } else {
389
+ return shadow
390
+ }
391
+ }
392
+ getGreenAreaList (list, max, cycle) {
393
+ let greenAreaList = []
394
+ let cycleNum = Math.ceil(max * 3 / cycle)
395
+ for (let i = 0; i < cycleNum; i++) {
396
+ let tempList = []
397
+ let tempList1 = []
398
+ if (list[3] === 0) {
399
+ let val1 = (cycle * i) + list[0]
400
+ let val2 = (cycle * i) + list[1]
401
+ tempList.push(val1)
402
+ tempList.push(val2)
403
+ greenAreaList.push(tempList)
404
+ } else {
405
+ if (i === 0) {
406
+ let val1 = list[0]
407
+ let val2 = list[1]
408
+ let val3 = list[2]
409
+ let val4 = list[3] + list[1]
410
+ tempList.push(val1)
411
+ tempList.push(val2)
412
+ tempList1.push(val3)
413
+ tempList1.push(val4)
414
+ greenAreaList.push(tempList)
415
+ greenAreaList.push(tempList1)
416
+ } else {
417
+ let val3 = (cycle * i) + list[2]
418
+ let val4 = (cycle * i) + list[3] + list[1]
419
+ tempList.push(val3)
420
+ tempList.push(val4)
421
+ greenAreaList.push(tempList)
422
+ }
423
+ }
424
+ }
425
+ return greenAreaList
426
+ }
427
+ getForwardIntersectionCycle () { // 获取正向每个路口的相位周期数组
428
+ let rourte = this.rourte
429
+ let list = []
430
+ let distance = 0
431
+ for (let devs of rourte.devs) {
432
+ let ob = {}
433
+ ob.name = devs.agentid
434
+ distance = distance + devs.distance
435
+ ob.distance = distance
436
+ let cycle = devs.patternList[0].cycle
437
+ ob.cycle = cycle
438
+ let forwardphaseid = devs.forwardphaseid
439
+ let rings = this.getByRingById(forwardphaseid, devs.patternList[0].rings)
440
+ let offset = devs.patternList[0].offset
441
+ ob.value = this.getCycleData(forwardphaseid, rings, cycle, offset)
442
+ list.push(ob)
443
+ }
444
+ return list
445
+ }
446
+ getBackIntersectionCycle () { // 获取反向每个路口的相位周期数组
447
+ let rourte = this.rourte
448
+ let list = []
449
+ let distance = 0
450
+ for (let devs of rourte.devs) {
451
+ let ob = {}
452
+ ob.name = devs.agentid
453
+ distance = distance + devs.distance
454
+ ob.distance = distance
455
+ let cycle = devs.patternList[0].cycle
456
+ ob.cycle = cycle
457
+ let backphaseid = devs.backphaseid
458
+ let rings = this.getByRingById(backphaseid, devs.patternList[0].rings)
459
+ let offset = devs.patternList[0].offset
460
+ // ob.value = this.getCycleData(backphaseid, devs.patternList[0].rings, cycle, offset)
461
+ ob.value = this.getCycleData(backphaseid, rings, cycle, offset)
462
+ list.push(ob)
463
+ }
464
+ return list
465
+ }
466
+ calculationNewCycle (list, addNum) { // 将数组里的每个值加addnum
467
+ let ll = []
468
+ for (let li of list) {
469
+ li = li + addNum
470
+ ll.push(li)
471
+ }
472
+ return ll
473
+ }
474
+ getByRingById (phaseId, ringsList) {
475
+ for (let rings of ringsList) {
476
+ let ring = rings.filter(item => item.id === phaseId)
477
+ if (ring.length > 0) {
478
+ return rings
479
+ }
480
+ }
481
+ return []
482
+ }
483
+ getCycleData (phaseid, rings, cycle, offset) {
484
+ let tempList = [0, 0, 0, 0]
485
+ let num = rings.length - 1
486
+ if (rings.length === 0) return tempList
487
+ let val = 0
488
+ let greenNum = 0 // 表示时距图中一个周期绿色部分的高度
489
+ for (let i = 0; i < rings.length; i++) {
490
+ val = val + rings[i].value
491
+ if (rings[i].id === phaseid) {
492
+ greenNum = rings[i].value
493
+ // tempList[1] = greenNum
494
+ // tempList[2] = cycle
495
+ if (i === 0) {
496
+ tempList[1] = greenNum
497
+ tempList[2] = cycle
498
+ } else if (i === num) {
499
+ tempList[0] = cycle - greenNum
500
+ tempList[1] = cycle
501
+ } else {
502
+ tempList[0] = val - greenNum
503
+ tempList[1] = val
504
+ tempList[2] = cycle
505
+ }
506
+ }
507
+ }
508
+ // 根据offset对tempList数组进行调整
509
+ if ((offset % cycle) !== 0) {
510
+ let relativeOffset = offset % cycle
511
+ let greenVal = tempList[1]
512
+ if ((relativeOffset + greenVal) < cycle) {
513
+ tempList[0] = relativeOffset + greenVal - greenNum
514
+ tempList[1] = relativeOffset + greenVal
515
+ tempList[2] = cycle
516
+ tempList[3] = 0
517
+ } else if ((relativeOffset + greenVal) === cycle) {
518
+ tempList[0] = cycle - greenNum
519
+ tempList[1] = cycle
520
+ tempList[2] = 0
521
+ tempList[3] = 0
522
+ } else {
523
+ let greenOffset = relativeOffset + greenVal - cycle
524
+ // tempList[0] = 0
525
+ // tempList[1] = greenOffset
526
+ // tempList[2] = relativeOffset
527
+ // tempList[3] = cycle
528
+ if (greenOffset < greenNum) {
529
+ tempList[0] = 0
530
+ tempList[1] = greenOffset
531
+ tempList[2] = relativeOffset + greenVal - greenNum
532
+ tempList[3] = cycle
533
+ } else if (greenOffset === greenNum) {
534
+ tempList[0] = 0
535
+ tempList[1] = greenNum
536
+ tempList[2] = cycle
537
+ tempList[3] = 0
538
+ } else {
539
+ tempList[0] = greenOffset - greenNum
540
+ tempList[1] = greenOffset
541
+ tempList[2] = cycle
542
+ tempList[3] = 0
543
+ }
544
+ }
545
+ }
546
+ return tempList
547
+ }
548
+ renderItem (params, api) {
549
+ if (params.context.rendered) {
550
+ return
551
+ }
552
+ params.context.rendered = true
553
+ var points = []
554
+ if (!Number.isNaN(api.value(6))) { // 处理阴影面积溢出y轴的情况
555
+ points.push(api.coord([api.value(5), api.value(0)]))
556
+ points.push(api.coord([api.value(5), api.value(1)]))
557
+ points.push(api.coord([api.value(4), api.value(2)]))
558
+ points.push(api.coord([api.value(6), api.value(2)]))
559
+ points.push(api.coord([api.value(6), api.value(3)]))
560
+ } else { // 处理正常情况
561
+ points.push(api.coord([api.value(4), api.value(0)]))
562
+ points.push(api.coord([api.value(4), api.value(1)]))
563
+ points.push(api.coord([api.value(5), api.value(2)]))
564
+ points.push(api.coord([api.value(5), api.value(3)]))
565
+ }
566
+ return {
567
+ type: 'polygon',
568
+ shape: {
569
+ // points: points
570
+ points: echarts.graphic.clipPointsByRect(points, {
571
+ x: params.coordSys.x,
572
+ y: params.coordSys.y,
573
+ width: params.coordSys.width,
574
+ height: params.coordSys.height
575
+ })
576
+ },
577
+ style: api.style({
578
+ fill: 'rgba(0, 159, 60, 0.2)'
579
+ // stroke: echarts.color.lift(color)
580
+ })
581
+ }
582
+ }
583
+ RenderOption () {
584
+ return {
585
+ // legend: {
586
+ // data: ['红灯1', '绿灯1']
587
+ // },
588
+ tooltip: {
589
+ // trigger: 'axis',
590
+ axisPointer: {
591
+ type: 'cross',
592
+ label: {
593
+ backgroundColor: '#6a7985'
594
+ }
595
+ },
596
+ formatter: function (params) {
597
+ return ''
598
+ }
599
+ },
600
+ grid: {
601
+ left: '3%',
602
+ right: '4%',
603
+ bottom: '3%',
604
+ containLabel: true
605
+ },
606
+ xAxis: [
607
+ {
608
+ type: 'value',
609
+ name: '距离(m)',
610
+ nameGap: 5,
611
+ axisTick: {
612
+ show: false,
613
+ alignWithLabel: false
614
+ },
615
+ splitLine: {
616
+ show: false
617
+ },
618
+ axisLabel: { // 可以设置x轴的value格式
619
+ formatter: function (val) {
620
+ return ''
621
+ },
622
+ interval: 0
623
+ // rotate: 30
624
+ },
625
+ nameTextStyle: {
626
+ color: getTheme() === 'light' ? '#666666' : '#B9BABF'
627
+ },
628
+ min: -50,
629
+ max: this.getMaxX() + 50
630
+ }
631
+ ],
632
+ yAxis: [
633
+ {
634
+ type: 'value',
635
+ name: '时间(s)',
636
+ axisLine: {
637
+ show: true,
638
+ onZero: false
639
+ },
640
+ axisTick: {
641
+ show: false
642
+ },
643
+ splitLine: {
644
+ show: true,
645
+ lineStyle: {
646
+ color: getTheme() === 'light' ? '#DCDFE6' : '#30384d'
647
+ }
648
+ },
649
+ nameTextStyle: {
650
+ color: getTheme() === 'light' ? '#666666' : '#B9BABF'
651
+ },
652
+ axisLabel: {
653
+ textStyle: {
654
+ color: getTheme() === 'light' ? '#666666' : '#B9BABF'
655
+ }
656
+ },
657
+ min: 0,
658
+ max: this.getMaxY() * 3
659
+ // show: false
660
+ }
661
+ ],
662
+ series: this.getSeries()
663
+ }
664
+ }
665
+ }