数据 输入输出 处理
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

156 lines
4.3 KiB

package adaptors
import (
"encoding/hex"
"encoding/json"
"goInOut/models"
"log"
"math"
"time"
)
// Adaptor_TYCJ_XTJC 统一采集软件数据 转换 湘潭健康监测平台
type Adaptor_TYCJ_XTJC struct {
IdMap map[string]int16
}
func (the Adaptor_TYCJ_XTJC) Transform(rawMsg string) [][]byte {
tycj := models.TYCJ{}
json.Unmarshal([]byte(rawMsg), &tycj)
return the.TYCJtoXTJC(tycj)
}
func (the Adaptor_TYCJ_XTJC) TYCJtoXTJC(tycj models.TYCJ) (result [][]byte) {
Atime, err := time.Parse("2006-01-02T15:04:05.000", tycj.SensorData.Time)
if err != nil {
log.Printf("统一采集 设备[%s] 数据时间 %s 解析错误", tycj.SensorData.Name, tycj.SensorData.Time)
return
}
var sensorDataList []float32
switch tycj.SensorData.FactorType {
case models.TYCJ_FactorType_QLSSF: //桥梁伸缩缝监测22
sensorDataList = append(sensorDataList, tycj.SensorData.Data.ThemeValues[0])
case models.TYCJ_FactorType_YLYB, models.TYCJ_FactorType_DTQYB: //应变23,挡土墙应变13
sensorDataList = append(sensorDataList, tycj.SensorData.Data.ThemeValues[0])
case models.TYCJ_FactorType_RD: //扰度31
sensorDataList = append(sensorDataList, tycj.SensorData.Data.ThemeValues[0])
case models.TYCJ_FactorType_QDQX: //桥墩倾斜20 X (mm) Y (mm) Z (mm) 温度(℃) 20240315对方要求每个监测项 分开上报
sensorDataList = append(sensorDataList, tycj.SensorData.Data.ThemeValues[0])
sensorDataList = append(sensorDataList, tycj.SensorData.Data.ThemeValues[1])
case models.TYCJ_FactorType_LF: //裂缝28
sensorDataList = append(sensorDataList, tycj.SensorData.Data.ThemeValues[0])
default:
log.Printf("监测因素[%d] 无匹配", tycj.SensorData.FactorType)
return
}
for i, sensorData := range sensorDataList {
var transBytes []byte
//1.添加通用报文头段
commPayloadHeader := the.getPayloadHeader(int16(1)) //20240315 客户确认 如双轴倾角 改成2条上报
transBytes = append(transBytes, commPayloadHeader...)
//2.添加时间段
transBytes = append(transBytes, the.getTimeBytes(Atime)...)
//3.添加对象码段
sensorCode := the.getSensorId(tycj.SensorData.Name)
if i == 1 {
//2项数据的目前只有倾斜 2桥 =》 Y轴id=X轴id+39 1桥=》Y轴id=X轴id+10000
sensorCode = sensorCode + 39
}
//
if sensorCode != 0 {
transBytes = append(transBytes, the.getCodeBytes(sensorCode)...)
} else {
log.Printf("统一采集 设备[%s] 无匹配的湘潭监测id,请检查配置文件", tycj.SensorData.Name)
return
}
d := []float32{sensorData}
//4.添加数据值段
transBytes = append(transBytes, the.getDatasBytes(d)...)
log.Printf("TYCJ [f=%d]-[%s]-[%d]-[%d]报文=%s", tycj.SensorData.FactorType, tycj.SensorData.Name, i,
the.getSensorId(tycj.SensorData.Name),
hex.EncodeToString(transBytes))
result = append(result, transBytes)
}
return result
}
func (the Adaptor_TYCJ_XTJC) getSensorId(rawSensorName string) int16 {
v, isValid := the.IdMap[rawSensorName]
if !isValid {
v = 0
}
return v
}
func (the Adaptor_TYCJ_XTJC) getCodeBytes(sensorCode int16) []byte {
bytes := make([]byte, 0)
bytes = append(bytes,
byte(sensorCode&0xFF),
byte(sensorCode>>8),
)
return bytes
}
func (the Adaptor_TYCJ_XTJC) getTimeBytes(sensorTime time.Time) []byte {
year := int8(sensorTime.Year() - 1900)
month := int8(sensorTime.Month())
day := int8(sensorTime.Day())
hour := int8(sensorTime.Hour())
minute := int8(sensorTime.Minute())
millisecond := uint16(sensorTime.Second()*1000 + sensorTime.Nanosecond()/1e6)
bytes := make([]byte, 0)
bytes = append(bytes,
byte(year),
byte(month),
byte(day),
byte(hour),
byte(minute),
byte(millisecond&0xFF),
byte(millisecond>>8),
)
return bytes
}
func (the Adaptor_TYCJ_XTJC) getDatasBytes(datas []float32) []byte {
bytes := make([]byte, 0)
for _, data := range datas {
bits := math.Float32bits(data)
bytes = append(bytes,
byte(bits&0xFF),
byte(bits>>8&0xFF),
byte(bits>>16&0xFF),
byte(bits>>24&0xFF),
)
}
return bytes
}
func (the Adaptor_TYCJ_XTJC) getPayloadHeader(floatCount int16) []byte {
bytes := make([]byte, 0)
bytes = append(bytes,
//报文类型
0x02,
0x00,
//1:上行信息
0x01,
//默认,通讯计算机编号
0x00,
//命令码
0x01,
//报文长度
byte((floatCount*4+9)&0xFF),
byte((floatCount*4+9)>>8),
)
return bytes
}