openatc-components 0.4.62 → 0.4.64

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 (456) 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 +120 -120
  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 +133 -133
  23. package/package/kisscomps/components/ChannelRealtimeIntersection/ChannelRealtimeIntersection.vue +123 -123
  24. package/package/kisscomps/components/Channelization/Channelization.vue +585 -585
  25. package/package/kisscomps/components/ChannelizationFlowStatistic/ChannelizationFlowStatistic.vue +360 -360
  26. package/package/kisscomps/components/ChannelizationWithInterface/ChannelizationWithInterface.vue +518 -518
  27. package/package/kisscomps/components/CommonKanban/CommonKanban.vue +132 -132
  28. package/package/kisscomps/components/DirectionListConfiguration/DirectionListConfiguration.vue +456 -456
  29. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-east-bottom.vue +41 -41
  30. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-east-top.vue +60 -60
  31. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-ewped.vue +105 -105
  32. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-north-left.vue +60 -60
  33. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-north-right.vue +60 -60
  34. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-snped.vue +105 -105
  35. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-south-left.vue +60 -60
  36. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-south-right.vue +60 -60
  37. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-west-bottom.vue +60 -60
  38. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-west-top.vue +60 -60
  39. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-xlped.vue +30 -30
  40. package/package/kisscomps/components/DirectionListConfiguration/svg/ped-xrped.vue +30 -30
  41. package/package/kisscomps/components/DirectionListConfiguration/svg/pedSvg.vue +78 -78
  42. package/package/kisscomps/components/DrawChannelization/drawsvg/basicCoordInfo.vue +181 -181
  43. package/package/kisscomps/components/DrawChannelization/drawsvg/channelizationElements.vue +255 -255
  44. package/package/kisscomps/components/DrawChannelization/drawsvg/detectorAssociatedComponent.vue +152 -152
  45. package/package/kisscomps/components/DrawChannelization/drawsvg/drawElement/TextBox.vue +91 -91
  46. package/package/kisscomps/components/DrawChannelization/drawsvg/drawElement/crossMap.vue +194 -194
  47. package/package/kisscomps/components/DrawChannelization/drawsvg/drawElement/editText.vue +108 -108
  48. package/package/kisscomps/components/DrawChannelization/drawsvg/firstImportCrossmap.vue +51 -51
  49. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/countdownSvg.vue +236 -236
  50. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorChart.vue +247 -247
  51. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorIconSvg.vue +210 -210
  52. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/laneIcon.vue +72 -72
  53. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/motorwayIconSvg.vue +368 -368
  54. package/package/kisscomps/components/DrawChannelization/drawsvg/iconSvg/pedroadIconSvg.vue +230 -230
  55. package/package/kisscomps/components/DrawChannelization/drawsvg/importDialog.vue +74 -74
  56. package/package/kisscomps/components/DrawChannelization/drawsvg/index.draw.vue +1022 -1022
  57. package/package/kisscomps/components/DrawChannelization/drawsvg/index.vue +144 -144
  58. package/package/kisscomps/components/DrawChannelization/drawsvg/laneEditPanel.vue +707 -707
  59. package/package/kisscomps/components/DrawChannelization/drawsvg/overlapAssociatedComponent.vue +172 -172
  60. package/package/kisscomps/components/DrawChannelization/drawsvg/phaseAssociatedComponent.vue +172 -172
  61. package/package/kisscomps/components/DrawChannelization/drawsvg/table.vue +99 -99
  62. package/package/kisscomps/components/DrawChannelization/drawsvg/utils/loadutils.js +87 -87
  63. package/package/kisscomps/components/DrawChannelization/drawsvg/utils/phaseDataModel.js +32 -32
  64. package/package/kisscomps/components/DrawChannelization/drawsvg/utils/phasePos.json +20 -20
  65. package/package/kisscomps/components/DrawChannelization/phaseDataMgr.js +278 -278
  66. package/package/kisscomps/components/ExpendConfig/ExpendConfig.vue +118 -118
  67. package/package/kisscomps/components/FaultDetailModal/FaultDetailModal.vue +178 -178
  68. package/package/kisscomps/components/IntersectionDirectionSelection/IntersectionDirectionSelection.vue +162 -162
  69. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/CrossRoadsSvg.vue +629 -629
  70. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/CustomRoadsSvg.vue +46 -46
  71. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionEWSvg.vue +447 -447
  72. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionSNSvg.vue +341 -341
  73. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampEastSvg.vue +497 -497
  74. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampNorthSvg.vue +353 -353
  75. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampSouthSvg.vue +359 -359
  76. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampWestSvg.vue +443 -443
  77. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkClickSvg.vue +1302 -1302
  78. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkSvg.vue +1190 -1190
  79. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeEastRoadsSvg.vue +498 -498
  80. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeNorthRoadsSvg.vue +484 -484
  81. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeSouthRoadsSvg.vue +488 -488
  82. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeWestRoadsSvg.vue +566 -566
  83. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LCrossRoadsSvg.vue +640 -640
  84. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeEastRoadsSvg.vue +497 -497
  85. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeNorthRoadsSvg.vue +486 -486
  86. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeSouthRoadsSvg.vue +490 -490
  87. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeWestRoadsSvg.vue +575 -575
  88. package/package/kisscomps/components/IntersectionMap/crossDirection/baseImg/refreshSvg.vue +63 -63
  89. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/busMapSvg.vue +50 -50
  90. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/eastBusSvg.vue +167 -167
  91. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/northBusSvg.vue +168 -168
  92. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/southBusSvg.vue +168 -168
  93. package/package/kisscomps/components/IntersectionMap/crossDirection/busIcon/westBusSvg.vue +169 -169
  94. package/package/kisscomps/components/IntersectionMap/crossDirection/crossDiagram.vue +1598 -1598
  95. package/package/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/LphaseIconSvg.vue +197 -197
  96. package/package/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/phaseIconSvg.vue +200 -196
  97. package/package/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/rampPhaseIconSvg.vue +122 -122
  98. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.json +196 -196
  99. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.left.json +196 -196
  100. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/effectPos.json +115 -115
  101. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.json +115 -115
  102. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.left.json +115 -115
  103. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/rampPos.json +52 -52
  104. package/package/kisscomps/components/IntersectionMap/crossDirection/posJson/sidePos.json +219 -219
  105. package/package/kisscomps/components/IntersectionMap/crossDirection/utils.js +91 -91
  106. package/package/kisscomps/components/IntersectionMap/intersectionmap.vue +220 -220
  107. package/package/kisscomps/components/IntersectionMapDirSelect/customCrossDiagram.vue +702 -0
  108. package/package/kisscomps/components/IntersectionMapDirSelect/customintersectionmap.vue +188 -0
  109. package/package/kisscomps/components/IntersectionMapDirSelect/index.js +2 -0
  110. package/package/kisscomps/components/IntersectionWithInterface/IntersectionWithInterface.vue +534 -534
  111. package/package/kisscomps/components/KanBan/kanban.vue +231 -231
  112. package/package/kisscomps/components/MessageBox/index.vue +96 -96
  113. package/package/kisscomps/components/OverLap/OverLap.vue +237 -237
  114. package/package/kisscomps/components/OverviewComponent/index.vue +853 -853
  115. package/package/kisscomps/components/PatternOptimize/PatternOptimize.vue +329 -329
  116. package/package/kisscomps/components/PatternStatus/PatternStatus.vue +1843 -1843
  117. package/package/kisscomps/components/PatternWalkSvg/PatternWalkSvg.vue +423 -423
  118. package/package/kisscomps/components/PhaseDirectionSelect/PhaseDirectionSelect.vue +126 -126
  119. package/package/kisscomps/components/PhaseDirectionText/PhaseDirectionText.vue +106 -106
  120. package/package/kisscomps/components/PhaseLegend/PhaseLegend.vue +286 -286
  121. package/package/kisscomps/components/PhaseMarker/index.js +6 -6
  122. package/package/kisscomps/components/PhaseMarker/phasemarker.vue +215 -215
  123. package/package/kisscomps/components/PhaseMarker/svg/patternSvg.vue +121 -121
  124. package/package/kisscomps/components/PhaseMarker/svg/phase.vue +60 -60
  125. package/package/kisscomps/components/PhaseMarker/svg/phaseCount.vue +62 -62
  126. package/package/kisscomps/components/PhaseMarker/svg/phaseCountCycle.vue +62 -62
  127. package/package/kisscomps/components/PhaseMarker/svg/phaseSvg.vue +117 -117
  128. package/package/kisscomps/components/PhasePedSelect/index.vue +206 -206
  129. package/package/kisscomps/components/SchemeConfig/SchemeConfig.vue +1027 -1027
  130. package/package/kisscomps/components/SchemeConfig/azimuthlocking/index.vue +365 -365
  131. package/package/kisscomps/components/SchemeConfig/azimuthlocking/utils.js +92 -92
  132. package/package/kisscomps/components/SchemeConfig/closePhaselControlModal/index.vue +214 -214
  133. package/package/kisscomps/components/SchemeConfig/lockingPhaselControlModal/index.vue +235 -235
  134. package/package/kisscomps/components/SchemeConfig/manualControlModal/index.vue +235 -235
  135. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/controlModelGroup.vue +131 -131
  136. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/icon.vue +470 -470
  137. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/index.vue +871 -871
  138. package/package/kisscomps/components/SchemeConfig/manualControlModalNew/othersIcon.vue +151 -151
  139. package/package/kisscomps/components/SchemeConfig/priorityControl/index.vue +215 -215
  140. package/package/kisscomps/components/SchemeConfig/priorityControl/utils.js +163 -163
  141. package/package/kisscomps/components/SchemeConfig/realtimeStatusModal/index.vue +308 -308
  142. package/package/kisscomps/components/SchemeConfig/tentativeplancontrolmodal/index.vue +1293 -1293
  143. package/package/kisscomps/components/SchemeConfig/utils/thirdPartypermission.js +95 -95
  144. package/package/kisscomps/components/SelectCrossPhase/index.vue +418 -418
  145. package/package/kisscomps/components/SelectCrossPhase/utils.js +142 -142
  146. package/package/kisscomps/components/StageBord/StageBord.vue +303 -303
  147. package/package/kisscomps/components/StageOptimize/StageOptimize.vue +367 -367
  148. package/package/kisscomps/components/StageOptimize/index.js +2 -2
  149. package/package/kisscomps/components/StageOptimize/index.vue +310 -0
  150. package/package/kisscomps/components/StageStatus/StageStatus.vue +341 -341
  151. package/package/kisscomps/components/Stages/index.vue +307 -307
  152. package/package/kisscomps/components/SvgIcon/SvgIcon.vue +53 -53
  153. package/package/kisscomps/components/XRDDirSelector/XRDDirSelector.vue +1041 -1041
  154. package/package/kisscomps/components/XiaoKanban/DirSelector.vue +356 -356
  155. package/package/kisscomps/components/XiaoKanban/index.vue +122 -122
  156. package/package/kisscomps/components/overView/index.vue +676 -676
  157. package/package/kisscomps/components/patternConfig/index.vue +802 -802
  158. package/package/kisscomps/components/patternConfig/pattern/patternTable.vue +599 -599
  159. package/package/kisscomps/components/patternConfig/pattern/planChart/model/coordinationModel.js +665 -665
  160. package/package/kisscomps/components/patternConfig/planContent.vue +604 -604
  161. package/package/kisscomps/components/patternConfig/planMenu.vue +329 -329
  162. package/package/kisscomps/components/patternConfig/utils.js +152 -152
  163. package/package/kisscomps/components/patternList/patternList.vue +606 -606
  164. package/package/kisscomps/index.js +133 -131
  165. package/package/kissui.min.js +1 -1
  166. package/package/static/img/CrossRoadsSvg.66a6236.svg +529 -0
  167. package/package.json +126 -126
  168. package/src/App.vue +24 -24
  169. package/src/EdgeMgr/EdgeModelBase.js +16 -16
  170. package/src/EdgeMgr/controller/crossDiagramMgr.js +125 -125
  171. package/src/api/authapi.js +31 -31
  172. package/src/api/config.js +21 -21
  173. package/src/api/control.js +110 -110
  174. package/src/api/cross.js +62 -62
  175. package/src/api/device.js +135 -135
  176. package/src/api/fault.js +66 -66
  177. package/src/api/index.js +24 -24
  178. package/src/api/login.js +46 -46
  179. package/src/api/optimize.js +72 -72
  180. package/src/api/param.js +165 -165
  181. package/src/api/passwdAssest.js +101 -101
  182. package/src/api/permission.js +33 -33
  183. package/src/api/route.js +171 -171
  184. package/src/api/template.js +27 -27
  185. package/src/assets/font/LICENSE.txt +202 -202
  186. package/src/assets/font/font.css +6 -6
  187. package/src/i18n/index.js +26 -26
  188. package/src/i18n/language/en.js +1493 -1493
  189. package/src/i18n/language/index.js +25 -25
  190. package/src/i18n/language/zh.js +1493 -1493
  191. package/src/icons/demo_index.html +8445 -8445
  192. package/src/icons/iconfont.css +1451 -1451
  193. package/src/icons/iconfont.json +2522 -2522
  194. package/src/icons/index.js +20 -20
  195. package/src/icons/svg/azimuthlocking.svg +26 -26
  196. package/src/icons/svg/bendi.svg +110 -110
  197. package/src/icons/svg/bujin.svg +36 -36
  198. package/src/icons/svg/connectBlue.svg +7 -7
  199. package/src/icons/svg/currentvolume.svg +0 -0
  200. package/src/icons/svg/custom-BRTlane.svg +40 -40
  201. package/src/icons/svg/custom-buslane.svg +40 -40
  202. package/src/icons/svg/custom-detector.svg +12 -12
  203. package/src/icons/svg/custom-east-bottom.svg +32 -32
  204. package/src/icons/svg/custom-east-top.svg +32 -32
  205. package/src/icons/svg/custom-ewped.svg +35 -35
  206. package/src/icons/svg/custom-nonmotorizedlane.svg +40 -40
  207. package/src/icons/svg/custom-north-left.svg +32 -32
  208. package/src/icons/svg/custom-north-right.svg +32 -32
  209. package/src/icons/svg/custom-peddetector.svg +17 -17
  210. package/src/icons/svg/custom-snped.svg +35 -35
  211. package/src/icons/svg/custom-south-left.svg +32 -32
  212. package/src/icons/svg/custom-south-right.svg +32 -32
  213. package/src/icons/svg/custom-tramlane.svg +40 -40
  214. package/src/icons/svg/custom-vehiclebranch.svg +40 -40
  215. package/src/icons/svg/custom-vehiclemainroad.svg +41 -41
  216. package/src/icons/svg/custom-west-bottom.svg +32 -32
  217. package/src/icons/svg/custom-west-top.svg +32 -32
  218. package/src/icons/svg/custom-xlped.svg +14 -14
  219. package/src/icons/svg/custom-xrped.svg +14 -14
  220. package/src/icons/svg/cutRed.svg +7 -7
  221. package/src/icons/svg/cycle.svg +0 -0
  222. package/src/icons/svg/dingzhouqi.svg +34 -34
  223. package/src/icons/svg/ganyingkongzhi.svg +30 -30
  224. package/src/icons/svg/guandeng.svg +81 -81
  225. package/src/icons/svg/huangshan.svg +71 -71
  226. package/src/icons/svg/maincontrol.svg +0 -0
  227. package/src/icons/svg/manualcontrolbackground.svg +51 -51
  228. package/src/icons/svg/manualcontrolbackground1.svg +62 -62
  229. package/src/icons/svg/manualcontrolbackgrounden.svg +62 -62
  230. package/src/icons/svg/model.svg +0 -0
  231. package/src/icons/svg/phasediff.svg +0 -0
  232. package/src/icons/svg/prioritycontrol.svg +21 -21
  233. package/src/icons/svg/quanhong.svg +86 -86
  234. package/src/icons/svg/shanghe.svg +11 -11
  235. package/src/icons/svg/shoudong.svg +103 -103
  236. package/src/icons/svg/tentativeplan.svg +28 -28
  237. package/src/icons/svg/time.svg +0 -0
  238. package/src/icons/svg/wuxianlan.svg +46 -46
  239. package/src/icons/svg/xiala.svg +11 -11
  240. package/src/icons/svg/xingrenguojie.svg +33 -33
  241. package/src/icons/svg/xitong.svg +89 -89
  242. package/src/icons/svg/youxian.svg +41 -41
  243. package/src/icons/svg/zizhukongzhi.svg +43 -43
  244. package/src/kisscomps/components/BoardCard/BoardCard.vue +133 -133
  245. package/src/kisscomps/components/ChannelRealtimeIntersection/ChannelRealtimeIntersection.vue +123 -123
  246. package/src/kisscomps/components/Channelization/Channelization.vue +585 -585
  247. package/src/kisscomps/components/ChannelizationFlowStatistic/ChannelizationFlowStatistic.vue +360 -360
  248. package/src/kisscomps/components/ChannelizationWithInterface/ChannelizationWithInterface.vue +518 -518
  249. package/src/kisscomps/components/CommonKanban/CommonKanban.vue +132 -132
  250. package/src/kisscomps/components/DirectionListConfiguration/DirectionListConfiguration.vue +456 -456
  251. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-east-bottom.vue +41 -41
  252. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-east-top.vue +60 -60
  253. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-ewped.vue +105 -105
  254. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-north-left.vue +60 -60
  255. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-north-right.vue +60 -60
  256. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-snped.vue +105 -105
  257. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-south-left.vue +60 -60
  258. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-south-right.vue +60 -60
  259. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-west-bottom.vue +60 -60
  260. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-west-top.vue +60 -60
  261. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-xlped.vue +30 -30
  262. package/src/kisscomps/components/DirectionListConfiguration/svg/ped-xrped.vue +30 -30
  263. package/src/kisscomps/components/DirectionListConfiguration/svg/pedSvg.vue +78 -78
  264. package/src/kisscomps/components/DrawChannelization/drawsvg/basicCoordInfo.vue +181 -181
  265. package/src/kisscomps/components/DrawChannelization/drawsvg/channelizationElements.vue +255 -255
  266. package/src/kisscomps/components/DrawChannelization/drawsvg/detectorAssociatedComponent.vue +152 -152
  267. package/src/kisscomps/components/DrawChannelization/drawsvg/drawElement/TextBox.vue +91 -91
  268. package/src/kisscomps/components/DrawChannelization/drawsvg/drawElement/crossMap.vue +194 -194
  269. package/src/kisscomps/components/DrawChannelization/drawsvg/drawElement/editText.vue +108 -108
  270. package/src/kisscomps/components/DrawChannelization/drawsvg/firstImportCrossmap.vue +51 -51
  271. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/countdownSvg.vue +236 -236
  272. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorChart.vue +247 -247
  273. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/detectorIconSvg.vue +210 -210
  274. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/laneIcon.vue +72 -72
  275. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/motorwayIconSvg.vue +368 -368
  276. package/src/kisscomps/components/DrawChannelization/drawsvg/iconSvg/pedroadIconSvg.vue +230 -230
  277. package/src/kisscomps/components/DrawChannelization/drawsvg/importDialog.vue +74 -74
  278. package/src/kisscomps/components/DrawChannelization/drawsvg/index.draw.vue +1022 -1022
  279. package/src/kisscomps/components/DrawChannelization/drawsvg/index.vue +144 -144
  280. package/src/kisscomps/components/DrawChannelization/drawsvg/laneEditPanel.vue +707 -707
  281. package/src/kisscomps/components/DrawChannelization/drawsvg/overlapAssociatedComponent.vue +172 -172
  282. package/src/kisscomps/components/DrawChannelization/drawsvg/phaseAssociatedComponent.vue +172 -172
  283. package/src/kisscomps/components/DrawChannelization/drawsvg/table.vue +99 -99
  284. package/src/kisscomps/components/DrawChannelization/drawsvg/utils/loadutils.js +87 -87
  285. package/src/kisscomps/components/DrawChannelization/drawsvg/utils/phaseDataModel.js +32 -32
  286. package/src/kisscomps/components/DrawChannelization/drawsvg/utils/phasePos.json +20 -20
  287. package/src/kisscomps/components/DrawChannelization/phaseDataMgr.js +278 -278
  288. package/src/kisscomps/components/ExpendConfig/ExpendConfig.vue +118 -118
  289. package/src/kisscomps/components/FaultDetailModal/FaultDetailModal.vue +178 -178
  290. package/src/kisscomps/components/IntersectionDirectionSelection/IntersectionDirectionSelection.vue +162 -162
  291. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/CrossRoadsSvg.vue +629 -629
  292. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/CustomRoadsSvg.vue +46 -46
  293. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionEWSvg.vue +447 -447
  294. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/PedSectionSNSvg.vue +341 -341
  295. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampEastSvg.vue +497 -497
  296. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampNorthSvg.vue +353 -353
  297. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampSouthSvg.vue +359 -359
  298. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/RampWestSvg.vue +443 -443
  299. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkClickSvg.vue +1302 -1302
  300. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/SidewalkSvg.vue +1190 -1190
  301. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeEastRoadsSvg.vue +498 -498
  302. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeNorthRoadsSvg.vue +484 -484
  303. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeSouthRoadsSvg.vue +488 -488
  304. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/TShapeWestRoadsSvg.vue +566 -566
  305. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LCrossRoadsSvg.vue +640 -640
  306. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeEastRoadsSvg.vue +497 -497
  307. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeNorthRoadsSvg.vue +486 -486
  308. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeSouthRoadsSvg.vue +490 -490
  309. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/leftroad/LTShapeWestRoadsSvg.vue +575 -575
  310. package/src/kisscomps/components/IntersectionMap/crossDirection/baseImg/refreshSvg.vue +63 -63
  311. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/busMapSvg.vue +50 -50
  312. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/eastBusSvg.vue +167 -167
  313. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/northBusSvg.vue +168 -168
  314. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/southBusSvg.vue +168 -168
  315. package/src/kisscomps/components/IntersectionMap/crossDirection/busIcon/westBusSvg.vue +169 -169
  316. package/src/kisscomps/components/IntersectionMap/crossDirection/crossDiagram.vue +1598 -1598
  317. package/src/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/LphaseIconSvg.vue +197 -197
  318. package/src/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/phaseIconSvg.vue +200 -196
  319. package/src/kisscomps/components/IntersectionMap/crossDirection/phaseIcon/rampPhaseIconSvg.vue +122 -122
  320. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.json +196 -196
  321. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/busPos.left.json +196 -196
  322. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/effectPos.json +115 -115
  323. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.json +115 -115
  324. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/phasePos.left.json +115 -115
  325. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/rampPos.json +52 -52
  326. package/src/kisscomps/components/IntersectionMap/crossDirection/posJson/sidePos.json +219 -219
  327. package/src/kisscomps/components/IntersectionMap/crossDirection/utils.js +91 -91
  328. package/src/kisscomps/components/IntersectionMap/intersectionmap.vue +220 -220
  329. package/src/kisscomps/components/IntersectionMapDirSelect/customCrossDiagram.vue +702 -0
  330. package/src/kisscomps/components/IntersectionMapDirSelect/customintersectionmap.vue +188 -0
  331. package/src/kisscomps/components/IntersectionMapDirSelect/index.js +2 -0
  332. package/src/kisscomps/components/IntersectionWithInterface/IntersectionWithInterface.vue +534 -534
  333. package/src/kisscomps/components/KanBan/kanban.vue +231 -231
  334. package/src/kisscomps/components/MessageBox/index.vue +96 -96
  335. package/src/kisscomps/components/OverLap/OverLap.vue +237 -237
  336. package/src/kisscomps/components/OverviewComponent/index.vue +853 -853
  337. package/src/kisscomps/components/PatternOptimize/PatternOptimize.vue +329 -329
  338. package/src/kisscomps/components/PatternStatus/PatternStatus.vue +1843 -1843
  339. package/src/kisscomps/components/PatternWalkSvg/PatternWalkSvg.vue +423 -423
  340. package/src/kisscomps/components/PhaseDirectionSelect/PhaseDirectionSelect.vue +126 -126
  341. package/src/kisscomps/components/PhaseDirectionText/PhaseDirectionText.vue +106 -106
  342. package/src/kisscomps/components/PhaseLegend/PhaseLegend.vue +286 -286
  343. package/src/kisscomps/components/PhaseMarker/index.js +6 -6
  344. package/src/kisscomps/components/PhaseMarker/phasemarker.vue +215 -215
  345. package/src/kisscomps/components/PhaseMarker/svg/patternSvg.vue +121 -121
  346. package/src/kisscomps/components/PhaseMarker/svg/phase.vue +60 -60
  347. package/src/kisscomps/components/PhaseMarker/svg/phaseCount.vue +62 -62
  348. package/src/kisscomps/components/PhaseMarker/svg/phaseCountCycle.vue +62 -62
  349. package/src/kisscomps/components/PhaseMarker/svg/phaseSvg.vue +117 -117
  350. package/src/kisscomps/components/PhasePedSelect/index.vue +206 -206
  351. package/src/kisscomps/components/SchemeConfig/SchemeConfig.vue +1027 -1027
  352. package/src/kisscomps/components/SchemeConfig/azimuthlocking/index.vue +365 -365
  353. package/src/kisscomps/components/SchemeConfig/azimuthlocking/utils.js +92 -92
  354. package/src/kisscomps/components/SchemeConfig/closePhaselControlModal/index.vue +214 -214
  355. package/src/kisscomps/components/SchemeConfig/lockingPhaselControlModal/index.vue +235 -235
  356. package/src/kisscomps/components/SchemeConfig/manualControlModal/index.vue +235 -235
  357. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/controlModelGroup.vue +131 -131
  358. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/icon.vue +470 -470
  359. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/index.vue +871 -871
  360. package/src/kisscomps/components/SchemeConfig/manualControlModalNew/othersIcon.vue +151 -151
  361. package/src/kisscomps/components/SchemeConfig/priorityControl/index.vue +215 -215
  362. package/src/kisscomps/components/SchemeConfig/priorityControl/utils.js +163 -163
  363. package/src/kisscomps/components/SchemeConfig/realtimeStatusModal/index.vue +308 -308
  364. package/src/kisscomps/components/SchemeConfig/tentativeplancontrolmodal/index.vue +1293 -1293
  365. package/src/kisscomps/components/SchemeConfig/utils/thirdPartypermission.js +95 -95
  366. package/src/kisscomps/components/SelectCrossPhase/index.vue +418 -418
  367. package/src/kisscomps/components/SelectCrossPhase/utils.js +142 -142
  368. package/src/kisscomps/components/StageBord/StageBord.vue +303 -303
  369. package/src/kisscomps/components/StageOptimize/StageOptimize.vue +367 -367
  370. package/src/kisscomps/components/StageOptimize/index.js +2 -2
  371. package/src/kisscomps/components/StageStatus/StageStatus.vue +341 -341
  372. package/src/kisscomps/components/Stages/index.vue +307 -307
  373. package/src/kisscomps/components/SvgIcon/SvgIcon.vue +53 -53
  374. package/src/kisscomps/components/XRDDirSelector/XRDDirSelector.vue +1041 -1041
  375. package/src/kisscomps/components/XiaoKanban/DirSelector.vue +356 -356
  376. package/src/kisscomps/components/XiaoKanban/index.vue +122 -122
  377. package/src/kisscomps/components/overView/index.vue +676 -676
  378. package/src/kisscomps/components/patternConfig/index.vue +802 -802
  379. package/src/kisscomps/components/patternConfig/pattern/patternTable.vue +599 -599
  380. package/src/kisscomps/components/patternConfig/pattern/planChart/model/coordinationModel.js +665 -665
  381. package/src/kisscomps/components/patternConfig/planContent.vue +604 -604
  382. package/src/kisscomps/components/patternConfig/planMenu.vue +329 -329
  383. package/src/kisscomps/components/patternConfig/utils.js +152 -152
  384. package/src/kisscomps/components/patternList/patternList.vue +606 -606
  385. package/src/kisscomps/index.js +133 -131
  386. package/src/lib/publicjs/ArryListUtil.js +38 -38
  387. package/src/lib/publicjs/HttpurlMgr.js +45 -45
  388. package/src/lib/publicjs/KissApi.js +158 -158
  389. package/src/lib/publicjs/KissWSSub/Heartcheck.js +128 -128
  390. package/src/lib/publicjs/KissWSSub/KissWsSub.js +91 -91
  391. package/src/lib/publicjs/KissWSSub/KissWsSubByType.js +152 -152
  392. package/src/lib/publicjs/KissWSSub/SimuWsSubByType.js +44 -44
  393. package/src/lib/publicjs/KissWSSub/Sub.js +51 -51
  394. package/src/lib/publicjs/KissWSSub/SubChannel.js +119 -119
  395. package/src/lib/publicjs/basecomponents.js +65 -65
  396. package/src/lib/publicjs/localStorage.js +112 -112
  397. package/src/lib/publicjs/objdeepcopy.js +32 -32
  398. package/src/lib/publicjs/pageScroll.js +30 -30
  399. package/src/lib/publicjs/passwdAssest.js +101 -101
  400. package/src/lib/publicjs/styleclassfactory.js +32 -32
  401. package/src/main.js +51 -51
  402. package/src/router/index.js +63 -63
  403. package/src/store/index.js +26 -26
  404. package/src/store/modules/globalParam.js +67 -67
  405. package/src/utils/ControlFormat.js +68 -68
  406. package/src/utils/RingDataModel.js +335 -335
  407. package/src/utils/auth.js +199 -199
  408. package/src/utils/conflct.js +268 -268
  409. package/src/utils/conflictList.js +87 -87
  410. package/src/utils/dateFormat.js +41 -41
  411. package/src/utils/fault.js +196 -196
  412. package/src/utils/faultcode.js +225 -225
  413. package/src/utils/index.js +69 -69
  414. package/src/utils/pedphasedesc.js +119 -119
  415. package/src/utils/phaseList.js +203 -203
  416. package/src/utils/phasedesc.js +144 -144
  417. package/src/utils/responseMessage.js +21 -21
  418. package/src/utils/validate.js +43 -43
  419. package/src/views/customchannelization.vue +49 -49
  420. package/src/views/home.1.vue +479 -479
  421. package/src/views/home.vue +93 -93
  422. package/src/views/intersection.vue +547 -527
  423. package/src/views/intersection2.vue +328 -328
  424. package/src/views/overView.vue +63 -63
  425. package/src/views/patternConfig.vue +14792 -14792
  426. package/src/views/schemeconfig.vue +205 -205
  427. package/static/apiconfig.json +471 -471
  428. package/static/img/CrossRoadsSvg.svg +529 -0
  429. package/static/styles/channelizatioon.scss +433 -433
  430. package/static/styles/common.scss +30 -30
  431. package/static/styles/commonkanban.scss +168 -168
  432. package/static/styles/dark/index.scss +2 -2
  433. package/static/styles/dark/theme/element-dark.scss +44 -44
  434. package/static/styles/index.scss +84 -84
  435. package/static/styles/intersection.scss +180 -180
  436. package/static/styles/light/index.scss +2 -2
  437. package/static/styles/light/theme/element-light.scss +44 -44
  438. package/static/styles/overview.scss +146 -146
  439. package/static/styles/patternConfig.scss +56 -56
  440. package/static/styles/phasePedSelect.scss +71 -71
  441. package/static/styles/schemeconfig.scss +558 -558
  442. package/static/styles/stages.scss +57 -57
  443. package/static/styles/uiComponents.scss +57 -57
  444. package/static/styles/xiaokanban.scss +61 -61
  445. package/static/token.json +2 -2
  446. package/test/e2e/custom-assertions/elementCount.js +27 -27
  447. package/test/e2e/nightwatch.conf.js +46 -46
  448. package/test/e2e/runner.js +48 -48
  449. package/test/e2e/specs/test.js +19 -19
  450. package/test/unit/.eslintrc +7 -7
  451. package/test/unit/jest.conf.js +30 -30
  452. package/test/unit/setup.js +3 -3
  453. package/test/unit/specs/HelloWorld.spec.js +11 -11
  454. package/package/kissui.js +0 -216608
  455. package/pnpm-lock.yaml +0 -16362
  456. package/src/utils/errorcode.js +0 -231
@@ -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
+ }