mirror of
https://github.com/dotMorten/NmeaParser.git
synced 2025-12-06 07:12:04 +01:00
Added gpgsv
This commit is contained in:
parent
944efb7fe3
commit
aa05f87b2e
98
src/NmeaParser.Shared/Nmea/Gps/GPGSV.cs
Normal file
98
src/NmeaParser.Shared/Nmea/Gps/GPGSV.cs
Normal file
|
|
@ -0,0 +1,98 @@
|
|||
//
|
||||
// Copyright (c) 2014 Morten Nielsen
|
||||
//
|
||||
// Licensed under the Microsoft Public License (Ms-PL) (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// http://opensource.org/licenses/Ms-PL.html
|
||||
//
|
||||
// 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.
|
||||
//
|
||||
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Globalization;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace NmeaParser.Nmea.Gps
|
||||
{
|
||||
/// <summary>
|
||||
/// GPS Satellites in view
|
||||
/// </summary>
|
||||
[NmeaMessageType(Type = "GPGSV")]
|
||||
public sealed class Gpgsv : NmeaMessage
|
||||
{
|
||||
protected override void LoadMessage(string[] message)
|
||||
{
|
||||
TotalMessages = int.Parse(message[0]);
|
||||
MessageNumber = int.Parse(message[1]);
|
||||
SVsInView = int.Parse(message[2]);
|
||||
|
||||
List<SatelitteVehicle> svs = new List<SatelitteVehicle>();
|
||||
for (int i = 3; i < 18; i+=4)
|
||||
{
|
||||
if (message[i].Length == 0)
|
||||
continue;
|
||||
else
|
||||
svs.Add(new SatelitteVehicle(message, i));
|
||||
}
|
||||
this.SVs = svs.ToArray();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Total number of messages of this type in this cycle
|
||||
/// </summary>
|
||||
public int TotalMessages { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Message number
|
||||
/// </summary>
|
||||
public int MessageNumber { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Total number of SVs in view
|
||||
/// </summary>
|
||||
public int SVsInView { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Dilution of precision
|
||||
/// </summary>
|
||||
public SatelitteVehicle[] SVs { get; private set; }
|
||||
}
|
||||
|
||||
public sealed class SatelitteVehicle
|
||||
{
|
||||
internal SatelitteVehicle(string[] message, int startIndex)
|
||||
{
|
||||
PrnNumber = int.Parse(message[startIndex]);
|
||||
Elevation = double.Parse(message[startIndex+1], CultureInfo.InvariantCulture);
|
||||
Azimuth = double.Parse(message[startIndex + 2], CultureInfo.InvariantCulture);
|
||||
int snr = -1;
|
||||
if (int.TryParse(message[startIndex + 3], out snr))
|
||||
SignalToNoiseRatio = snr;
|
||||
}
|
||||
/// <summary>
|
||||
/// SV PRN number
|
||||
/// </summary>
|
||||
public int PrnNumber { get; set; }
|
||||
/// <summary>
|
||||
/// Elevation in degrees, 90 maximum
|
||||
/// </summary>
|
||||
public double Elevation { get; private set; }
|
||||
/// <summary>
|
||||
/// Azimuth, degrees from true north, 000 to 359
|
||||
/// </summary>
|
||||
public double Azimuth { get; private set; }
|
||||
/// <summary>
|
||||
/// Signal-to-Noise ratio, 0-99 dB (-1 when not tracking)
|
||||
/// </summary>
|
||||
public int SignalToNoiseRatio { get; private set; }
|
||||
}
|
||||
}
|
||||
|
|
@ -12,6 +12,7 @@
|
|||
<Compile Include="$(MSBuildThisFileDirectory)NmeaDevice.cs" />
|
||||
<Compile Include="$(MSBuildThisFileDirectory)NmeaFileDevice.cs" />
|
||||
<Compile Include="$(MSBuildThisFileDirectory)Nmea\Gps\Garmin\PGRME.cs" />
|
||||
<Compile Include="$(MSBuildThisFileDirectory)Nmea\Gps\GPGSV.cs" />
|
||||
<Compile Include="$(MSBuildThisFileDirectory)Nmea\Gps\GPGSA.cs" />
|
||||
<Compile Include="$(MSBuildThisFileDirectory)Nmea\Gps\GPGGA.cs" />
|
||||
<Compile Include="$(MSBuildThisFileDirectory)Nmea\Gps\GPRMB.cs" />
|
||||
|
|
|
|||
|
|
@ -192,5 +192,50 @@ namespace NmeaParser.Tests
|
|||
Assert.AreEqual(1.0, gsa.HDop);
|
||||
Assert.AreEqual(1.3, gsa.VDop);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
public void TestGpgsv()
|
||||
{
|
||||
string input = "$GPGSV,3,3,11,22,42,067,42,24,14,311,43,27,05,244,00,,,,*4D";
|
||||
var msg = NmeaMessage.Parse(input);
|
||||
Assert.IsInstanceOfType(msg, typeof(Gpgsv));
|
||||
Gpgsv gsv = (Gpgsv)msg;
|
||||
Assert.AreEqual(3, gsv.TotalMessages);
|
||||
Assert.AreEqual(3, gsv.MessageNumber);
|
||||
Assert.AreEqual(11, gsv.SVsInView);
|
||||
Assert.IsNotNull(gsv.SVs);
|
||||
Assert.AreEqual(3, gsv.SVs.Length);
|
||||
var sv = gsv.SVs[0];
|
||||
Assert.AreEqual(22, sv.PrnNumber);
|
||||
Assert.AreEqual(42, sv.Elevation);
|
||||
Assert.AreEqual(67, sv.Azimuth);
|
||||
Assert.AreEqual(42, sv.SignalToNoiseRatio);
|
||||
|
||||
sv = gsv.SVs[1];
|
||||
Assert.AreEqual(24, sv.PrnNumber);
|
||||
Assert.AreEqual(14, sv.Elevation);
|
||||
Assert.AreEqual(311, sv.Azimuth);
|
||||
Assert.AreEqual(43, sv.SignalToNoiseRatio);
|
||||
|
||||
sv = gsv.SVs[2];
|
||||
Assert.AreEqual(27, sv.PrnNumber);
|
||||
Assert.AreEqual(5, sv.Elevation);
|
||||
Assert.AreEqual(244, sv.Azimuth);
|
||||
Assert.AreEqual(00, sv.SignalToNoiseRatio);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
public void TestGpgsv_Empty()
|
||||
{
|
||||
string input = "$GPGSV,1,1,0,,,,,,,,,,,,,,,,*49";
|
||||
var msg = NmeaMessage.Parse(input);
|
||||
Assert.IsInstanceOfType(msg, typeof(Gpgsv));
|
||||
Gpgsv gsv = (Gpgsv)msg;
|
||||
Assert.AreEqual(1, gsv.TotalMessages);
|
||||
Assert.AreEqual(1, gsv.MessageNumber);
|
||||
Assert.AreEqual(0, gsv.SVsInView);
|
||||
Assert.IsNotNull(gsv.SVs);
|
||||
Assert.AreEqual(0, gsv.SVs.Length);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in a new issue