Support three turn options for one segment in the result route description

This commit is contained in:
Roman Inflianskas 2016-04-05 12:58:05 +03:00
parent 7f72ed8375
commit 5336b59495
3 changed files with 23 additions and 4 deletions

View file

@ -1006,6 +1006,7 @@ public class RouteResultPreparation {
int[] lanes = new int[splitLaneOptions.length];
for (int i = 0; i < splitLaneOptions.length; i++) {
String[] laneOptions = splitLaneOptions[i].split(";");
boolean is_tertiary_turn = false;
for (int j = 0; j < laneOptions.length; j++) {
int turn;
@ -1039,10 +1040,13 @@ public class RouteResultPreparation {
(TurnType.isLeftTurn(calcTurnType) && TurnType.isLeftTurn(turn))
) {
TurnType.setPrimaryTurnShiftOthers(lanes, i, turn);
} else {
} else if (!is_tertiary_turn) {
TurnType.setSecondaryTurnShiftOthers(lanes, i, turn);
is_tertiary_turn = true;
} else {
TurnType.setTertiaryTurn(lanes, i, turn);
break;
}
break; // Move on to the next lane
}
}
}

View file

@ -180,7 +180,7 @@ public class TurnType {
}
public static int getSecondaryTurn(int laneValue) {
// Get the primary turn modifier for the lane
// Get the secondary turn modifier for the lane
return (laneValue >> 5);
}
@ -206,7 +206,7 @@ public class TurnType {
}
public static int getTertiaryTurn(int laneValue) {
// Get the primary turn modifier for the lane
// Get the tertiary turn modifier for the lane
return (laneValue >> 10);
}

View file

@ -216,6 +216,21 @@
"expectedResults": {
"14418": "TL, +TL, C, C, TR"
}
},
{
"testName": "11.Figure 8 TL",
"startPoint": {
"latitude": 45.69816447596442,
"longitude": 35.74885922431952
},
"endPoint": {
"latitude": 45.700075267731705,
"longitude": 35.7467134571076
},
"expectedResults": {
"43906": null,
"43905": "+TL;C;TR"
}
}
]