Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
T
traffic-signal-platform
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
signal
traffic-signal-platform
Commits
2d0df2e2
Commit
2d0df2e2
authored
Jan 31, 2024
by
duanruiming
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[update] 优化圆饼灯逻辑处理,圆饼灯123还是23
parent
2bdd1f16
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
19 additions
and
11 deletions
+19
-11
HisensePhaseCountDownTask.java
...net/wanji/utc/hisense/task/HisensePhaseCountDownTask.java
+1
-1
SignalStatus4StaticSchemeTask.java
...ava/net/wanji/utc/task/SignalStatus4StaticSchemeTask.java
+18
-10
No files found.
signal-utc-hisense-service/src/main/java/net/wanji/utc/hisense/task/HisensePhaseCountDownTask.java
View file @
2d0df2e2
...
...
@@ -316,7 +316,7 @@ public class HisensePhaseCountDownTask {
}
List
<
CrossLightsPO
>
value
=
entry
.
getValue
();
int
type
=
1
;
for
(
CrossLightsPO
crossLightsPO
:
value
)
{
for
(
CrossLightsPO
crossLightsPO
:
value
)
{
//todo 需要处理,路口方向级别,灯组圆饼灯要区分,有没有左转,crossd dir级别,有几个转向
Integer
turn
=
crossLightsPO
.
getTurn
();
type
=
crossLightsPO
.
getType
();
// 搭接相位跳过绿灯变红灯
...
...
signal-utc-service/src/main/java/net/wanji/utc/task/SignalStatus4StaticSchemeTask.java
View file @
2d0df2e2
...
...
@@ -5,10 +5,7 @@ import net.wanji.common.framework.Constants;
import
net.wanji.common.utils.tool.DateUtil
;
import
net.wanji.common.utils.tool.StringUtils
;
import
net.wanji.databus.dao.entity.*
;
import
net.wanji.databus.dao.mapper.CrossPhaseMapper
;
import
net.wanji.databus.dao.mapper.CrossSchedulesMapper
;
import
net.wanji.databus.dao.mapper.CrossSchemeMapper
;
import
net.wanji.databus.dao.mapper.CrossSectionMapper
;
import
net.wanji.databus.dao.mapper.*
;
import
net.wanji.databus.po.CrossInfoPO
;
import
net.wanji.databus.vo.LightsStatusVO
;
import
net.wanji.utc.cache.CrossInfoCache
;
...
...
@@ -47,6 +44,8 @@ public class SignalStatus4StaticSchemeTask {
private
CrossSchemeMapper
crossSchemeMapper
;
@Resource
private
CrossPhaseMapper
crossPhaseMapper
;
@Resource
private
CrossLightsMapper
crossLightsMapper
;
@Scheduled
(
fixedRate
=
1000
)
public
void
signalStatusCountDown
()
throws
Exception
{
...
...
@@ -513,7 +512,7 @@ public class SignalStatus4StaticSchemeTask {
}
List
<
CrossLightsPO
>
value
=
entry
.
getValue
();
int
type
=
1
;
for
(
CrossLightsPO
crossLightsPO
:
value
)
{
for
(
CrossLightsPO
crossLightsPO
:
value
)
{
//todo 需要处理,路口方向级别,灯组圆饼灯要区分,有没有左转,crossd dir级别,有几个转向
Integer
turn
=
crossLightsPO
.
getTurn
();
type
=
crossLightsPO
.
getType
();
// 搭接相位跳过绿灯变红灯
...
...
@@ -525,7 +524,7 @@ public class SignalStatus4StaticSchemeTask {
if
(
type
==
2
)
{
setAllTurnColor
(
turnColor
,
"red"
);
//红灯时,圆饼灯操作
}
//
turnColor.put(3, "green");
turnColor
.
put
(
3
,
"green"
);
dirLampGroupMap
.
put
(
dir
,
turnColor
);
}
}
...
...
@@ -538,8 +537,10 @@ public class SignalStatus4StaticSchemeTask {
Integer
yellowTime
=
phaseCountDownDTO
.
getYellowTime
();
Integer
redTime
=
phaseCountDownDTO
.
getRedTime
();
Map
<
Integer
,
List
<
CrossLightsPO
>>
dirTurnMap
=
phaseDirTurnPojo
.
getDirTurnMap
();
// 判断圆饼灯代表123,还是23
List
<
CrossLightsPO
>
crossLightsPOS
=
crossLightsMapper
.
selectByCrossId
(
crossId
);
if
(
Objects
.
nonNull
(
dirTurnMap
)
&&
!
dirTurnMap
.
isEmpty
())
{
setDirTurnColor
(
cyclePhaseCountDown
,
dirLampGroupMap
,
yellowTime
,
redTime
,
dirTurnMap
);
setDirTurnColor
(
cyclePhaseCountDown
,
dirLampGroupMap
,
yellowTime
,
redTime
,
dirTurnMap
,
crossLightsPOS
);
}
}
}
...
...
@@ -547,7 +548,8 @@ public class SignalStatus4StaticSchemeTask {
}
private
static
void
setDirTurnColor
(
Integer
cyclePhaseCountDown
,
Map
<
String
,
Object
>
dirLampGroupMap
,
Integer
yellowTime
,
Integer
redTime
,
Map
<
Integer
,
List
<
CrossLightsPO
>>
dirTurnMap
)
throws
Exception
{
Integer
yellowTime
,
Integer
redTime
,
Map
<
Integer
,
List
<
CrossLightsPO
>>
dirTurnMap
,
List
<
CrossLightsPO
>
crossLightsPOS
)
throws
Exception
{
for
(
Map
.
Entry
<
Integer
,
List
<
CrossLightsPO
>>
dirEntry
:
dirTurnMap
.
entrySet
())
{
String
dir
=
String
.
valueOf
(
dirEntry
.
getKey
());
List
<
CrossLightsPO
>
lightsList
=
dirEntry
.
getValue
();
...
...
@@ -568,8 +570,14 @@ public class SignalStatus4StaticSchemeTask {
color
=
setTurnColor
(
cyclePhaseCountDown
,
yellowTime
,
redTime
,
turnColor
,
color
,
turn
);
turnColor
.
put
(
turn
,
color
);
}
if
(
type
==
2
)
{
setAllTurnColor
(
turnColor
,
color
);
List
<
CrossLightsPO
>
dirAllLights
=
crossLightsPOS
.
stream
().
filter
(
po
->
Objects
.
equals
(
po
.
getDir
(),
dirEntry
.
getKey
())).
collect
(
Collectors
.
toList
());
if
(
type
==
2
)
{
// 方向是圆饼灯,并且只有一个灯组
if
(
dirAllLights
.
size
()
==
1
)
{
setAllTurnColor
(
turnColor
,
color
);
}
else
{
turnColor
.
put
(
2
,
"green"
);
turnColor
.
put
(
3
,
"green"
);
// 右转常绿
}
}
dirLampGroupMap
.
put
(
dir
,
turnColor
);
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment