mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge
synced 2025-01-15 20:27:32 +01:00
Changed NavigationSpec's distance into a String.
Previously we used an integer (in meters) but when using Google Maps navigation, Google Maps picks units based on locale *and* the distance - it might report "100m" or "20km". Then we carefully undo all that work, and for PineTime we just as "m" so you may well have "20000m" or more displayed, which is not ideal. I imagine at some point that will change, but we probably want to be able to handle that in the OSMAnd side of Gadgetbridge so all watches that implement navigation will benefit (and won't duplicate code).
This commit is contained in:
parent
5c3b76b838
commit
b2aa61e182
@ -61,7 +61,7 @@ public class OsmandEventReceiver {
|
|||||||
@Override
|
@Override
|
||||||
public void updateNavigationInfo(ADirectionInfo directionInfo) {
|
public void updateNavigationInfo(ADirectionInfo directionInfo) {
|
||||||
navigationInfoSpec.nextAction = directionInfo.getTurnType();
|
navigationInfoSpec.nextAction = directionInfo.getTurnType();
|
||||||
navigationInfoSpec.distanceToTurn = directionInfo.getDistanceTo();
|
navigationInfoSpec.distanceToTurn = directionInfo.getDistanceTo()+"m";
|
||||||
|
|
||||||
if (shouldSendNavigation()) {
|
if (shouldSendNavigation()) {
|
||||||
GBApplication.deviceService().onSetNavigationInfo(navigationInfoSpec);
|
GBApplication.deviceService().onSetNavigationInfo(navigationInfoSpec);
|
||||||
|
@ -958,21 +958,8 @@ public class GoogleMapsNotificationHandler {
|
|||||||
if (matchedIcon>=0)
|
if (matchedIcon>=0)
|
||||||
navInfo.nextAction = matchedIcon;
|
navInfo.nextAction = matchedIcon;
|
||||||
navInfo.instruction = instruction;
|
navInfo.instruction = instruction;
|
||||||
if (distance != null) {
|
if (distance != null)
|
||||||
float distanceMultiplier = 1;
|
navInfo.distanceToTurn = distance;
|
||||||
String distanceUnit = distance.replaceAll("[\\d.\\s]", "").toLowerCase();
|
|
||||||
if (distanceUnit.equals("m")) distanceMultiplier = 1;
|
|
||||||
else if (distanceUnit.equals("mi")) distanceMultiplier = 1609.34f;
|
|
||||||
else if (distanceUnit.equals("yd")) distanceMultiplier = 0.9144f;
|
|
||||||
else if (distanceUnit.equals("ft")) distanceMultiplier = 0.3048f;
|
|
||||||
else if (distanceUnit.equals("km")) distanceMultiplier = 1000;
|
|
||||||
else LOG.info("Unknown distance unit '"+distanceUnit+"'");
|
|
||||||
try {
|
|
||||||
navInfo.distanceToTurn = Math.round(distanceMultiplier * Float.parseFloat(distance.replaceAll("[^\\d.]", "")));
|
|
||||||
} catch (NumberFormatException e) {
|
|
||||||
LOG.info("Couldn't parse distance");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (navLines[2].contains("ETA"))
|
if (navLines[2].contains("ETA"))
|
||||||
navInfo.ETA = navLines[2].replace("ETA","").trim();
|
navInfo.ETA = navLines[2].replace("ETA","").trim();
|
||||||
GBApplication.deviceService().onSetNavigationInfo(navInfo);
|
GBApplication.deviceService().onSetNavigationInfo(navInfo);
|
||||||
|
@ -37,7 +37,7 @@ public class NavigationInfoSpec {
|
|||||||
|
|
||||||
// ETA? Total Distance?
|
// ETA? Total Distance?
|
||||||
public String instruction;
|
public String instruction;
|
||||||
public int distanceToTurn; ///< Distance to turn (in metres?)
|
public String distanceToTurn; ///< Distance to turn (as a string, eg "100m")
|
||||||
public int nextAction; ///< One of the ACTION_ constants
|
public int nextAction; ///< One of the ACTION_ constants
|
||||||
public String ETA; ///< Estimated time of Arrival
|
public String ETA; ///< Estimated time of Arrival
|
||||||
}
|
}
|
||||||
|
@ -890,7 +890,7 @@ public class DeviceCommunicationService extends Service implements SharedPrefere
|
|||||||
NavigationInfoSpec navigationInfoSpec = new NavigationInfoSpec();
|
NavigationInfoSpec navigationInfoSpec = new NavigationInfoSpec();
|
||||||
navigationInfoSpec.instruction = intent.getStringExtra(EXTRA_NAVIGATION_INSTRUCTION);
|
navigationInfoSpec.instruction = intent.getStringExtra(EXTRA_NAVIGATION_INSTRUCTION);
|
||||||
navigationInfoSpec.nextAction = intent.getIntExtra(EXTRA_NAVIGATION_NEXT_ACTION,0);
|
navigationInfoSpec.nextAction = intent.getIntExtra(EXTRA_NAVIGATION_NEXT_ACTION,0);
|
||||||
navigationInfoSpec.distanceToTurn = intent.getIntExtra(EXTRA_NAVIGATION_DISTANCE_TO_TURN,0);
|
navigationInfoSpec.distanceToTurn = intent.getStringExtra(EXTRA_NAVIGATION_DISTANCE_TO_TURN);
|
||||||
navigationInfoSpec.ETA = intent.getStringExtra(EXTRA_NAVIGATION_ETA);
|
navigationInfoSpec.ETA = intent.getStringExtra(EXTRA_NAVIGATION_ETA);
|
||||||
deviceSupport.onSetNavigationInfo(navigationInfoSpec);
|
deviceSupport.onSetNavigationInfo(navigationInfoSpec);
|
||||||
break;
|
break;
|
||||||
|
@ -326,9 +326,11 @@ public class PineTimeJFSupport extends AbstractBTLEDeviceSupport implements DfuL
|
|||||||
if (navigationInfoSpec.instruction == null) {
|
if (navigationInfoSpec.instruction == null) {
|
||||||
navigationInfoSpec.instruction = "";
|
navigationInfoSpec.instruction = "";
|
||||||
}
|
}
|
||||||
|
if (navigationInfoSpec.distanceToTurn == null) {
|
||||||
|
navigationInfoSpec.distanceToTurn = "";
|
||||||
|
}
|
||||||
safeWriteToCharacteristic(builder, PineTimeJFConstants.UUID_CHARACTERISTICS_NAVIGATION_NARRATIVE, navigationInfoSpec.instruction.getBytes(StandardCharsets.UTF_8));
|
safeWriteToCharacteristic(builder, PineTimeJFConstants.UUID_CHARACTERISTICS_NAVIGATION_NARRATIVE, navigationInfoSpec.instruction.getBytes(StandardCharsets.UTF_8));
|
||||||
safeWriteToCharacteristic(builder, PineTimeJFConstants.UUID_CHARACTERISTICS_NAVIGATION_MAN_DISTANCE, (navigationInfoSpec.distanceToTurn + "m").getBytes(StandardCharsets.UTF_8));
|
safeWriteToCharacteristic(builder, PineTimeJFConstants.UUID_CHARACTERISTICS_NAVIGATION_MAN_DISTANCE, navigationInfoSpec.distanceToTurn.getBytes(StandardCharsets.UTF_8));
|
||||||
String iconname;
|
String iconname;
|
||||||
switch (navigationInfoSpec.nextAction) {
|
switch (navigationInfoSpec.nextAction) {
|
||||||
case NavigationInfoSpec.ACTION_CONTINUE:
|
case NavigationInfoSpec.ACTION_CONTINUE:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user