altoslib: Retry map connections 10 times on network failure
[fw/altos] / altoslib / AltosLocation.java
1 /*
2  * Copyright © 2014 Keith Packard <keithp@keithp.com>
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation; either version 2 of the License, or
7  * (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful, but
10  * WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12  * General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License along
15  * with this program; if not, write to the Free Software Foundation, Inc.,
16  * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
17  */
18
19 package org.altusmetrum.altoslib_13;
20
21 public abstract class AltosLocation extends AltosUnits {
22
23         public abstract String pos();
24         public abstract String neg();
25
26         public double value(double v, boolean imperial_units) {
27                 return v;
28         }
29
30         public double inverse(double v, boolean imperial_units) {
31                 return v;
32         }
33
34         public String show_units(boolean imperial_units) {
35                 return "°";
36         }
37
38         public String say_units(boolean imperial_units) {
39                 return "degrees";
40         }
41
42         public int show_fraction(int width, boolean imperial_units) {
43                 return 2;
44         }
45
46         public String show(int width, double v, boolean imperial_units) {
47                 String  h = pos();
48                 if (v < 0) {
49                         h = neg();
50                         v = -v;
51                 }
52                 int deg = (int) Math.floor(v);
53                 double min = (v - Math.floor(v)) * 60.0;
54                 return String.format("%s %4d° %9.6f", h, deg, min);
55         }
56
57         public String say(double v, boolean imperial_units) {
58                 String  h = pos();
59                 if (v < 0) {
60                         h = neg();
61                         v = -v;
62                 }
63                 int deg = (int) Math.floor(v);
64                 double min = (v - Math.floor(v)) * 60.0;
65                 return String.format("%s %d degrees %d", h, deg, (int) Math.floor(min + 0.5));
66         }
67 }