forked from df8oe/RS41HUP
-
Notifications
You must be signed in to change notification settings - Fork 0
/
locator.c
32 lines (24 loc) · 862 Bytes
/
locator.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
// Based on HamLib's locator routines
// OK1TE 2018-10
#include "locator.h"
#include "config.h"
const static uint8_t loc_char_range[] = { 18, 10, 24, 10, 24, 10 };
const float precision = 1E+7;
uint8_t longlat2locator(int32_t longitude, int32_t latitude, char locator[]) {
if (!locator)
return 0;
for (uint8_t x_or_y = 0; x_or_y < 2; ++x_or_y) {
float ordinate = ((x_or_y == 0) ? (longitude / 2) / precision : latitude / precision) + 90;
uint32_t divisions = 1;
for (uint8_t pair = 0; pair < PAIR_COUNT; ++pair) {
divisions *= loc_char_range[pair];
const float square_size = 180.0 / divisions;
uint8_t locvalue = (uint8_t) (ordinate / square_size);
ordinate -= square_size * locvalue;
locvalue += (loc_char_range[pair] == 10) ? '0':'A';
locator[pair * 2 + x_or_y] = locvalue;
}
}
locator[PAIR_COUNT * 2] = 0;
return 1;
}