@signalk/nmea0183-signalk
Version:
A node.js/javascript parser for NMEA0183 sentences. Sentences are parsed to Signal K format.
102 lines (93 loc) • 2.94 kB
JavaScript
'use strict'
/**
* Copyright 2016 Signal K <info@signalk.org> and contributors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
const debug = require('debug')('signalk-parser-nmea0183/HDG')
const utils = require('@signalk/nmea0183-utilities')
/*
******* 0 1 2 3 4
******* | | | | |
$--HDG,x.x,x.x,a,x.x,a*hh<CR><LF>
Field Number:
0 Magnetic Sensor heading in degrees
1 Magnetic Deviation, degrees
2 Magnetic Deviation direction, E = Easterly, W = Westerly
3 Magnetic Variation degrees
4 Magnetic Variation direction, E = Easterly, W = Westerly
*/
function isEmpty(mixed) {
return (
(typeof mixed !== 'string' && typeof mixed !== 'number') ||
(typeof mixed === 'string' && mixed.trim() === '')
)
}
module.exports = function (input) {
const { parts, tags } = input
const values = []
const headingCompass = parts[0]
const deviation = parts[1]
const deviationDir = parts[2] === 'E' ? 1 : -1
const variation = parts[3]
const variationDir = parts[4] === 'E' ? 1 : -1
if (!isEmpty(headingCompass)) {
const effectiveDeviation = !isEmpty(deviation) ? Number(deviation) * deviationDir : 0
values.push({
path: 'navigation.headingMagnetic',
value: utils.transform(utils.float(headingCompass) + effectiveDeviation, 'deg', 'rad'),
})
if (!isEmpty(deviation)) {
values.push({
path: 'navigation.headingCompass',
value: utils.transform(utils.float(headingCompass), 'deg', 'rad'),
})
}
if (!isEmpty(variation)) {
const effectiveVariation = variation * variationDir
values.push({
path: 'navigation.headingTrue',
value: utils.transform(utils.float(headingCompass) + effectiveDeviation + effectiveVariation, 'deg', 'rad'),
})
}
}
if (!(isEmpty(variation) || isEmpty(variationDir))) {
values.push({
path: 'navigation.magneticVariation',
value:
utils.transform(utils.float(variation), 'deg', 'rad') *
variationDir,
})
}
if (!(isEmpty(deviation) || isEmpty(deviationDir))) {
values.push({
path: 'navigation.magneticDeviation',
value:
utils.transform(utils.float(deviation), 'deg', 'rad') *
deviationDir,
})
}
if (!values.length) {
return null
}
const delta = {
updates: [
{
source: tags.source,
timestamp: tags.timestamp,
values,
},
],
}
return delta
}