I am receiving data from a gps unit via a udp packet. Lat/Lng values are in hex.
Example Data
13BF71A8 = Latitude (33.1313576)
BA18A506 = Longitude (-1
use this for 2 compliment
private static Decimal ParseHexStringToDouble(string hexNumber) {
long result = 0;
result = int.Parse(hexNumber, System.Globalization.NumberStyles.HexNumber);
return result;
}
Because you are using signed numbers, you need to specify a point at which the hexadecimal code should flip to the bottom. This will be happening at 7FFFFFFF
and up. Now update your code to check if the input is greater than this number, and if so, subtract it from the input.
function convert(h) {
dec = parseInt(h, 16);
return (dec < parseInt('7FFFFFFF', 16)) ?
dec * 0.0000001 :
0 - ((parseInt('FFFFFFFF', 16) - dec) * 0.0000001);
}
The only reason your example worked is because the output was expected to be positive.
As AlexWien mentioned in the comments: Since parsing 7FFFFFFF
and FFFFFFFF
are giving the same integers every time, you could store them as constants. Their values are 2147483647
and 4294967295
respectively.
Lat and Long use the same algorithm for conversion. Your latitude accidentaly wokred because it is positive (33.13)
The test Longitude is negative, which makes the error in the conversion algorithm visible, as usually with negative numbers.