【bug】车库门操作、状态发送等逻辑中的bug
This commit is contained in:
parent
01b0655eb5
commit
33ed496dcd
@ -82,6 +82,10 @@ func newRepository(id string, version string) *Repository {
|
|||||||
keyMap: make(map[string]*Key),
|
keyMap: make(map[string]*Key),
|
||||||
platformMap: make(map[string]*Platform),
|
platformMap: make(map[string]*Platform),
|
||||||
centralizedMap: make(map[string]*proto.CentralizedStationRef),
|
centralizedMap: make(map[string]*proto.CentralizedStationRef),
|
||||||
|
ckmMap: make(map[string]*Ckm),
|
||||||
|
ckmPslMap: make(map[string]*CkmPsl),
|
||||||
|
xcjMap: make(map[string]*Xcj),
|
||||||
|
|
||||||
PipeMap: make(map[string]*Pipe), //ISCS 管线
|
PipeMap: make(map[string]*Pipe), //ISCS 管线
|
||||||
PipeFittingMap: make(map[string]*PipeFitting), //ISCS 管件
|
PipeFittingMap: make(map[string]*PipeFitting), //ISCS 管件
|
||||||
CircuitBreakerMap: make(map[string]*CircuitBreaker), //ISCS 断路器
|
CircuitBreakerMap: make(map[string]*CircuitBreaker), //ISCS 断路器
|
||||||
|
@ -27,13 +27,13 @@ func (p *CkmSys) Update(world ecs.World) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
posCom := component.FixedPositionTransformType.Get(entry)
|
posCom := component.FixedPositionTransformType.Get(entry)
|
||||||
remote := true //是否远程模式
|
local := true //是否本地模式
|
||||||
circuit := component.CkmCircuitType.Get(entry) //目前不考虑没有车库门电路的情况
|
circuit := component.CkmCircuitType.Get(entry) //目前不考虑没有车库门电路的情况
|
||||||
//车库门PSL
|
//车库门PSL
|
||||||
if entry.HasComponent(component.CkmPslType) {
|
if entry.HasComponent(component.CkmPslType) {
|
||||||
ckmPsl := component.CkmPslType.Get(entry)
|
ckmPsl := component.CkmPslType.Get(entry)
|
||||||
component.RelayDriveType.Get(circuit.MPLJ).Td = component.BitStateType.Get(ckmPsl.MPLA).Val
|
component.RelayDriveType.Get(circuit.MPLJ).Td = component.BitStateType.Get(ckmPsl.MPLA).Val
|
||||||
remote = component.BitStateType.Get(ckmPsl.MMSA).Val
|
local = component.BitStateType.Get(ckmPsl.MMSA).Val
|
||||||
}
|
}
|
||||||
//门开/关继电器及状态
|
//门开/关继电器及状态
|
||||||
if posCom.Pos == consts.TwoPosMin {
|
if posCom.Pos == consts.TwoPosMin {
|
||||||
@ -46,7 +46,11 @@ func (p *CkmSys) Update(world ecs.World) {
|
|||||||
//门故障继电器及状态
|
//门故障继电器及状态
|
||||||
component.RelayDriveType.Get(circuit.MGZJ).Td = entry.HasComponent(component.CkmStateLossTag)
|
component.RelayDriveType.Get(circuit.MGZJ).Td = entry.HasComponent(component.CkmStateLossTag)
|
||||||
//开/关门继电器驱动状态
|
//开/关门继电器驱动状态
|
||||||
if remote {
|
if local {
|
||||||
|
ckmPsl := component.CkmPslType.Get(entry)
|
||||||
|
component.RelayDriveType.Get(circuit.KMJ).Td = component.BitStateType.Get(ckmPsl.KMA).Val
|
||||||
|
component.RelayDriveType.Get(circuit.GMJ).Td = component.BitStateType.Get(ckmPsl.GMA).Val
|
||||||
|
} else {
|
||||||
kmBit, err := worldData.QueryQdBit(component.UidType.Get(circuit.KMJ).Id)
|
kmBit, err := worldData.QueryQdBit(component.UidType.Get(circuit.KMJ).Id)
|
||||||
if err == nil {
|
if err == nil {
|
||||||
component.RelayDriveType.Get(circuit.KMJ).Td = kmBit
|
component.RelayDriveType.Get(circuit.KMJ).Td = kmBit
|
||||||
@ -59,10 +63,6 @@ func (p *CkmSys) Update(world ecs.World) {
|
|||||||
} else {
|
} else {
|
||||||
slog.Error(err.Error())
|
slog.Error(err.Error())
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
ckmPsl := component.CkmPslType.Get(entry)
|
|
||||||
component.RelayDriveType.Get(circuit.KMJ).Td = component.BitStateType.Get(ckmPsl.KMA).Val
|
|
||||||
component.RelayDriveType.Get(circuit.GMJ).Td = component.BitStateType.Get(ckmPsl.GMA).Val
|
|
||||||
}
|
}
|
||||||
//驱动
|
//驱动
|
||||||
if component.BitStateType.Get(circuit.GMJ).Val {
|
if component.BitStateType.Get(circuit.GMJ).Val {
|
||||||
|
Loading…
Reference in New Issue
Block a user