57 lines
1.2 KiB
Go
57 lines
1.2 KiB
Go
package message
|
||
|
||
import (
|
||
"encoding/binary"
|
||
"math"
|
||
)
|
||
|
||
// 速度转转速计算公式:
|
||
// 转速=车速 ÷ 车轮周长
|
||
// 车的轮径为d,车速为v1,电机转速为v2
|
||
// 公式为:V2=V1÷(πd)×60
|
||
type ElectricMachinery struct {
|
||
Speed float32 // 车速,m/s
|
||
WheelDiameter int32 // 轮径,mm
|
||
IsBack bool // 是否倒车
|
||
}
|
||
|
||
func (t *ElectricMachinery) Encode() []byte {
|
||
b := []byte{0x01, 0x10, 0x60, 0xff, 0x00, 0x02, 0x04}
|
||
rotarySpeed := t.Speed * 60 / (float32(math.Pi) * float32(t.WheelDiameter) / 1000)
|
||
if t.IsBack {
|
||
b = binary.BigEndian.AppendUint32(b, uint32(0-rotarySpeed))
|
||
} else {
|
||
b = binary.BigEndian.AppendUint32(b, uint32(rotarySpeed))
|
||
}
|
||
crc := chkcrc(b) // crc校验码
|
||
b = binary.BigEndian.AppendUint16(b, crc)
|
||
return b
|
||
}
|
||
|
||
// 生成crc
|
||
func chkcrc(data []byte) uint16 {
|
||
var crc uint16 = 0xFFFF
|
||
for i := 0; i < len(data); i++ {
|
||
crc = calccrc(data[i], crc)
|
||
}
|
||
hi := crc % 256
|
||
lo := crc / 256
|
||
crc = (hi << 8) | lo
|
||
return crc
|
||
}
|
||
|
||
// 计算crc
|
||
func calccrc(crcbuf byte, crc uint16) uint16 {
|
||
crc = crc ^ uint16(crcbuf)
|
||
for i := 0; i < 8; i++ {
|
||
chk := crc & 1
|
||
crc = crc >> 1
|
||
crc = crc & 0x7fff
|
||
if chk == 1 {
|
||
crc = crc ^ 0xa001
|
||
}
|
||
crc = crc & 0xffff
|
||
}
|
||
return crc
|
||
}
|