Merge remote-tracking branch 'origin/master' into exp_imp_profile_with_features
# Conflicts: # OsmAnd/res/values/strings.xml # OsmAnd/src/net/osmand/plus/settings/ConfigureProfileFragment.java
This commit is contained in:
commit
f34fd13ee9
141 changed files with 2556 additions and 3794 deletions
|
@ -36,6 +36,16 @@ public abstract class MoreMath {
|
|||
*/
|
||||
public static final transient double HALF_PI_D = Math.PI / 2.0d;
|
||||
|
||||
/**
|
||||
* Math.PI/4
|
||||
*/
|
||||
public static final transient float QUAD_PI = (float) Math.PI / 4.0f;
|
||||
|
||||
/**
|
||||
* Math.PI/4
|
||||
*/
|
||||
public static final transient double QUAD_PI_D = Math.PI / 4.0d;
|
||||
|
||||
/**
|
||||
* Checks if a ~= b. Use this to test equality of floating point numbers.
|
||||
* <p>
|
||||
|
|
|
@ -19,6 +19,8 @@ public class BinaryMapDataObject {
|
|||
protected int[] types = null;
|
||||
protected int[] additionalTypes = null;
|
||||
protected int objectType = RenderingRulesStorage.POINT_RULES;
|
||||
protected int labelX;
|
||||
protected int labelY;
|
||||
|
||||
protected TIntObjectHashMap<String> objectNames = null;
|
||||
protected TIntArrayList namesOrder = null;
|
||||
|
@ -33,7 +35,7 @@ public class BinaryMapDataObject {
|
|||
|
||||
|
||||
public BinaryMapDataObject(long id, int[] coordinates, int[][] polygonInnerCoordinates, int objectType, boolean area,
|
||||
int[] types, int[] additionalTypes){
|
||||
int[] types, int[] additionalTypes, int labelX, int labelY){
|
||||
this.polygonInnerCoordinates = polygonInnerCoordinates;
|
||||
this.coordinates = coordinates;
|
||||
this.additionalTypes = additionalTypes;
|
||||
|
@ -41,6 +43,8 @@ public class BinaryMapDataObject {
|
|||
this.id = id;
|
||||
this.objectType = objectType;
|
||||
this.area = area;
|
||||
this.labelX = labelX;
|
||||
this.labelY = labelY;
|
||||
}
|
||||
|
||||
protected void setCoordinates(int[] coordinates) {
|
||||
|
@ -202,79 +206,80 @@ public class BinaryMapDataObject {
|
|||
&& this.id == thatObj.id
|
||||
&& this.area == thatObj.area
|
||||
&& compareCoordinates(this.coordinates, thatObj.coordinates, coordinatesPrecision) ) {
|
||||
if(mapIndex == null) {
|
||||
if (mapIndex == null) {
|
||||
throw new IllegalStateException("Illegal binary object: " + id);
|
||||
}
|
||||
if(thatObj.mapIndex == null) {
|
||||
if (thatObj.mapIndex == null) {
|
||||
throw new IllegalStateException("Illegal binary object: " + thatObj.id);
|
||||
}
|
||||
|
||||
boolean equals = true;
|
||||
if(equals) {
|
||||
if(polygonInnerCoordinates == null || thatObj.polygonInnerCoordinates == null) {
|
||||
equals = polygonInnerCoordinates == thatObj.polygonInnerCoordinates;
|
||||
} else if(polygonInnerCoordinates.length != thatObj.polygonInnerCoordinates.length){
|
||||
if (equals) {
|
||||
if (polygonInnerCoordinates == null || thatObj.polygonInnerCoordinates == null) {
|
||||
equals = polygonInnerCoordinates == thatObj.polygonInnerCoordinates;
|
||||
} else if (polygonInnerCoordinates.length != thatObj.polygonInnerCoordinates.length) {
|
||||
equals = false;
|
||||
} else {
|
||||
for(int i = 0; i < polygonInnerCoordinates.length && equals; i++) {
|
||||
if(polygonInnerCoordinates[i] == null || thatObj.polygonInnerCoordinates[i] == null) {
|
||||
equals = polygonInnerCoordinates[i] == thatObj.polygonInnerCoordinates[i];
|
||||
} else if(polygonInnerCoordinates[i].length != thatObj.polygonInnerCoordinates[i].length){
|
||||
for (int i = 0; i < polygonInnerCoordinates.length && equals; i++) {
|
||||
if (polygonInnerCoordinates[i] == null || thatObj.polygonInnerCoordinates[i] == null) {
|
||||
equals = polygonInnerCoordinates[i] == thatObj.polygonInnerCoordinates[i];
|
||||
} else if (polygonInnerCoordinates[i].length != thatObj.polygonInnerCoordinates[i].length) {
|
||||
equals = false;
|
||||
} else {
|
||||
equals = compareCoordinates(polygonInnerCoordinates[i], thatObj.polygonInnerCoordinates[i], coordinatesPrecision);
|
||||
equals = compareCoordinates(polygonInnerCoordinates[i], thatObj.polygonInnerCoordinates[i],
|
||||
coordinatesPrecision);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if(equals) {
|
||||
if(types == null || thatObj.types == null) {
|
||||
equals = types == thatObj.types;
|
||||
} else if(types.length != thatObj.types.length){
|
||||
if (equals) {
|
||||
if (types == null || thatObj.types == null) {
|
||||
equals = types == thatObj.types;
|
||||
} else if (types.length != thatObj.types.length) {
|
||||
equals = false;
|
||||
} else {
|
||||
for(int i = 0; i < types.length && equals; i++) {
|
||||
for (int i = 0; i < types.length && equals; i++) {
|
||||
TagValuePair o = mapIndex.decodeType(types[i]);
|
||||
TagValuePair s = thatObj.mapIndex.decodeType(thatObj.types[i]);
|
||||
equals = o.equals(s) && equals;
|
||||
}
|
||||
}
|
||||
}
|
||||
if(equals) {
|
||||
if(additionalTypes == null || thatObj.additionalTypes == null) {
|
||||
equals = additionalTypes == thatObj.additionalTypes;
|
||||
} else if(additionalTypes.length != thatObj.additionalTypes.length){
|
||||
if (equals) {
|
||||
if (additionalTypes == null || thatObj.additionalTypes == null) {
|
||||
equals = additionalTypes == thatObj.additionalTypes;
|
||||
} else if (additionalTypes.length != thatObj.additionalTypes.length) {
|
||||
equals = false;
|
||||
} else {
|
||||
for(int i = 0; i < additionalTypes.length && equals; i++) {
|
||||
for (int i = 0; i < additionalTypes.length && equals; i++) {
|
||||
TagValuePair o = mapIndex.decodeType(additionalTypes[i]);
|
||||
TagValuePair s = thatObj.mapIndex.decodeType(thatObj.additionalTypes[i]);
|
||||
equals = o.equals(s);
|
||||
}
|
||||
}
|
||||
}
|
||||
if(equals) {
|
||||
if(namesOrder == null || thatObj.namesOrder == null) {
|
||||
equals = namesOrder == thatObj.namesOrder;
|
||||
} else if(namesOrder.size() != thatObj.namesOrder.size()){
|
||||
if (equals) {
|
||||
if (namesOrder == null || thatObj.namesOrder == null) {
|
||||
equals = namesOrder == thatObj.namesOrder;
|
||||
} else if (namesOrder.size() != thatObj.namesOrder.size()) {
|
||||
equals = false;
|
||||
} else {
|
||||
for(int i = 0; i < namesOrder.size() && equals; i++) {
|
||||
for (int i = 0; i < namesOrder.size() && equals; i++) {
|
||||
TagValuePair o = mapIndex.decodeType(namesOrder.get(i));
|
||||
TagValuePair s = thatObj.mapIndex.decodeType(thatObj.namesOrder.get(i));
|
||||
equals = o.equals(s);
|
||||
}
|
||||
}
|
||||
}
|
||||
if(equals) {
|
||||
if (equals) {
|
||||
// here we know that name indexes are equal & it is enough to check the value sets
|
||||
if(objectNames == null || thatObj.objectNames == null) {
|
||||
equals = objectNames == thatObj.objectNames;
|
||||
} else if(objectNames.size() != thatObj.objectNames.size()){
|
||||
if (objectNames == null || thatObj.objectNames == null) {
|
||||
equals = objectNames == thatObj.objectNames;
|
||||
} else if (objectNames.size() != thatObj.objectNames.size()) {
|
||||
equals = false;
|
||||
} else {
|
||||
for(int i = 0; i < namesOrder.size() && equals; i++) {
|
||||
for (int i = 0; i < namesOrder.size() && equals; i++) {
|
||||
String o = objectNames.get(namesOrder.get(i));
|
||||
String s = thatObj.objectNames.get(thatObj.namesOrder.get(i));
|
||||
equals = Algorithms.objectEquals(o, s);
|
||||
|
@ -357,14 +362,41 @@ public class BinaryMapDataObject {
|
|||
|
||||
}
|
||||
|
||||
public boolean isLabelSpecified() {
|
||||
return (labelX != 0 || labelY != 0) && coordinates.length > 0;
|
||||
}
|
||||
|
||||
public int getLabelX() {
|
||||
long sum = 0;
|
||||
int LABEL_SHIFT = 31 - BinaryMapIndexReader.LABEL_ZOOM_ENCODE;
|
||||
int len = coordinates.length / 2;
|
||||
for(int i = 0; i < len; i++) {
|
||||
sum += coordinates[2 * i];
|
||||
}
|
||||
int average = ((int) (sum >> BinaryMapIndexReader.SHIFT_COORDINATES)/ len)
|
||||
<< (BinaryMapIndexReader.SHIFT_COORDINATES - LABEL_SHIFT);
|
||||
int label31X = (average + this.labelX) << LABEL_SHIFT;
|
||||
return label31X;
|
||||
}
|
||||
|
||||
public int getLabelY() {
|
||||
long sum = 0;
|
||||
int LABEL_SHIFT = 31 - BinaryMapIndexReader.LABEL_ZOOM_ENCODE;
|
||||
int len = coordinates.length / 2;
|
||||
for(int i = 0; i < len; i++) {
|
||||
sum += coordinates[2 * i + 1];
|
||||
}
|
||||
int average = ((int) (sum >> BinaryMapIndexReader.SHIFT_COORDINATES)/ len)
|
||||
<< (BinaryMapIndexReader.SHIFT_COORDINATES - LABEL_SHIFT);
|
||||
int label31Y = (average + this.labelY) << LABEL_SHIFT;
|
||||
return label31Y;
|
||||
}
|
||||
|
||||
public int[] getCoordinates() {
|
||||
return coordinates;
|
||||
}
|
||||
|
||||
|
||||
public int getObjectType() {
|
||||
return objectType;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -76,12 +76,12 @@ import gnu.trove.map.TIntObjectMap;
|
|||
import gnu.trove.map.hash.TIntObjectHashMap;
|
||||
import gnu.trove.map.hash.TLongObjectHashMap;
|
||||
import gnu.trove.set.hash.TIntHashSet;
|
||||
import gnu.trove.set.hash.TLongHashSet;
|
||||
|
||||
public class BinaryMapIndexReader {
|
||||
|
||||
public final static int TRANSPORT_STOP_ZOOM = 24;
|
||||
public static final int SHIFT_COORDINATES = 5;
|
||||
public static final int LABEL_ZOOM_ENCODE = 26;
|
||||
private final static Log log = PlatformUtil.getLog(BinaryMapIndexReader.class);
|
||||
public static boolean READ_STATS = false;
|
||||
public static final SearchPoiTypeFilter ACCEPT_ALL_POI_TYPE_FILTER = new SearchPoiTypeFilter() {
|
||||
|
@ -1136,6 +1136,7 @@ public class BinaryMapIndexReader {
|
|||
TIntObjectHashMap<String> stringNames = null;
|
||||
TIntArrayList stringOrder = null;
|
||||
long id = 0;
|
||||
int labelX = 0, labelY = 0;
|
||||
|
||||
boolean loop = true;
|
||||
while (loop) {
|
||||
|
@ -1232,6 +1233,26 @@ public class BinaryMapIndexReader {
|
|||
req.stat.lastStringNamesSize += sizeL;
|
||||
}
|
||||
break;
|
||||
case OsmandOdb.MapData.LABELCOORDINATES_FIELD_NUMBER:
|
||||
sizeL = codedIS.readRawVarint32();
|
||||
old = codedIS.pushLimit(sizeL);
|
||||
int i = 0;
|
||||
while (codedIS.getBytesUntilLimit() > 0) {
|
||||
if (i == 0) {
|
||||
labelX = codedIS.readSInt32();
|
||||
} else if (i == 1) {
|
||||
labelY = codedIS.readSInt32();
|
||||
} else {
|
||||
codedIS.readRawVarint32();
|
||||
}
|
||||
i++;
|
||||
}
|
||||
codedIS.popLimit(old);
|
||||
if (READ_STATS) {
|
||||
req.stat.addTagHeader(OsmandOdb.MapData.LABELCOORDINATES_FIELD_NUMBER, sizeL);
|
||||
req.stat.lastObjectLabelCoordinates += sizeL;
|
||||
}
|
||||
break;
|
||||
default:
|
||||
skipUnknownField(t);
|
||||
break;
|
||||
|
@ -1259,6 +1280,9 @@ public class BinaryMapIndexReader {
|
|||
dataObject.id = id;
|
||||
dataObject.area = area;
|
||||
dataObject.mapIndex = root;
|
||||
dataObject.labelX = labelX;
|
||||
dataObject.labelY = labelY;
|
||||
|
||||
return dataObject;
|
||||
}
|
||||
|
||||
|
@ -1562,6 +1586,7 @@ public class BinaryMapIndexReader {
|
|||
public int lastObjectAdditionalTypes;
|
||||
public int lastObjectTypes;
|
||||
public int lastObjectCoordinates;
|
||||
public int lastObjectLabelCoordinates;
|
||||
|
||||
public int lastObjectSize;
|
||||
public int lastBlockStringTableSize;
|
||||
|
@ -1586,6 +1611,7 @@ public class BinaryMapIndexReader {
|
|||
lastObjectAdditionalTypes = 0;
|
||||
lastObjectTypes = 0;
|
||||
lastObjectCoordinates = 0;
|
||||
lastObjectLabelCoordinates = 0;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1917,7 +1943,8 @@ public class BinaryMapIndexReader {
|
|||
|
||||
BinaryMapDataObject bm =
|
||||
new BinaryMapDataObject(o.id, o.coordinates, o.polygonInnerCoordinates, o.objectType, o.area,
|
||||
types.toArray(), additionalTypes.isEmpty() ? null : additionalTypes.toArray());
|
||||
types.toArray(), additionalTypes.isEmpty() ? null : additionalTypes.toArray(),
|
||||
o.labelX, o.labelY);
|
||||
if (o.namesOrder != null) {
|
||||
bm.objectNames = new TIntObjectHashMap<>();
|
||||
bm.namesOrder = new TIntArrayList();
|
||||
|
@ -2093,7 +2120,7 @@ public class BinaryMapIndexReader {
|
|||
|
||||
public static void main(String[] args) throws IOException {
|
||||
File fl = new File(System.getProperty("maps") + "/Synthetic_test_rendering.obf");
|
||||
fl = new File(System.getProperty("maps") + "/Belarus_europe_2.obf");
|
||||
fl = new File("/home/madwasp79/OsmAnd-maps/Poly_center2.obf");
|
||||
|
||||
RandomAccessFile raf = new RandomAccessFile(fl, "r");
|
||||
|
||||
|
@ -2201,7 +2228,6 @@ public class BinaryMapIndexReader {
|
|||
private static List<Location> readGPX(File f) {
|
||||
List<Location> res = new ArrayList<Location>();
|
||||
try {
|
||||
StringBuilder content = new StringBuilder();
|
||||
BufferedReader reader = new BufferedReader(getUTF8Reader(new FileInputStream(f)));
|
||||
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
|
||||
DocumentBuilder dom = factory.newDocumentBuilder();
|
||||
|
@ -2218,7 +2244,6 @@ public class BinaryMapIndexReader {
|
|||
// Document doc = dom.parse(new InputSource(new StringReader(content.toString())));
|
||||
Document doc = dom.parse(new InputSource(reader));
|
||||
NodeList list = doc.getElementsByTagName("trkpt");
|
||||
Way w = new Way(-1);
|
||||
for (int i = 0; i < list.getLength(); i++) {
|
||||
Element item = (Element) list.item(i);
|
||||
try {
|
||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,4 +1,5 @@
|
|||
package net.osmand.data;
|
||||
|
||||
import net.osmand.util.MapUtils;
|
||||
|
||||
public class RotatedTileBox {
|
||||
|
@ -212,6 +213,19 @@ public class RotatedTileBox {
|
|||
return pixHeight;
|
||||
}
|
||||
|
||||
public float getPixXFrom31(int x31, int y31) {
|
||||
double zm = MapUtils.getPowZoom(31 - zoom);
|
||||
double xTile = ((double) x31) / zm;
|
||||
double yTile = ((double) y31) / zm;
|
||||
return getPixXFromTile(xTile, yTile);
|
||||
}
|
||||
|
||||
public float getPixYFrom31(int x31, int y31) {
|
||||
double zm = MapUtils.getPowZoom(31 - zoom);
|
||||
double xTile = ((double) x31) / zm;
|
||||
double yTile = ((double) y31) / zm;
|
||||
return getPixYFromTile(xTile, yTile);
|
||||
}
|
||||
|
||||
public float getPixXFromLatLon(double latitude, double longitude) {
|
||||
double xTile = MapUtils.getTileNumberX(zoom, longitude);
|
||||
|
@ -380,15 +394,15 @@ public class RotatedTileBox {
|
|||
|
||||
public QuadPointDouble getLeftTopTile(double zoom) {
|
||||
checkTileRectangleCalculated();
|
||||
return new QuadPointDouble((tileLT.x * MapUtils.getPowZoom(zoom - this.zoom)),
|
||||
return new QuadPointDouble((tileLT.x * MapUtils.getPowZoom(zoom - this.zoom)),
|
||||
(tileLT.y * MapUtils.getPowZoom(zoom - this.zoom)));
|
||||
}
|
||||
|
||||
|
||||
public QuadPointDouble getRightBottomTile(float zoom) {
|
||||
checkTileRectangleCalculated();
|
||||
return new QuadPointDouble((tileRB.x * MapUtils.getPowZoom(zoom - this.zoom)),
|
||||
(tileRB.y * MapUtils.getPowZoom(zoom - this.zoom)));
|
||||
return new QuadPointDouble((tileRB.x * MapUtils.getPowZoom(zoom - this.zoom)),
|
||||
(tileRB.y * MapUtils.getPowZoom(zoom - this.zoom)));
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -691,31 +691,21 @@ public class OsmandRegions {
|
|||
}
|
||||
}
|
||||
|
||||
public List<WorldRegion> getWoldRegionsAt(LatLon latLon) throws IOException {
|
||||
List<WorldRegion> result = new ArrayList<>();
|
||||
List<BinaryMapDataObject> mapDataObjects = getBinaryMapDataObjectsAt(latLon);
|
||||
for (BinaryMapDataObject obj : mapDataObjects) {
|
||||
String fullName = getFullName(obj);
|
||||
if (fullName != null) {
|
||||
WorldRegion reg = getRegionData(fullName);
|
||||
if (reg != null) {
|
||||
result.add(reg);
|
||||
}
|
||||
}
|
||||
}
|
||||
return result;
|
||||
public List<WorldRegion> getWorldRegionsAt(LatLon latLon) throws IOException {
|
||||
Map<WorldRegion, BinaryMapDataObject> mapDataObjects = getBinaryMapDataObjectsWithRegionsAt(latLon);
|
||||
return new ArrayList<>(mapDataObjects.keySet());
|
||||
}
|
||||
|
||||
public BinaryMapDataObject getSmallestBinaryMapDataObjectAt(LatLon latLon) throws IOException {
|
||||
List<BinaryMapDataObject> mapDataObjects = getBinaryMapDataObjectsAt(latLon);
|
||||
return getSmallestBinaryMapDataObjectAt(mapDataObjects);
|
||||
public Map.Entry<WorldRegion, BinaryMapDataObject> getSmallestBinaryMapDataObjectAt(LatLon latLon) throws IOException {
|
||||
Map<WorldRegion, BinaryMapDataObject> mapDataObjectsWithRegions = getBinaryMapDataObjectsWithRegionsAt(latLon);
|
||||
return getSmallestBinaryMapDataObjectAt(mapDataObjectsWithRegions);
|
||||
}
|
||||
|
||||
public BinaryMapDataObject getSmallestBinaryMapDataObjectAt(List<BinaryMapDataObject> mapDataObjects) {
|
||||
BinaryMapDataObject res = null;
|
||||
public Map.Entry<WorldRegion, BinaryMapDataObject> getSmallestBinaryMapDataObjectAt(Map<WorldRegion, BinaryMapDataObject> mapDataObjectsWithRegions) {
|
||||
Map.Entry<WorldRegion, BinaryMapDataObject> res = null;
|
||||
double smallestArea = -1;
|
||||
for (BinaryMapDataObject o : mapDataObjects) {
|
||||
double area = OsmandRegions.getArea(o);
|
||||
for (Map.Entry<WorldRegion, BinaryMapDataObject> o : mapDataObjectsWithRegions.entrySet()) {
|
||||
double area = OsmandRegions.getArea(o.getValue());
|
||||
if (smallestArea == -1) {
|
||||
smallestArea = area;
|
||||
res = o;
|
||||
|
@ -727,10 +717,10 @@ public class OsmandRegions {
|
|||
return res;
|
||||
}
|
||||
|
||||
private List<BinaryMapDataObject> getBinaryMapDataObjectsAt(LatLon latLon) throws IOException {
|
||||
private Map<WorldRegion, BinaryMapDataObject> getBinaryMapDataObjectsWithRegionsAt(LatLon latLon) throws IOException {
|
||||
int point31x = MapUtils.get31TileNumberX(latLon.getLongitude());
|
||||
int point31y = MapUtils.get31TileNumberY(latLon.getLatitude());
|
||||
|
||||
Map<WorldRegion, BinaryMapDataObject> foundObjects = new LinkedHashMap<>();
|
||||
List<BinaryMapDataObject> mapDataObjects;
|
||||
try {
|
||||
mapDataObjects = queryBboxNoInit(point31x, point31x, point31y, point31y, true);
|
||||
|
@ -743,25 +733,18 @@ public class OsmandRegions {
|
|||
while (it.hasNext()) {
|
||||
BinaryMapDataObject o = it.next();
|
||||
if (o.getTypes() != null) {
|
||||
boolean isRegion = true;
|
||||
for (int i = 0; i < o.getTypes().length; i++) {
|
||||
TagValuePair tp = o.getMapIndex().decodeType(o.getTypes()[i]);
|
||||
if ("boundary".equals(tp.value)) {
|
||||
isRegion = false;
|
||||
break;
|
||||
}
|
||||
}
|
||||
WorldRegion downloadRegion = getRegionData(getFullName(o));
|
||||
if (!isRegion
|
||||
|| downloadRegion == null
|
||||
if ( downloadRegion == null
|
||||
|| !downloadRegion.isRegionMapDownload()
|
||||
|| !contain(o, point31x, point31y)) {
|
||||
it.remove();
|
||||
} else {
|
||||
foundObjects.put(downloadRegion, o);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return mapDataObjects;
|
||||
return foundObjects;
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -5,6 +5,7 @@ import java.util.Collection;
|
|||
import java.util.Collections;
|
||||
import java.util.Comparator;
|
||||
import java.util.List;
|
||||
import java.util.PriorityQueue;
|
||||
|
||||
import net.osmand.data.LatLon;
|
||||
import net.osmand.osm.edit.Relation.RelationMember;
|
||||
|
@ -46,6 +47,18 @@ public class OsmMapUtils {
|
|||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public static LatLon getComplexPolyCenter(Collection<Node> nodes) {
|
||||
double precision = 1e-5; //where to set precision constant?
|
||||
|
||||
final List<List<LatLon>> rings = new ArrayList<>();
|
||||
List<LatLon> outerRing = new ArrayList<>();
|
||||
for (Node n : nodes) {
|
||||
outerRing.add(new LatLon(n.getLatitude(), n.getLongitude()));
|
||||
}
|
||||
rings.add(outerRing);
|
||||
return getPolylabelPoint(rings, precision);
|
||||
}
|
||||
|
||||
public static LatLon getWeightCenter(Collection<LatLon> nodes) {
|
||||
if (nodes.isEmpty()) {
|
||||
|
@ -86,7 +99,7 @@ public class OsmMapUtils {
|
|||
return null;
|
||||
}
|
||||
boolean area = w.getFirstNodeId() == w.getLastNodeId();
|
||||
LatLon ll = area ? getMathWeightCenterForNodes(nodes) : getWeightCenterForNodes(nodes);
|
||||
LatLon ll = area ? getComplexPolyCenter(nodes) : getWeightCenterForNodes(nodes);
|
||||
if(ll == null) {
|
||||
return null;
|
||||
}
|
||||
|
@ -107,6 +120,7 @@ public class OsmMapUtils {
|
|||
}
|
||||
|
||||
return new LatLon(flat, flon);
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
@ -436,6 +450,177 @@ public class OsmMapUtils {
|
|||
|
||||
return Math.abs(area) / 2;
|
||||
}
|
||||
|
||||
/**
|
||||
* Calculate "visual" center point of polygons (based on Mapbox' polylabel algorithm)
|
||||
* @param rings - list of lists of nodes
|
||||
* @param precision - precision of calculation, should be small, like 1e-4 or less.
|
||||
* @return coordinates of calculated center
|
||||
*/
|
||||
|
||||
private static LatLon getPolylabelPoint(List<List<LatLon>> rings, double precision) {
|
||||
// find the bounding box of the outer ring
|
||||
double minX = Double.MAX_VALUE;
|
||||
double minY = Double.MAX_VALUE;
|
||||
double maxX = -Double.MAX_VALUE;
|
||||
double maxY = -Double.MAX_VALUE;
|
||||
List<LatLon> outerRingCoordinates = rings.get(0);
|
||||
for (LatLon p: outerRingCoordinates) {
|
||||
double lat = p.getLatitude();
|
||||
double lon = p.getLongitude();
|
||||
|
||||
minX = StrictMath.min(minX, lon);
|
||||
minY = StrictMath.min(minY, lat);
|
||||
maxX = StrictMath.max(maxX, lon);
|
||||
maxY = StrictMath.max(maxY, lat);
|
||||
}
|
||||
|
||||
double width = maxX - minX;
|
||||
double height = maxY - minY;
|
||||
double cellSize = Math.min(width, height);
|
||||
double h = cellSize / 2;
|
||||
|
||||
if (cellSize == 0) return new LatLon(minX, minY);
|
||||
|
||||
// a priority queue of cells in order of their "potential" (max distance to polygon)
|
||||
PriorityQueue<Cell> cellQueue = new PriorityQueue<>(new CellComparator());
|
||||
|
||||
// cover polygon with initial cells
|
||||
for (double x = minX; x < maxX; x += cellSize) {
|
||||
for (double y = minY; y < maxY; y += cellSize) {
|
||||
cellQueue.add(new Cell(x + h, y + h, h, rings));
|
||||
}
|
||||
}
|
||||
|
||||
// take centroid as the first best guess
|
||||
Cell bestCell = getCentroidCell(rings);
|
||||
|
||||
// special case for rectangular polygons
|
||||
Cell bboxCell = new Cell(minX + width / 2, minY + height / 2, 0, rings);
|
||||
if (bboxCell.d > bestCell.d) bestCell = bboxCell;
|
||||
|
||||
while (!cellQueue.isEmpty()) {
|
||||
// pick the most promising cell from the queue
|
||||
Cell cell = cellQueue.poll();
|
||||
|
||||
// update the best cell if we found a better one
|
||||
if (cell.d > bestCell.d) {
|
||||
bestCell = cell;
|
||||
}
|
||||
|
||||
// do not drill down further if there's no chance of a better solution
|
||||
// System.out.println(String.format("check for precision: cell.max - bestCell.d = %f Precision: %f", cell.max, precision));
|
||||
if (cell.max - bestCell.d <= precision) continue;
|
||||
|
||||
// split the cell into four cells
|
||||
h = cell.h / 2;
|
||||
cellQueue.add(new Cell(cell.x - h, cell.y - h, h, rings));
|
||||
cellQueue.add(new Cell(cell.x + h, cell.y - h, h, rings));
|
||||
cellQueue.add(new Cell(cell.x - h, cell.y + h, h, rings));
|
||||
cellQueue.add(new Cell(cell.x + h, cell.y + h, h, rings));
|
||||
}
|
||||
// System.out.println(String.format("Best lat/lon: %f, %f", bestCell.y, bestCell.x));
|
||||
return new LatLon(bestCell.y, bestCell.x);
|
||||
}
|
||||
|
||||
// get polygon centroid
|
||||
private static Cell getCentroidCell(List<List<LatLon>> rings) {
|
||||
double area = 0;
|
||||
double x = 0;
|
||||
double y = 0;
|
||||
|
||||
List<LatLon> points = rings.get(0);
|
||||
for (int i = 0, len = points.size(), j = len - 1; i < len; j = i++) {
|
||||
LatLon a = points.get(i);
|
||||
LatLon b = points.get(j);
|
||||
double aLon = a.getLongitude();
|
||||
double aLat = a.getLatitude();
|
||||
double bLon = b.getLongitude();
|
||||
double bLat = b.getLatitude();
|
||||
|
||||
double f = aLon * bLat - bLon * aLat;
|
||||
x += (aLon + bLon) * f;
|
||||
y += (aLat + bLat) * f;
|
||||
area += f * 3;
|
||||
}
|
||||
|
||||
if (area == 0) {
|
||||
LatLon p = points.get(0);
|
||||
return new Cell(p.getLatitude(), p.getLongitude(), 0, rings);
|
||||
}
|
||||
|
||||
return new Cell(x / area, y / area, 0, rings);
|
||||
}
|
||||
|
||||
private static class CellComparator implements Comparator<Cell> {
|
||||
@Override
|
||||
public int compare(Cell o1, Cell o2) {
|
||||
return Double.compare(o2.max, o1.max);
|
||||
}
|
||||
}
|
||||
|
||||
private static class Cell {
|
||||
private final double x; // cell center x (lon)
|
||||
private final double y; // cell center y (lat)
|
||||
private final double h; // half the cell size
|
||||
private final double d; // distance from cell center to polygon
|
||||
private final double max; // max distance to polygon within a cell
|
||||
|
||||
private Cell(double x, double y, double h, List<List<LatLon>> rings) {
|
||||
this.x = x;
|
||||
this.y = y;
|
||||
this.h = h;
|
||||
this.d = pointToPolygonDist(x, y, rings);
|
||||
this.max = this.d + this.h * Math.sqrt(2);
|
||||
}
|
||||
|
||||
// signed distance from point to polygon outline (negative if point is outside)
|
||||
private double pointToPolygonDist(double x, double y, List<List<LatLon>> rings) {
|
||||
boolean inside = false;
|
||||
double minDistSq = Double.MAX_VALUE;
|
||||
|
||||
for (List<LatLon> ring: rings) {
|
||||
for (int i = 0, len = ring.size(), j = len - 1; i < len; j = i++) {
|
||||
LatLon a = ring.get(i);
|
||||
LatLon b = ring.get(j);
|
||||
double aLon = a.getLongitude();
|
||||
double aLat = a.getLatitude();
|
||||
double bLon = b.getLongitude();
|
||||
double bLat = b.getLatitude();
|
||||
|
||||
if ((aLat > y != bLat > y) && (x < (bLon - aLon) * (y - aLat) / (bLat - aLat) + aLon)) {
|
||||
inside = !inside;
|
||||
}
|
||||
|
||||
minDistSq = Math.min(minDistSq, getSegmentDistanceSqared(x, y, a, b));
|
||||
}
|
||||
}
|
||||
return (inside ? 1 : -1) * Math.sqrt(minDistSq);
|
||||
}
|
||||
|
||||
// get squared distance from a point to a segment of polygon
|
||||
private double getSegmentDistanceSqared(double px, double py, LatLon a, LatLon b) {
|
||||
double x = a.getLongitude();
|
||||
double y = a.getLatitude();
|
||||
double dx = b.getLongitude() - x;
|
||||
double dy = b.getLatitude() - y;
|
||||
|
||||
if (dx != 0 || dy != 0) {
|
||||
double t = ((px - x) * dx + (py - y) * dy) / (dx * dx + dy * dy);
|
||||
|
||||
if (t > 1) {
|
||||
x = b.getLongitude();
|
||||
y = b.getLatitude();
|
||||
} else if (t > 0) {
|
||||
x += dx * t;
|
||||
y += dy * t;
|
||||
}
|
||||
}
|
||||
|
||||
dx = px - x;
|
||||
dy = py - y;
|
||||
|
||||
return dx * dx + dy * dy;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -11,6 +11,9 @@ import net.osmand.data.QuadPoint;
|
|||
import net.osmand.data.QuadRect;
|
||||
import net.osmand.util.GeoPointParserUtil.GeoParsedPoint;
|
||||
|
||||
import static com.jwetherell.openmap.common.MoreMath.QUAD_PI;
|
||||
import static com.jwetherell.openmap.common.MoreMath.QUAD_PI_D;
|
||||
|
||||
|
||||
/**
|
||||
* This utility class includes :
|
||||
|
@ -169,11 +172,11 @@ public class MapUtils {
|
|||
}
|
||||
|
||||
public static double get31LongitudeX(int tileX) {
|
||||
return MapUtils.getLongitudeFromTile(21, tileX / 1024f);
|
||||
return MapUtils.getLongitudeFromTile(21, tileX / 1024.0);
|
||||
}
|
||||
|
||||
public static double get31LatitudeY(int tileY) {
|
||||
return MapUtils.getLatitudeFromTile(21, tileY / 1024f);
|
||||
return MapUtils.getLatitudeFromTile(21, tileY / 1024.0);
|
||||
}
|
||||
|
||||
|
||||
|
@ -633,6 +636,31 @@ public class MapUtils {
|
|||
|| (l1 != null && l2 != null && Math.abs(l1.getLatitude() - l2.getLatitude()) < 0.00001
|
||||
&& Math.abs(l1.getLongitude() - l2.getLongitude()) < 0.00001);
|
||||
}
|
||||
|
||||
public static LatLon rhumbDestinationPoint(LatLon latLon, double distance, double bearing)
|
||||
{
|
||||
double radius = 6371e3;
|
||||
|
||||
double d = distance / radius; // angular distance in radians
|
||||
double phi1 = Math.toRadians(latLon.getLatitude());
|
||||
double lambda1 = Math.toRadians(latLon.getLongitude());
|
||||
double theta = Math.toRadians(bearing);
|
||||
|
||||
double deltaPhi = d * Math.cos(theta);
|
||||
double phi2 = phi1 + deltaPhi;
|
||||
|
||||
// check for some daft bugger going past the pole, normalise latitude if so
|
||||
//if (ABS(phi2) > M_PI_2)
|
||||
// phi2 = phi2>0 ? M_PI-phi2 : -M_PI-phi2;
|
||||
|
||||
double deltaPsi = Math.log(Math.tan(phi2 / 2 + QUAD_PI_D) / Math.tan(phi1 / 2 + QUAD_PI_D));
|
||||
double q = Math.abs(deltaPsi) > 10e-12 ? deltaPhi / deltaPsi : Math.cos(phi1); // E-W course becomes incorrect with 0/0
|
||||
|
||||
double deltalambda = d * Math.sin(theta) / q;
|
||||
double lambda2 = lambda1 + deltalambda;
|
||||
|
||||
return new LatLon(Math.toDegrees(phi2), Math.toDegrees(lambda2));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -15,7 +15,7 @@
|
|||
android:name="net.osmand.telegram.TelegramApplication"
|
||||
android:allowBackup="true"
|
||||
android:icon="@mipmap/ic_launcher"
|
||||
android:label="@string/app_name"
|
||||
android:label="@string/app_name_short"
|
||||
android:launchMode="singleTask"
|
||||
android:screenOrientation="unspecified"
|
||||
android:supportsRtl="true"
|
||||
|
|
|
@ -262,4 +262,9 @@
|
|||
<string name="shared_string_suggested">Cunsigiadu</string>
|
||||
<string name="status_widget_title">Istadu de s\'arrastadore de OsmAnd</string>
|
||||
<string name="back_to_osmand">Torra a OsmAnd</string>
|
||||
<string name="last_update_from_telegram_date">Ùrtimu agiornamentu dae Telegram: %1$s</string>
|
||||
<string name="last_response_date">Ùrtima risposta: %1$s</string>
|
||||
<string name="last_update_from_telegram_duration">Ùrtimu agiornamentu dae Telegram: %1$s a como</string>
|
||||
<string name="last_response_duration">Ùrtima risposta: %1$s a como</string>
|
||||
<string name="duration_ago">%1$s a como</string>
|
||||
</resources>
|
|
@ -7,6 +7,11 @@ import android.content.Intent
|
|||
class InitAppBroadcastReceiver : BroadcastReceiver() {
|
||||
|
||||
override fun onReceive(context: Context, intent: Intent) {
|
||||
// do nothing, TelegramApplication already initialized
|
||||
// check if aidl connection was lost
|
||||
val app = context.applicationContext as TelegramApplication
|
||||
val aidlHelper = app.osmandAidlHelper
|
||||
if (aidlHelper.isOsmandBound() && !aidlHelper.isOsmandConnected()) {
|
||||
aidlHelper.connectOsmand()
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -42,7 +42,7 @@ class TelegramApplication : Application() {
|
|||
telegramHelper.messageActiveTimeSec = settings.locHistoryTime
|
||||
uiUtils = UiUtils(this)
|
||||
osmandAidlHelper = OsmandAidlHelper(this)
|
||||
osmandAidlHelper.listener = object : OsmandHelperListener {
|
||||
osmandAidlHelper.addConnectionListener(object : OsmandHelperListener {
|
||||
override fun onOsmandConnectionStateChanged(connected: Boolean) {
|
||||
if (connected) {
|
||||
osmandAidlHelper.clearNavDrawerItems("net.osmand.telegram")
|
||||
|
@ -60,7 +60,7 @@ class TelegramApplication : Application() {
|
|||
showLocationHelper.addOrUpdateStatusWidget(-1, false)
|
||||
}
|
||||
}
|
||||
}
|
||||
})
|
||||
osmandAidlHelper.setUpdatesListener(object : UpdatesListener {
|
||||
override fun update() {
|
||||
if (settings.hasAnyChatToShowOnMap()) {
|
||||
|
|
|
@ -109,10 +109,11 @@ class TelegramService : Service(), LocationListener, TelegramIncomingMessagesLis
|
|||
sendLocationInterval = intent.getLongExtra(SEND_LOCATION_INTERVAL, 0)
|
||||
setupServiceErrorInterval()
|
||||
|
||||
app.telegramService = this
|
||||
app.telegramHelper.addIncomingMessagesListener(this)
|
||||
app.telegramHelper.addOutgoingMessagesListener(this)
|
||||
|
||||
app.telegramService = this
|
||||
|
||||
if (isUsedByMyLocation(usedBy)) {
|
||||
initLocationUpdates()
|
||||
startShareInfoUpdates()
|
||||
|
@ -122,6 +123,7 @@ class TelegramService : Service(), LocationListener, TelegramIncomingMessagesLis
|
|||
app.telegramHelper.startLiveMessagesUpdates(app.settings.sendMyLocInterval)
|
||||
startTracksUpdates()
|
||||
}
|
||||
app.shareLocationHelper.checkAndSendBufferMessages()
|
||||
|
||||
val locationNotification = app.notificationHelper.locationNotification
|
||||
val notification = app.notificationHelper.buildNotification(locationNotification)
|
||||
|
|
|
@ -58,6 +58,8 @@ class OsmandAidlHelper(private val app: TelegramApplication) {
|
|||
const val OSMAND_NIGHTLY_PACKAGE_NAME = "net.osmand.dev"
|
||||
|
||||
const val UPDATE_TIME_MS = 5000L
|
||||
|
||||
private const val CALLBACK_INVALID_ID = -1L
|
||||
}
|
||||
|
||||
private var mIOsmAndAidlInterface: IOsmAndAidlInterface? = null
|
||||
|
@ -68,7 +70,7 @@ class OsmandAidlHelper(private val app: TelegramApplication) {
|
|||
private var osmandUpdatesCallbackId: Long = -1
|
||||
private var osmandContextMenuCallbackId: Long = -1
|
||||
|
||||
var listener: OsmandHelperListener? = null
|
||||
private val connectionListeners = HashSet<OsmandHelperListener>()
|
||||
|
||||
interface OsmandHelperListener {
|
||||
fun onOsmandConnectionStateChanged(connected: Boolean)
|
||||
|
@ -133,6 +135,14 @@ class OsmandAidlHelper(private val app: TelegramApplication) {
|
|||
}
|
||||
}
|
||||
|
||||
fun addConnectionListener(listener: OsmandHelperListener) {
|
||||
connectionListeners.add(listener)
|
||||
}
|
||||
|
||||
fun removeConnectionListener(listener: OsmandHelperListener) {
|
||||
connectionListeners.remove(listener)
|
||||
}
|
||||
|
||||
fun setSearchCompleteListener(mSearchCompleteListener: SearchCompleteListener) {
|
||||
this.mSearchCompleteListener = mSearchCompleteListener
|
||||
}
|
||||
|
@ -155,7 +165,7 @@ class OsmandAidlHelper(private val app: TelegramApplication) {
|
|||
this.mUpdatesListener = mUpdatesListener
|
||||
}
|
||||
|
||||
fun updatesCallbackRegistered() = osmandUpdatesCallbackId > 0
|
||||
fun updatesCallbackRegistered() = osmandUpdatesCallbackId > CALLBACK_INVALID_ID
|
||||
/**
|
||||
* Class for interacting with the main interface of the service.
|
||||
*/
|
||||
|
@ -169,16 +179,18 @@ class OsmandAidlHelper(private val app: TelegramApplication) {
|
|||
// representation of that from the raw service object.
|
||||
mIOsmAndAidlInterface = IOsmAndAidlInterface.Stub.asInterface(service)
|
||||
initialized = true
|
||||
//Toast.makeText(app, "OsmAnd connected", Toast.LENGTH_SHORT).show()
|
||||
listener?.onOsmandConnectionStateChanged(true)
|
||||
connectionListeners.forEach {
|
||||
it.onOsmandConnectionStateChanged(true)
|
||||
}
|
||||
}
|
||||
|
||||
override fun onServiceDisconnected(className: ComponentName) {
|
||||
// This is called when the connection with the service has been
|
||||
// unexpectedly disconnected -- that is, its process crashed.
|
||||
mIOsmAndAidlInterface = null
|
||||
//Toast.makeText(app, "OsmAnd disconnected", Toast.LENGTH_SHORT).show()
|
||||
listener?.onOsmandConnectionStateChanged(false)
|
||||
connectionListeners.forEach {
|
||||
it.onOsmandConnectionStateChanged(false)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -193,7 +205,7 @@ class OsmandAidlHelper(private val app: TelegramApplication) {
|
|||
fun isOsmandConnected(): Boolean {
|
||||
return mIOsmAndAidlInterface != null
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get list of active GPX files.
|
||||
*
|
||||
|
@ -1162,20 +1174,20 @@ class OsmandAidlHelper(private val app: TelegramApplication) {
|
|||
if (mIOsmAndAidlInterface != null) {
|
||||
try {
|
||||
osmandUpdatesCallbackId = mIOsmAndAidlInterface!!.registerForUpdates(UPDATE_TIME_MS, mIOsmAndAidlCallback)
|
||||
return osmandUpdatesCallbackId > 0
|
||||
return osmandUpdatesCallbackId > CALLBACK_INVALID_ID
|
||||
} catch (e: RemoteException) {
|
||||
e.printStackTrace()
|
||||
}
|
||||
}
|
||||
return false
|
||||
}
|
||||
|
||||
|
||||
fun unregisterFromUpdates(): Boolean {
|
||||
if (mIOsmAndAidlInterface != null) {
|
||||
try {
|
||||
val unregistered = mIOsmAndAidlInterface!!.unregisterFromUpdates(osmandUpdatesCallbackId)
|
||||
if (unregistered) {
|
||||
osmandUpdatesCallbackId = 0
|
||||
osmandUpdatesCallbackId = CALLBACK_INVALID_ID
|
||||
}
|
||||
return unregistered
|
||||
} catch (e: RemoteException) {
|
||||
|
@ -1222,7 +1234,7 @@ class OsmandAidlHelper(private val app: TelegramApplication) {
|
|||
val params = RemoveContextMenuButtonsParams(paramsId, osmandContextMenuCallbackId)
|
||||
val removed = mIOsmAndAidlInterface!!.removeContextMenuButtons(params)
|
||||
if (removed) {
|
||||
osmandContextMenuCallbackId = -1
|
||||
osmandContextMenuCallbackId = CALLBACK_INVALID_ID
|
||||
}
|
||||
return removed
|
||||
} catch (e: RemoteException) {
|
||||
|
|
|
@ -1,5 +1,7 @@
|
|||
package net.osmand.telegram.helpers
|
||||
|
||||
import android.os.Handler
|
||||
import android.os.Message
|
||||
import net.osmand.Location
|
||||
import net.osmand.PlatformUtil
|
||||
import net.osmand.telegram.*
|
||||
|
@ -16,7 +18,9 @@ import org.json.JSONObject
|
|||
private const val USER_SET_LIVE_PERIOD_DELAY_MS = 5000 // 5 sec
|
||||
|
||||
private const val MIN_MESSAGE_SENDING_INTERVAL_MS = 1000 // 1 sec
|
||||
private const val MIN_MESSAGES_BUFFER_CHECK_INTERVAL_MS = 800 // 0.8 sec
|
||||
private const val MIN_MESSAGES_BUFFER_CHECK_INTERVAL_MS = 300 // 0.3 sec
|
||||
|
||||
private const val SEND_MESSAGES_BUFFER_MS_MSG_ID = 5000
|
||||
|
||||
class ShareLocationHelper(private val app: TelegramApplication) {
|
||||
|
||||
|
@ -52,6 +56,9 @@ class ShareLocationHelper(private val app: TelegramApplication) {
|
|||
|
||||
private var lastTimeInMillis: Long = 0L
|
||||
|
||||
private var sendBufferMessagesHandler = Handler()
|
||||
private var sendBufferMessagesRunnable = Runnable { app.shareLocationHelper.checkAndSendBufferMessages(false) }
|
||||
|
||||
fun updateLocation(location: Location?) {
|
||||
val lastPoint = lastLocation
|
||||
var record = true
|
||||
|
@ -120,7 +127,7 @@ class ShareLocationHelper(private val app: TelegramApplication) {
|
|||
}
|
||||
}
|
||||
|
||||
fun checkAndSendBufferMessages() {
|
||||
fun checkAndSendBufferMessages(checkNetworkTypeAllowed: Boolean = true) {
|
||||
log.debug("checkAndSendBufferMessages")
|
||||
var pendingMessagesLimitReached = false
|
||||
app.settings.getChatsShareInfo().forEach { (chatId, shareInfo) ->
|
||||
|
@ -129,18 +136,30 @@ class ShareLocationHelper(private val app: TelegramApplication) {
|
|||
pendingMessagesLimitReached = true
|
||||
}
|
||||
}
|
||||
if (pendingMessagesLimitReached) {
|
||||
if (pendingMessagesLimitReached && checkNetworkTypeAllowed) {
|
||||
checkNetworkType()
|
||||
}
|
||||
}
|
||||
|
||||
fun checkAndSendBufferMessagesDelayed() {
|
||||
if (!sendBufferMessagesHandler.hasMessages(SEND_MESSAGES_BUFFER_MS_MSG_ID)) {
|
||||
val msg = Message.obtain(sendBufferMessagesHandler, sendBufferMessagesRunnable)
|
||||
msg.what = SEND_MESSAGES_BUFFER_MS_MSG_ID
|
||||
sendBufferMessagesHandler.sendMessageDelayed(msg, MIN_MESSAGES_BUFFER_CHECK_INTERVAL_MS.toLong() + 1L)
|
||||
}
|
||||
}
|
||||
|
||||
fun checkAndSendBufferMessagesToChat(chatId: Long, forced: Boolean = false): Int {
|
||||
val shareChatsInfo = app.settings.getChatsShareInfo()
|
||||
val shareInfo = shareChatsInfo[chatId]
|
||||
if (shareInfo != null) {
|
||||
val bufferedMessagesCount = app.locationMessages.getBufferedMessagesCountForChat(chatId)
|
||||
if (bufferedMessagesCount > 0) {
|
||||
checkAndSendBufferMessagesDelayed()
|
||||
}
|
||||
val currentTime = System.currentTimeMillis()
|
||||
if (currentTime - shareInfo.lastBufferCheckTime < MIN_MESSAGES_BUFFER_CHECK_INTERVAL_MS && !forced) {
|
||||
return app.locationMessages.getBufferedMessagesCountForChat(chatId)
|
||||
return bufferedMessagesCount
|
||||
}
|
||||
shareInfo.lastBufferCheckTime = currentTime
|
||||
|
||||
|
@ -182,7 +201,9 @@ class ShareLocationHelper(private val app: TelegramApplication) {
|
|||
|
||||
refreshNotification()
|
||||
|
||||
checkAndSendBufferMessages()
|
||||
if (app.telegramService != null) {
|
||||
checkAndSendBufferMessages()
|
||||
}
|
||||
} else {
|
||||
app.forceUpdateMyLocation()
|
||||
}
|
||||
|
|
|
@ -77,6 +77,15 @@ class ShowLocationHelper(private val app: TelegramApplication) {
|
|||
private var forcedStop: Boolean = false
|
||||
|
||||
init {
|
||||
app.osmandAidlHelper.addConnectionListener(object : OsmandAidlHelper.OsmandHelperListener {
|
||||
override fun onOsmandConnectionStateChanged(connected: Boolean) {
|
||||
if (!connected && showingLocation && !app.settings.monitoringEnabled) {
|
||||
if (isUseOsmandCallback() && app.osmandAidlHelper.updatesCallbackRegistered()) {
|
||||
showingLocation = false
|
||||
}
|
||||
}
|
||||
}
|
||||
})
|
||||
app.osmandAidlHelper.setContextMenuButtonsListener(object : ContextMenuButtonsListener {
|
||||
|
||||
override fun onContextMenuButtonClicked(buttonId: Int, pointId: String, layerId: String) {
|
||||
|
@ -137,7 +146,7 @@ class ShowLocationHelper(private val app: TelegramApplication) {
|
|||
osmandAidlHelper.showMapPoint(MAP_LAYER_ID, pointId, name, name, item.chatTitle, Color.WHITE, aLatLon, details, params)
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
fun updateLocationsOnMap() {
|
||||
osmandAidlHelper.execOsmandApi {
|
||||
val messages = telegramHelper.getMessages()
|
||||
|
@ -427,7 +436,7 @@ class ShowLocationHelper(private val app: TelegramApplication) {
|
|||
forcedStop = force
|
||||
if (showingLocation) {
|
||||
showingLocation = false
|
||||
if (isUseOsmandCallback() && app.osmandAidlHelper.updatesCallbackRegistered()) {
|
||||
if (isUseOsmandCallback() && osmandAidlHelper.updatesCallbackRegistered()) {
|
||||
osmandAidlHelper.unregisterFromUpdates()
|
||||
} else if (!app.settings.monitoringEnabled) {
|
||||
app.stopUserLocationService()
|
||||
|
|
|
@ -391,7 +391,6 @@
|
|||
<activity android:name="net.osmand.plus.activities.SettingsGeneralActivity" android:configChanges="keyboardHidden|orientation" />
|
||||
<activity android:name="net.osmand.plus.activities.SettingsNavigationActivity" android:configChanges="keyboardHidden|orientation" />
|
||||
<activity android:name="net.osmand.plus.monitoring.SettingsMonitoringActivity" android:configChanges="keyboardHidden|orientation" />
|
||||
<activity android:name="net.osmand.plus.rastermaps.SettingsRasterMapsActivity" android:configChanges="keyboardHidden|orientation" />
|
||||
|
||||
<activity android:name="net.osmand.plus.osmedit.SettingsOsmEditingActivity" android:configChanges="keyboardHidden|orientation" />
|
||||
<activity android:name="net.osmand.plus.development.SettingsDevelopmentActivity" android:configChanges="keyboardHidden|orientation" />
|
||||
|
@ -986,15 +985,6 @@
|
|||
|
||||
<receiver android:name="net.osmand.plus.liveupdates.LiveUpdatesAlarmReceiver"/>
|
||||
|
||||
<activity
|
||||
android:configChanges="keyboardHidden|orientation"
|
||||
android:label="Application profiles"
|
||||
android:name=".profiles.SettingsProfileActivity"/>
|
||||
|
||||
<activity
|
||||
android:name=".profiles.EditProfileActivity"
|
||||
android:label="Application profiles"/>
|
||||
|
||||
<activity android:name=".activities.PrivacyAndSecurityActivity"
|
||||
android:configChanges="keyboardHidden|orientation" />
|
||||
|
||||
|
|
|
@ -30,22 +30,27 @@
|
|||
android:orientation="horizontal"
|
||||
android:paddingLeft="@dimen/list_content_padding">
|
||||
|
||||
<CheckBox
|
||||
android:id="@+id/toggle_item"
|
||||
<FrameLayout
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_gravity="center_vertical"
|
||||
android:layout_marginRight="@dimen/list_content_padding"
|
||||
android:focusable="false"
|
||||
android:visibility="gone"
|
||||
tools:visibility="visible"/>
|
||||
android:layout_height="match_parent">
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/favourite_icon"
|
||||
android:layout_width="@dimen/standard_icon_size"
|
||||
android:layout_height="@dimen/standard_icon_size"
|
||||
android:layout_gravity="center_vertical"
|
||||
android:layout_marginRight="@dimen/list_content_padding"/>
|
||||
<CheckBox
|
||||
android:id="@+id/toggle_item"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_gravity="center_vertical"
|
||||
android:layout_marginRight="@dimen/list_content_padding"
|
||||
android:focusable="false"
|
||||
android:visibility="gone"
|
||||
tools:visibility="visible" />
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/favourite_icon"
|
||||
android:layout_width="34dp"
|
||||
android:layout_height="34dp"
|
||||
android:layout_gravity="center_vertical"
|
||||
android:layout_marginRight="@dimen/guide_line_vertical_offset" />
|
||||
</FrameLayout>
|
||||
|
||||
<LinearLayout
|
||||
android:layout_width="0dp"
|
||||
|
|
|
@ -1,576 +0,0 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||
xmlns:tools="http://schemas.android.com/tools"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
android:background="?attr/activity_background_color"
|
||||
android:orientation="vertical">
|
||||
|
||||
<android.support.design.widget.AppBarLayout
|
||||
android:id="@+id/appbar"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content">
|
||||
|
||||
<android.support.v7.widget.Toolbar
|
||||
android:id="@+id/toolbar"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="@dimen/toolbar_height"
|
||||
android:background="?attr/actionModeBackground"
|
||||
app:contentInsetLeft="0dp"
|
||||
app:contentInsetStart="0dp">
|
||||
|
||||
<LinearLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content">
|
||||
|
||||
<ImageButton
|
||||
android:id="@+id/close_button"
|
||||
style="@style/Widget.AppCompat.Toolbar.Button.Navigation"
|
||||
android:layout_width="@dimen/toolbar_height"
|
||||
android:layout_height="@dimen/toolbar_height"
|
||||
android:contentDescription="@string/access_shared_string_navigate_up"
|
||||
android:src="@drawable/ic_action_mode_back" />
|
||||
|
||||
<net.osmand.plus.widgets.TextViewEx
|
||||
android:id="@+id/toolbar_title"
|
||||
android:layout_width="0dp"
|
||||
android:layout_height="match_parent"
|
||||
android:layout_weight="1"
|
||||
android:gravity="center_vertical"
|
||||
android:paddingLeft="@dimen/content_padding"
|
||||
android:paddingRight="@dimen/content_padding"
|
||||
android:textColor="?attr/app_bar_primary_item_color"
|
||||
android:textSize="@dimen/dialog_header_text_size"
|
||||
app:typeface="@string/font_roboto_medium"
|
||||
tools:text="@string/routing_settings_2" />
|
||||
|
||||
<ImageButton
|
||||
android:id="@+id/delete_button"
|
||||
style="@style/Widget.AppCompat.Toolbar.Button.Navigation"
|
||||
android:layout_width="@dimen/toolbar_height"
|
||||
android:layout_height="@dimen/toolbar_height"
|
||||
android:contentDescription="@string/shared_string_delete"
|
||||
android:src="@drawable/ic_action_delete_dark" />
|
||||
|
||||
</LinearLayout>
|
||||
|
||||
</android.support.v7.widget.Toolbar>
|
||||
|
||||
</android.support.design.widget.AppBarLayout>
|
||||
|
||||
<FrameLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
android:background="?attr/activity_background_color">
|
||||
|
||||
<ScrollView
|
||||
android:id="@+id/scroll_view_container"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginBottom="@dimen/setting_profile_item_height"
|
||||
android:layout_gravity="top"
|
||||
android:focusable="true"
|
||||
android:focusableInTouchMode="true">
|
||||
|
||||
<LinearLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:orientation="vertical">
|
||||
|
||||
<LinearLayout
|
||||
android:id="@+id/type_selection_button"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:background="?attr/bg_color"
|
||||
android:clickable="true"
|
||||
android:focusable="true"
|
||||
android:foreground="?attr/selectableItemBackground"
|
||||
android:orientation="vertical">
|
||||
|
||||
<LinearLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="64dp"
|
||||
android:paddingStart="@dimen/content_padding"
|
||||
android:paddingEnd="@dimen/content_padding_small"
|
||||
android:paddingLeft="@dimen/content_padding"
|
||||
android:paddingRight="@dimen/content_padding_small"
|
||||
android:orientation="horizontal">
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/mode_icon"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginEnd="@dimen/bottom_sheet_icon_margin"
|
||||
android:layout_marginRight="@dimen/bottom_sheet_icon_margin"
|
||||
android:layout_gravity="center_vertical"
|
||||
android:tint="?attr/default_icon_color"
|
||||
tools:src="@drawable/ic_action_coordinates_latitude"/>
|
||||
|
||||
<LinearLayout
|
||||
android:layout_width="0dp"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_weight="1"
|
||||
android:layout_marginEnd="@dimen/content_padding"
|
||||
android:layout_marginRight="@dimen/content_padding"
|
||||
android:layout_gravity="center_vertical"
|
||||
android:gravity="center_vertical"
|
||||
android:orientation="vertical">
|
||||
|
||||
<TextView
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:textColor="?android:textColorPrimary"
|
||||
android:ellipsize="end"
|
||||
android:maxLines="1"
|
||||
android:text="@string/profile_type_base_string"/>
|
||||
|
||||
<TextView
|
||||
android:id="@+id/mode_title"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:ellipsize="end"
|
||||
android:maxLines="1"
|
||||
android:textColor="?android:textColorPrimary"
|
||||
android:textSize="18sp"
|
||||
tools:text="Item additional description"/>
|
||||
|
||||
</LinearLayout>
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/type_down_arrow2"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_weight="0"
|
||||
android:layout_gravity="center_vertical"
|
||||
android:src="@drawable/ic_action_arrow_drop_down"
|
||||
android:tint="@color/settings_divider"/>
|
||||
|
||||
</LinearLayout>
|
||||
|
||||
</LinearLayout>
|
||||
|
||||
|
||||
<LinearLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:background="?attr/activity_background_color"
|
||||
android:orientation="vertical">
|
||||
|
||||
<ImageView
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:scaleType="fitXY"
|
||||
android:src="@drawable/bg_shadow_list_bottom"/>
|
||||
|
||||
<View
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="10dp"/>
|
||||
|
||||
<ImageView
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:scaleType="fitXY"
|
||||
android:src="@drawable/bg_shadow_list_top"/>
|
||||
|
||||
</LinearLayout>
|
||||
|
||||
<LinearLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:background="?attr/bg_color"
|
||||
android:orientation="vertical">
|
||||
|
||||
<FrameLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content">
|
||||
|
||||
<LinearLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:gravity="center_vertical"
|
||||
android:orientation="horizontal">
|
||||
|
||||
|
||||
<net.osmand.plus.widgets.OsmandTextFieldBoxes
|
||||
android:id="@+id/profile_name_otfb"
|
||||
android:layout_width="0dp"
|
||||
android:layout_height="60dp"
|
||||
android:layout_weight="1"
|
||||
android:layout_margin="@dimen/list_content_padding"
|
||||
app:primaryColor="@color/active_color_primary_dark"
|
||||
app:secondaryColor="?android:textColorSecondary"
|
||||
app:labelText="@string/profile_name_hint">
|
||||
|
||||
<studio.carbonylgroup.textfieldboxes.ExtendedEditText
|
||||
android:id="@+id/profile_name_et"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:maxLines="1"
|
||||
|
||||
tools:text="@string/lorem_ipsum"/>
|
||||
|
||||
</net.osmand.plus.widgets.OsmandTextFieldBoxes>
|
||||
|
||||
|
||||
|
||||
</LinearLayout>
|
||||
|
||||
|
||||
|
||||
</FrameLayout>
|
||||
|
||||
<FrameLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginBottom="8dp"
|
||||
android:layout_marginStart="@dimen/list_content_padding"
|
||||
android:layout_marginEnd="@dimen/list_content_padding"
|
||||
android:layout_marginLeft="@dimen/list_content_padding"
|
||||
android:layout_marginRight="@dimen/list_content_padding">
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/type_down_arrow"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_gravity="center_vertical|right"
|
||||
android:paddingRight="@dimen/content_padding"
|
||||
android:src="@drawable/ic_action_arrow_drop_down"
|
||||
android:tint="@color/settings_divider"/>
|
||||
|
||||
<net.osmand.plus.widgets.OsmandTextFieldBoxes
|
||||
android:id="@+id/master_profile_otfb"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="60dp"
|
||||
app:primaryColor="@color/active_color_primary_dark"
|
||||
app:secondaryColor="?android:textColorSecondary"
|
||||
app:labelText="@string/nav_type_hint">
|
||||
|
||||
<studio.carbonylgroup.textfieldboxes.ExtendedEditText
|
||||
android:id="@+id/master_profile_et"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:focusable="false"
|
||||
android:maxLines="1"
|
||||
|
||||
tools:text="Car"/>
|
||||
|
||||
</net.osmand.plus.widgets.OsmandTextFieldBoxes>
|
||||
|
||||
<FrameLayout
|
||||
android:id="@+id/select_nav_type_btn"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
android:clickable="true"
|
||||
android:focusable="true"/>
|
||||
|
||||
</FrameLayout>
|
||||
|
||||
<LinearLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="@dimen/context_menu_action_buttons_h"
|
||||
android:layout_marginTop="8dp"
|
||||
android:layout_marginBottom="@dimen/list_content_padding"
|
||||
android:layout_marginLeft="@dimen/list_content_padding"
|
||||
android:layout_marginRight="@dimen/list_content_padding"
|
||||
android:orientation="vertical">
|
||||
<View
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="1dp"
|
||||
android:background="?attr/divider_color"/>
|
||||
|
||||
|
||||
<LinearLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
android:orientation="horizontal"
|
||||
android:layout_gravity="center_vertical">
|
||||
|
||||
<LinearLayout
|
||||
android:id="@+id/select_icon_button"
|
||||
android:layout_width="0dp"
|
||||
android:layout_height="match_parent"
|
||||
android:background="?attr/selectableItemBackground"
|
||||
android:layout_weight="1"
|
||||
android:clickable="true"
|
||||
android:focusable="true"
|
||||
android:orientation="horizontal">
|
||||
|
||||
<TextView
|
||||
android:layout_width="0dp"
|
||||
android:layout_height="match_parent"
|
||||
android:gravity="center_vertical"
|
||||
android:layout_weight="1"
|
||||
android:textSize="@dimen/default_list_text_size"
|
||||
android:text="@string/shared_string_icon"
|
||||
android:textColor="?android:textColorPrimary"/>
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/profile_icon_img"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:padding="@dimen/list_content_padding"
|
||||
tools:src="@drawable/ic_action_horse"
|
||||
tools:tint="@color/A400red"/>
|
||||
|
||||
</LinearLayout>
|
||||
|
||||
<View
|
||||
android:layout_width="1dp"
|
||||
android:layout_height="36dp"
|
||||
android:layout_gravity="center_vertical"
|
||||
android:background="?attr/divider_color"/>
|
||||
|
||||
<LinearLayout
|
||||
android:id="@+id/select_icon_color_button"
|
||||
android:layout_width="0dp"
|
||||
android:layout_height="match_parent"
|
||||
android:layout_weight="1"
|
||||
android:background="?attr/selectableItemBackground"
|
||||
android:clickable="true"
|
||||
android:focusable="true"
|
||||
android:orientation="horizontal">
|
||||
|
||||
<TextView
|
||||
android:layout_width="0dp"
|
||||
android:paddingLeft="@dimen/list_content_padding"
|
||||
android:layout_height="match_parent"
|
||||
android:layout_weight="1"
|
||||
android:gravity="center_vertical"
|
||||
android:textSize="@dimen/default_list_text_size"
|
||||
android:text="@string/shared_string_color"
|
||||
android:textColor="?android:textColorPrimary"/>
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/color_sample_img"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:padding="@dimen/list_content_padding"
|
||||
tools:src = "@drawable/ic_action_circle"
|
||||
tools:tint="@color/A400red"/>
|
||||
|
||||
</LinearLayout>
|
||||
|
||||
</LinearLayout>
|
||||
|
||||
<View
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="1dp"
|
||||
android:background="?attr/divider_color"/>
|
||||
|
||||
</LinearLayout>
|
||||
|
||||
<TextView
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginBottom="12dp"
|
||||
android:layout_marginStart="@dimen/list_content_padding"
|
||||
android:layout_marginEnd="@dimen/list_content_padding"
|
||||
android:layout_marginLeft="@dimen/list_content_padding"
|
||||
android:layout_marginRight="@dimen/list_content_padding"
|
||||
android:text="@string/osmand_routing_promo"/>
|
||||
|
||||
<FrameLayout
|
||||
android:id="@+id/click_block_layout"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
android:clickable="false"/>
|
||||
|
||||
</LinearLayout>
|
||||
|
||||
<LinearLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:background="?attr/activity_background_color"
|
||||
android:orientation="vertical">
|
||||
|
||||
<ImageView
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:scaleType="fitXY"
|
||||
android:src="@drawable/bg_shadow_list_bottom"/>
|
||||
|
||||
<View
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="10dp"/>
|
||||
|
||||
<ImageView
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:scaleType="fitXY"
|
||||
android:src="@drawable/bg_shadow_list_top"/>
|
||||
|
||||
</LinearLayout>
|
||||
|
||||
|
||||
<LinearLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:background="?attr/bg_color"
|
||||
android:orientation="vertical">
|
||||
|
||||
<TextView
|
||||
android:textStyle="bold"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginTop="@dimen/list_content_padding"
|
||||
android:layout_marginStart="@dimen/list_content_padding"
|
||||
android:layout_marginEnd="@dimen/list_content_padding"
|
||||
android:layout_marginLeft="@dimen/list_content_padding"
|
||||
android:layout_marginRight="@dimen/list_content_padding"
|
||||
android:text="@string/edit_profile_setup_title"
|
||||
android:textColor="?android:textColorPrimary"
|
||||
android:textSize="@dimen/default_list_text_size"/>
|
||||
|
||||
<TextView
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginBottom="@dimen/list_content_padding"
|
||||
android:layout_marginStart="@dimen/list_content_padding"
|
||||
android:layout_marginEnd="@dimen/list_content_padding"
|
||||
android:layout_marginLeft="@dimen/list_content_padding"
|
||||
android:layout_marginRight="@dimen/list_content_padding"
|
||||
android:text="@string/edit_profile_setup_subtitle"
|
||||
android:textColor="@color/description_font_and_bottom_sheet_icons"/>
|
||||
|
||||
<LinearLayout
|
||||
android:id="@+id/profile_config_btn"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="65dp"
|
||||
android:background="?android:attr/selectableItemBackground"
|
||||
android:gravity="center_vertical"
|
||||
android:orientation="horizontal">
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/profile_config_icon"
|
||||
android:layout_width="24dp"
|
||||
android:layout_height="24dp"
|
||||
android:layout_marginStart="@dimen/list_content_padding"
|
||||
android:layout_marginLeft="@dimen/list_content_padding"
|
||||
android:src="@drawable/ic_action_settings"
|
||||
android:tint="?attr/default_icon_color"/>
|
||||
|
||||
<LinearLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginStart="24dp"
|
||||
android:layout_marginLeft="24dp"
|
||||
android:layout_marginEnd="@dimen/list_content_padding"
|
||||
android:layout_marginRight="@dimen/list_content_padding"
|
||||
android:orientation="vertical">
|
||||
|
||||
<TextView
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:text="@string/configure_profile"
|
||||
android:textColor="?android:textColorPrimary"
|
||||
android:textSize="@dimen/default_list_text_size"/>
|
||||
|
||||
<TextView
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:textColor="@color/description_font_and_bottom_sheet_icons"
|
||||
android:visibility="gone"
|
||||
tools:text="@string/configure_profile_info"
|
||||
tools:visibility="visible" />
|
||||
|
||||
</LinearLayout>
|
||||
</LinearLayout>
|
||||
</LinearLayout>
|
||||
|
||||
|
||||
<include layout="@layout/list_shadow_footer"/>
|
||||
|
||||
|
||||
<LinearLayout
|
||||
android:id="@+id/buttons_layout_sv"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_gravity="bottom"
|
||||
android:background="?attr/bg_color"
|
||||
android:orientation="horizontal"
|
||||
android:visibility="gone">
|
||||
|
||||
<Button
|
||||
android:id="@+id/cancel_button_sv"
|
||||
android:layout_width="0dp"
|
||||
android:layout_height="42dp"
|
||||
android:layout_weight="1"
|
||||
android:layout_marginTop="@dimen/list_content_padding"
|
||||
android:layout_marginBottom="@dimen/list_content_padding"
|
||||
android:layout_marginStart="@dimen/list_content_padding"
|
||||
android:layout_marginEnd="8dp"
|
||||
android:layout_marginLeft="@dimen/list_content_padding"
|
||||
android:layout_marginRight="8dp"
|
||||
android:background="?attr/profile_cancel_btn"
|
||||
android:text="@string/shared_string_cancel"
|
||||
android:textAllCaps="false"
|
||||
android:textColor="@color/map_widget_blue"/>
|
||||
|
||||
<Button
|
||||
android:id="@+id/save_profile_btn_sv"
|
||||
android:layout_width="0dp"
|
||||
android:layout_height="42dp"
|
||||
android:layout_weight="1"
|
||||
android:layout_marginTop="@dimen/list_content_padding"
|
||||
android:layout_marginBottom="@dimen/list_content_padding"
|
||||
android:layout_marginStart="8dp"
|
||||
android:layout_marginEnd="@dimen/list_content_padding"
|
||||
android:layout_marginLeft="8dp"
|
||||
android:layout_marginRight="@dimen/list_content_padding"
|
||||
android:background="?attr/profile_save_btn"
|
||||
android:text="@string/shared_string_save"
|
||||
android:textAllCaps="false"
|
||||
android:textColor="@color/color_white"/>
|
||||
|
||||
</LinearLayout>
|
||||
|
||||
</LinearLayout>
|
||||
|
||||
</ScrollView>
|
||||
|
||||
<LinearLayout
|
||||
android:id="@+id/buttons_layout"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_gravity="bottom"
|
||||
android:background="?attr/bg_color"
|
||||
android:orientation="horizontal">
|
||||
|
||||
<Button
|
||||
android:id="@+id/cancel_button"
|
||||
android:layout_width="0dp"
|
||||
android:layout_height="42dp"
|
||||
android:layout_weight="1"
|
||||
android:layout_marginTop="@dimen/list_content_padding"
|
||||
android:layout_marginBottom="@dimen/list_content_padding"
|
||||
android:layout_marginStart="@dimen/list_content_padding"
|
||||
android:layout_marginEnd="8dp"
|
||||
android:layout_marginLeft="@dimen/list_content_padding"
|
||||
android:layout_marginRight="8dp"
|
||||
android:background="?attr/profile_cancel_btn"
|
||||
android:text="@string/shared_string_cancel"
|
||||
android:textAllCaps="false"
|
||||
android:textColor="?attr/active_color_basic"/>
|
||||
|
||||
<Button
|
||||
android:id="@+id/save_profile_btn"
|
||||
android:layout_width="0dp"
|
||||
android:layout_height="42dp"
|
||||
android:layout_weight="1"
|
||||
android:layout_marginTop="@dimen/list_content_padding"
|
||||
android:layout_marginBottom="@dimen/list_content_padding"
|
||||
android:layout_marginStart="8dp"
|
||||
android:layout_marginEnd="@dimen/list_content_padding"
|
||||
android:layout_marginLeft="8dp"
|
||||
android:layout_marginRight="@dimen/list_content_padding"
|
||||
android:background="?attr/profile_save_btn"
|
||||
android:text="@string/shared_string_save"
|
||||
android:textAllCaps="false"
|
||||
android:textColor="@color/color_white"/>
|
||||
|
||||
</LinearLayout>
|
||||
|
||||
</FrameLayout>
|
||||
|
||||
</LinearLayout>
|
|
@ -1,66 +0,0 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
android:background="?attr/activity_background_color"
|
||||
android:orientation="vertical">
|
||||
|
||||
<android.support.design.widget.AppBarLayout
|
||||
android:id="@+id/appbar"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content">
|
||||
|
||||
<include layout="@layout/global_preference_toolbar" />
|
||||
|
||||
</android.support.design.widget.AppBarLayout>
|
||||
|
||||
<RelativeLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
android:background="?attr/list_background_color"
|
||||
android:orientation="vertical">
|
||||
|
||||
<android.support.v7.widget.RecyclerView
|
||||
android:id="@+id/profiles_list"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
|
||||
android:clipToPadding="false"
|
||||
android:paddingBottom="72dp"/>
|
||||
|
||||
<LinearLayout
|
||||
android:id="@+id/add_profile_btn"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_alignParentBottom="true"
|
||||
android:layout_alignParentRight="true"
|
||||
android:layout_alignParentEnd="true"
|
||||
android:clickable="true"
|
||||
android:focusable="true"
|
||||
android:layout_gravity="bottom|center_horizontal"
|
||||
android:background="@drawable/fab_extended_drawable"
|
||||
android:orientation="horizontal"
|
||||
android:gravity="center_vertical">
|
||||
|
||||
<android.support.v7.widget.AppCompatImageView
|
||||
android:layout_gravity="center_vertical"
|
||||
android:layout_width="24dp"
|
||||
android:layout_height="24dp"
|
||||
android:layout_marginLeft="14dp"
|
||||
android:layout_marginStart="14dp"
|
||||
android:src="@drawable/ic_action_plus"/>
|
||||
|
||||
<android.support.v7.widget.AppCompatTextView
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:text="@string/shared_string_add"
|
||||
android:textColor="@color/color_white"
|
||||
android:layout_marginRight="20dp"
|
||||
android:layout_marginEnd="20dp"
|
||||
/>
|
||||
|
||||
</LinearLayout>
|
||||
|
||||
</RelativeLayout>
|
||||
|
||||
</LinearLayout>
|
|
@ -3308,7 +3308,7 @@
|
|||
<string name="routing_attr_width_description">حدد الحد المسموح به لعرض السيارة على الطرق.</string>
|
||||
<string name="simulate_your_location_gpx_descr">محاكاة موقعك باستخدام مسار GPX مسجل.</string>
|
||||
<string name="quick_action_directions_from_desc">زر لجعل الشاشة مركز نقطة الانطلاق وحساب الطريق إلى الوجهة أو فتح مربع حوار لتحديد الوجهة إذا لم تكن علامة الوجهة علي الخريطة.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">شخصي</string>
|
||||
<string name="shared_string_downloading_formatted">تنزيل %s</string>
|
||||
|
|
|
@ -3360,7 +3360,7 @@
|
|||
<string name="add_new_profile_q">Дадаць новы профіль \"%1$s\"\?</string>
|
||||
<string name="save_heading">Захоўваць кірунак</string>
|
||||
<string name="save_heading_descr">Падчас запісу захоўваць кірунак для кожнага пункта маршруту.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Асабісты</string>
|
||||
<string name="shared_string_downloading_formatted">Спампоўванне %s</string>
|
||||
|
|
|
@ -3394,7 +3394,7 @@ Abasta l\'àrea: %1$s x %2$s</string>
|
|||
<string name="dialogs_and_notifications_descr">Emergents de control, diàlegs i notificacions que surten a OsmAnd mentre s\'utilitza.</string>
|
||||
<string name="join_segments">Uneix segments</string>
|
||||
<string name="add_new_profile_q">Voleu afegir el perfil nou \'%1$s\'\?</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Personal</string>
|
||||
<string name="shared_string_downloading_formatted">S\'està baixant %s</string>
|
||||
|
|
|
@ -3785,7 +3785,7 @@
|
|||
<string name="poi_volcano_type_maar">Maar</string>
|
||||
<string name="poi_volcano_type_caldera">Caldera</string>
|
||||
<string name="poi_volcano_type_lava_dome">Lavadome</string>
|
||||
<string name="poi_volcano_type_dirt">J́ord</string>
|
||||
<string name="poi_volcano_type_mud">J́ord</string>
|
||||
<string name="poi_volcano_last_eruption">Sidste udbrud</string>
|
||||
<string name="poi_volcano_status_extinct">Uddød</string>
|
||||
<string name="poi_volcano_status_dormant">Sovende</string>
|
||||
|
|
|
@ -3406,7 +3406,7 @@ Repræsenterer område: %1$s x %2$s</string>
|
|||
<string name="add_new_profile_q">Tilføj ny profil \'%1$s\'\?</string>
|
||||
<string name="save_heading">Medtag overskrift</string>
|
||||
<string name="save_heading_descr">Gem overskrift til hvert TrackPoint under optagelsen.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Personlig</string>
|
||||
<string name="shared_string_downloading_formatted">Henter %s</string>
|
||||
|
|
|
@ -3780,7 +3780,7 @@
|
|||
<string name="poi_volcano_type_maar">Maar</string>
|
||||
<string name="poi_volcano_type_caldera">Caldera</string>
|
||||
<string name="poi_volcano_type_lava_dome">Lavadom</string>
|
||||
<string name="poi_volcano_type_dirt">Erde</string>
|
||||
<string name="poi_volcano_type_mud">Erde</string>
|
||||
<string name="poi_volcano_last_eruption">Letzter Ausbruch</string>
|
||||
<string name="poi_volcano_status_extinct">Erloschen</string>
|
||||
<string name="poi_volcano_status_dormant">Ruhend</string>
|
||||
|
|
|
@ -3403,7 +3403,7 @@ Lon %2$s</string>
|
|||
<string name="add_new_profile_q">Neues Profil \'%1$s\' hinzufügen\?</string>
|
||||
<string name="save_heading">Richtung einbeziehen</string>
|
||||
<string name="save_heading_descr">Richtung zu jedem Trackpunkt während der Aufnahme speichern.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Persönlich</string>
|
||||
<string name="shared_string_downloading_formatted">%s herunterladen</string>
|
||||
|
|
|
@ -3399,7 +3399,7 @@
|
|||
<string name="add_new_profile_q">Προσθήκη νέας κατατομής (προφίλ) \'%1$s\';</string>
|
||||
<string name="save_heading">Συμπερίληψη κατεύθυνσης</string>
|
||||
<string name="save_heading_descr">Αποθήκευση κατεύθυνσης για κάθε σημείο ίχνους κατά την εγγραφή.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Προσωπικό</string>
|
||||
<string name="shared_string_downloading_formatted">Λήψη %s</string>
|
||||
|
|
|
@ -3770,7 +3770,7 @@
|
|||
<string name="poi_volcano_type_maar">malprofund‑kratera (maaro)</string>
|
||||
<string name="poi_volcano_type_caldera">kaldero</string>
|
||||
<string name="poi_volcano_type_lava_dome">lafkupolo</string>
|
||||
<string name="poi_volcano_type_dirt">ŝlimvulkano</string>
|
||||
<string name="poi_volcano_type_mud">ŝlimvulkano</string>
|
||||
<string name="poi_volcano_last_eruption">Antaŭa erupcio</string>
|
||||
<string name="poi_volcano_status_extinct">neaktiva</string>
|
||||
<string name="poi_volcano_status_dormant">dormanta</string>
|
||||
|
|
|
@ -3378,7 +3378,7 @@ Indikas lokon: %1$s x %2$s"</string>
|
|||
<string name="add_new_profile_q">Ĉu aldoni novan profilon “%1$s”\?</string>
|
||||
<string name="save_heading">Inkluzivi direkton</string>
|
||||
<string name="save_heading_descr">Konservi direkton al ĉiu punkto de kurso dum registri.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Personaj</string>
|
||||
<string name="shared_string_downloading_formatted">Elŝutado de %s</string>
|
||||
|
@ -3401,8 +3401,8 @@ Indikas lokon: %1$s x %2$s"</string>
|
|||
<string name="reset_all_profile_settings">Ĉu rekomencigi ĉiujn agordojn pri profiloj\?</string>
|
||||
<string name="ltr_or_rtl_combine_via_colon">%1$s: %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_space">%1$s %2$s</string>
|
||||
<string name="file_does_not_contain_routing_rules">La dosiero “%1$s” ne enhavas regulojn pri kurs‑difinado, bonvolu elekti alian dosieron.</string>
|
||||
<string name="not_support_file_type_with_ext">Nesubtenata tipo de dosiero. Elektu dosieron kun la finaĵo %1$s.</string>
|
||||
<string name="file_does_not_contain_routing_rules">Neniuj reguloj pri kurs‑difinado en “%1$s”. Bonvolu elekti alian dosieron.</string>
|
||||
<string name="not_support_file_type_with_ext">Bonvolu elekti dosieron kun la subtenata finaĵo %1$s.</string>
|
||||
<string name="import_from_file">Enporti el dosiero</string>
|
||||
<string name="import_routing_file">Enporti dosieron de kurs‑difinado</string>
|
||||
<string name="import_profile">Enporti profilon</string>
|
||||
|
@ -3427,5 +3427,7 @@ Indikas lokon: %1$s x %2$s"</string>
|
|||
<string name="app_mode_osm">OSM</string>
|
||||
<string name="select_nav_icon_descr">La emblemo montriĝos nur dum navigi aŭ dum moviĝi.</string>
|
||||
<string name="select_map_icon_descr">Map‑emblemo montriĝas nur dum foliumi mapon kaj ŝanĝiĝas dum navigi al la emblemo de navigo.</string>
|
||||
<string name="logcat_buffer_descr">Tie ĉi vi povas legi kaj kunhavigi protokolojn de la aplikaĵo</string>
|
||||
<string name="logcat_buffer_descr">Legi kaj kunhavigi detalajn protokolojn de la aplikaĵo</string>
|
||||
<string name="permission_is_required">Permeso estas necesa por uzi tiun ĉi eblaĵon.</string>
|
||||
<string name="monitoring_min_speed_descr">Tiu ĉi filtrilo preventas registri punktojn sub difinita rapidlimo. Tiel registritaj spuroj aspektos pli glate dum vidiĝi sur la mapo.</string>
|
||||
</resources>
|
|
@ -3784,11 +3784,12 @@
|
|||
<string name="poi_volcano_type_maar">Maar</string>
|
||||
<string name="poi_volcano_type_caldera">Caldera</string>
|
||||
<string name="poi_volcano_type_lava_dome">Cúpula de lava</string>
|
||||
<string name="poi_volcano_type_dirt">Tierra (lodosa)</string>
|
||||
<string name="poi_volcano_type_mud">Tierra (lodosa)</string>
|
||||
<string name="poi_volcano_last_eruption">Última erupción</string>
|
||||
<string name="poi_volcano_status_extinct">Extinto</string>
|
||||
<string name="poi_volcano_status_dormant">Latente o dormido</string>
|
||||
<string name="poi_volcano_status_active">Activo</string>
|
||||
<string name="poi_volcano_status_inactive">Inactivo</string>
|
||||
<string name="poi_volcano_number_of_eruptions">Número de erupciones</string>
|
||||
<string name="poi_memorial_ghost_bike">Bicicleta fantasma</string>
|
||||
</resources>
|
|
@ -2299,23 +2299,11 @@ Lon %2$s</string>
|
|||
\n ¡Más países alrededor del globo están disponibles para descargar!
|
||||
\n Obtén un navegador confiable en tu país - ya sea Francia, Alemania, México, Reino Unido, España, Países bajos, Estados Unidos, Rusia, Brasil o cualquier otro.</string>
|
||||
<string name="osmand_plus_extended_description_part2">"Navegación GPS
|
||||
\n
|
||||
\n
|
||||
\n • Funciona en línea (rápido) o sin conexión (sin cargos de roaming al viajar al extranjero)
|
||||
\n
|
||||
\n
|
||||
\n • Guía por voz giro-a-giro (voces grabadas y sintetizadas)
|
||||
\n
|
||||
\n
|
||||
\n • (Opcional) Guía de carriles, nombres de calles y tiempo estimado al destino
|
||||
\n
|
||||
\n
|
||||
\n • Admite puntos intermedios en el itinerario
|
||||
\n
|
||||
\n
|
||||
\n • La ruta se recalcula al salirse de la misma
|
||||
\n
|
||||
\n
|
||||
\n • Busca destinos por dirección, por tipo (por ejemplo: Restaurantes, hoteles, estaciones de servicio, museos), o por coordenada geográfica "</string>
|
||||
<string name="osmand_plus_extended_description_part3">Vista del mapa
|
||||
\n • Muestra tu ubicación y orientación
|
||||
|
@ -3347,8 +3335,8 @@ Lon %2$s</string>
|
|||
<string name="shared_string_memory_used_mb_desc">Usado %1$s MB</string>
|
||||
<string name="shared_string_memory_used_kb_desc">Usado %1$s kB</string>
|
||||
<string name="contour_lines_and_hillshade">Curvas de nivel y sombreado</string>
|
||||
<string name="routing_attr_prefer_unpaved_name">Preferir ruta sin pavimentar</string>
|
||||
<string name="routing_attr_prefer_unpaved_description">Prefiere rutas sin pavimentar.</string>
|
||||
<string name="routing_attr_prefer_unpaved_name">Preferir caminos sin pavimentar</string>
|
||||
<string name="routing_attr_prefer_unpaved_description">Prefiere caminos sin pavimentar.</string>
|
||||
<string name="update_all_maps">Actualizar todos los mapas</string>
|
||||
<string name="update_all_maps_q">¿Actualizar todos los mapas (%1$d)\?</string>
|
||||
<string name="release_3_5">• Ajustes de la aplicación y del perfil actualizados. Cómoda distribución de los ajustes por tipo y posibilidad de personalizar cada perfil
|
||||
|
@ -3370,8 +3358,8 @@ Lon %2$s</string>
|
|||
\n</string>
|
||||
<string name="apply_preference_to_all_profiles">Puedes aplicar este cambio a todos los perfiles o sólo al marcado.</string>
|
||||
<string name="shared_preference">Compartido</string>
|
||||
<string name="routing_attr_driving_style_prefer_unpaved_name">Preferir rutas sin pavimentar</string>
|
||||
<string name="routing_attr_driving_style_prefer_unpaved_description">Ruta por terreno sin pavimento.</string>
|
||||
<string name="routing_attr_driving_style_prefer_unpaved_name">Preferir caminos sin pavimentar</string>
|
||||
<string name="routing_attr_driving_style_prefer_unpaved_description">Prefiere los caminos sin pavimentar a los pavimentados para el trazado de rutas.</string>
|
||||
<string name="layer_osm_edits">Ediciones de OSM</string>
|
||||
<string name="quick_action_contour_lines_descr">Un botón que muestra u oculta las curvas de nivel en el mapa.</string>
|
||||
<string name="quick_action_contour_lines_show">Mostrar curvas de nivel</string>
|
||||
|
@ -3388,13 +3376,13 @@ Lon %2$s</string>
|
|||
<string name="overwrite_profile_q">El perfil «%1$s» ya existe. ¿Sobrescribir\?</string>
|
||||
<string name="export_profile_failed">No se pudo exportar el perfil.</string>
|
||||
<string name="profile_import">Importar perfil</string>
|
||||
<string name="profile_import_descr">Añade un perfil abriendo el archivo en OsmAnd.</string>
|
||||
<string name="profile_import_descr">Añade un perfil abriendo este archivo con OsmAnd.</string>
|
||||
<string name="file_import_error">Error de importación de %1$s: %2$s</string>
|
||||
<string name="file_imported_successfully">%1$s importado.</string>
|
||||
<string name="rendering_value_white_name">Blanco</string>
|
||||
<string name="swap_two_places">Alternar %1$s y %2$s</string>
|
||||
<string name="route_start_point">Punto de partida</string>
|
||||
<string name="default_speed_dialog_msg">Estima el tiempo de llegada para los tipos de caminos desconocidos, y limita la velocidad para todos los caminos (puede desviarse)</string>
|
||||
<string name="default_speed_dialog_msg">Estima el tiempo de llegada para los tipos de caminos desconocidos, y limita la velocidad para todos los caminos (puede afectar a la ruta)</string>
|
||||
<string name="track_saved">Traza guardada</string>
|
||||
<string name="empty_filename">Nombre del archivo vacío</string>
|
||||
<string name="shared_string_revert">Revertir</string>
|
||||
|
@ -3414,27 +3402,27 @@ Lon %2$s</string>
|
|||
<string name="join_segments">Unir segmentos</string>
|
||||
<string name="add_new_profile_q">¿Añadir el nuevo perfil «%1$s»\?</string>
|
||||
<string name="save_heading">Incluir rumbo</string>
|
||||
<string name="save_heading_descr">Guarda el rumbo para cada punto de la traza durante el seguimiento.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="save_heading_descr">Guarda el rumbo para cada punto de la traza durante la grabación.</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Personal</string>
|
||||
<string name="shared_string_downloading_formatted">Descargando %s</string>
|
||||
<string name="rendering_value_thick_name">Espesor</string>
|
||||
<string name="desert_render_descr">Para desiertos y otras zonas escasamente pobladas. Más detallado.</string>
|
||||
<string name="select_navigation_icon">Icono de navegación</string>
|
||||
<string name="select_map_icon">Icono del mapa</string>
|
||||
<string name="delete_profiles_descr">Al pulsar en «Aplicar», todos los perfiles serán borrados completamente.</string>
|
||||
<string name="select_navigation_icon">Icono de la ubicación mientras se mueve</string>
|
||||
<string name="select_map_icon">Icono de la ubicación en reposo</string>
|
||||
<string name="delete_profiles_descr">Al pulsar en «Aplicar», los perfiles borrados se perderán completamente.</string>
|
||||
<string name="master_profile">Perfil principal</string>
|
||||
<string name="select_color">Elegir el color</string>
|
||||
<string name="edit_profiles_descr">Los perfiles de OsmAnd se pueden mover a la parte inferior, pero no se pueden borrar. Vuelve para quitarlos.</string>
|
||||
<string name="edit_profiles_descr">Los perfiles predefinidos de OsmAnd no se pueden borrar, sino desactivar (en la pantalla anterior) u ordenarse en la parte inferior.</string>
|
||||
<string name="edit_profiles">Editar perfiles</string>
|
||||
<string name="select_nav_profile_dialog_message">El «Tipo de navegación» afecta a las reglas para los cálculos de la ruta.</string>
|
||||
<string name="select_nav_profile_dialog_message">El «Tipo de navegación» rige la forma en que se calculan las rutas.</string>
|
||||
<string name="profile_appearance">Aspecto del perfil</string>
|
||||
<string name="choose_icon_color_name">Icono, color y nombre</string>
|
||||
<string name="reorder_profiles">Editar la lista de perfiles</string>
|
||||
<string name="selected_profile">Perfil marcado</string>
|
||||
<string name="reset_confirmation_descr">Al pulsar en «%1$s», se perderán todos los cambios.</string>
|
||||
<string name="reset_all_profile_settings_descr">Todos los ajustes del perfil volverán a los valores predefinidos de la instalación.</string>
|
||||
<string name="reset_confirmation_descr">Al pulsar en «%1$s», serán descartados todos los cambios.</string>
|
||||
<string name="reset_all_profile_settings_descr">Restablecer todos los ajustes del perfil a los valores predefinidos de la instalación.</string>
|
||||
<string name="reset_all_profile_settings">¿Restablecer todos los ajustes del perfil\?</string>
|
||||
<string name="ltr_or_rtl_combine_via_space">%1$s %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_colon">%1$s: %2$s</string>
|
||||
|
@ -3452,7 +3440,7 @@ Lon %2$s</string>
|
|||
<string name="live_monitoring">Seguimiento en línea</string>
|
||||
<string name="save_track_logging_accuracy">Precisión de registro</string>
|
||||
<string name="tracks_view_descr">Puedes encontrar todas tus trazas grabadas en «%1$s» o en la carpeta OsmAnd usando el administrador de archivos.</string>
|
||||
<string name="multimedia_notes_view_descr">Puedes encontrar todas tus notas en «%1$s»</string>
|
||||
<string name="multimedia_notes_view_descr">Puedes encontrar todas tus notas en «%1$s».</string>
|
||||
<string name="video_notes">Notas de video</string>
|
||||
<string name="photo_notes">Notas fotográficas</string>
|
||||
<string name="route_recalculation">Recálculo de la ruta</string>
|
||||
|
@ -3462,8 +3450,36 @@ Lon %2$s</string>
|
|||
<string name="osm_editing">Edición de OSM</string>
|
||||
<string name="osm_edits_view_descr">Puedes ver todas tus ediciones no subidas o errores de OSM en «%1$s». Los puntos subidos no se muestran en OsmAnd.</string>
|
||||
<string name="app_mode_osm">OSM</string>
|
||||
<string name="select_nav_icon_descr">El icono sólo se muestra mientras se navega o se mueve.</string>
|
||||
<string name="select_map_icon_descr">El icono del mapa sólo se muestra en el mapa.</string>
|
||||
<string name="select_nav_icon_descr">El icono se muestra mientras se navega o se mueve.</string>
|
||||
<string name="select_map_icon_descr">El icono se muestra en reposo.</string>
|
||||
<string name="logcat_buffer_descr">Comprueba y comparte los registros detallados de la aplicación</string>
|
||||
<string name="search_offline_geo_error">No se puede analizar la geointención «%s».</string>
|
||||
<string name="permission_is_required">Se necesita permiso para usar esta opción.</string>
|
||||
<string name="monitoring_min_speed_descr">Se trata de un filtro de corte de baja velocidad para no grabar puntos por debajo de una cierta velocidad. Esto puede hacer que las trazas grabadas se vean más suaves cuando se muestran en el mapa.</string>
|
||||
<string name="monitoring_min_speed_descr_side_effect">Efecto secundario: En la traza faltarán todos los tramos en los que no se haya cumplido el criterio de velocidad mínima (por ejemplo, cuando se empuja la bicicleta por una colina empinada). Además, no habrá información sobre los períodos de descanso, como las pausas. Esto tiene efectos en cualquier análisis o post-proceso, como cuando se trata de determinar la duración total del viaje, el tiempo en movimiento, o la velocidad promedio.</string>
|
||||
<string name="monitoring_min_speed_descr_recommendation">Recomendación: Prueba primero a utilizar la detección de movimiento mediante el filtro de desplazamiento mínimo de registro (B), puede producir mejores resultados y perderá menos datos. Si las trazas siguen siendo ruidosas a bajas velocidades, prueba aquí con valores distintos de cero. Tenga en cuenta que algunas mediciones pueden no informar ningún valor de velocidad (algunos métodos basados en la red), en cuyo caso no se registraría nada.</string>
|
||||
<string name="monitoring_min_speed_descr_remark">Observación: comprobar velocidad > 0: La mayoría de los chipsets de GPS informan un valor de velocidad sólo si el algoritmo determina que está en movimiento. Por lo tanto, el uso del ajuste > 0 en este filtro, en cierto sentido utiliza la detección de movimiento del conjunto de chips del GPS. Pero incluso si no se filtra aquí en el momento de la grabación, seguimos utilizando esta función en nuestro análisis GPX para determinar la distancia corregida, es decir, el valor que se muestra en ese campo es la distancia grabada en movimiento.</string>
|
||||
<string name="monitoring_min_accuracy_descr">Esto registrará solo los puntos medidos con una indicación de precisión mínima (en metros o pies, según lo informado por Android para su conjunto de chips). La precisión se refiere a la dispersión de mediciones repetidas, y no está directamente relacionada con la precisión, que define qué tan cerca están sus mediciones de su posición real.</string>
|
||||
<string name="monitoring_min_accuracy_descr_side_effect">Efecto secundario: Como resultado del filtrado por precisión, pueden faltar puntos por ejemplo debajo de puentes, bajo árboles, entre edificios altos o con ciertas condiciones climáticas.</string>
|
||||
<string name="monitoring_min_accuracy_descr_recommendation">Recomendación: Es difícil predecir lo que se grabará y lo que no, puede ser mejor apagar este filtro.</string>
|
||||
<string name="monitoring_min_accuracy_descr_remark">Observación: Si el GPS se hubiera apagado inmediatamente antes de una grabación, el primer punto medido podría tener una precisión disminuida, por lo que en nuestro código puede que queramos esperar un segundo más o menos antes de grabar un punto (o grabar el mejor de 3 puntos consecutivos, etc.), pero esto todavía no se ha implementado.</string>
|
||||
<string name="monitoring_min_distance_descr">Este filtro evita que se registren puntos duplicados en los que puede haber muy poco movimiento real, y da un aspecto espacial más agradable a las pistas que no se procesan posteriormente.</string>
|
||||
<string name="monitoring_min_distance_descr_side_effect">Efectos secundarios: Los períodos de descanso no se registran en absoluto o sólo en un punto cada uno. Los pequeños movimientos (del mundo real) (por ejemplo, hacia los lados, para marcar un posible desvío en su viaje) pueden ser filtrados. Su archivo contiene menos información para el post-procesamiento, y tiene peores estadísticas al filtrar los puntos obviamente redundantes en el tiempo de grabación, mientras que potencialmente mantiene los artefactos causados por la mala recepción o los efectos del chipset del GPS.</string>
|
||||
<string name="monitoring_min_distance_descr_recommendation">Recomendación: Un ajuste de 5 metros puede funcionar bien si no necesitas capturar detalles más finos que eso, y no deseas capturar explícitamente los datos mientras está en reposo.</string>
|
||||
<string name="live_monitoring_time_buffer">Memoria intermedia</string>
|
||||
<string name="live_monitoring_tracking_interval">Intervalo de seguimiento</string>
|
||||
<string name="live_monitoring_adress">Dirección web</string>
|
||||
<string name="live_monitoring_adress_descr">Indica la dirección web con sintaxis de parámetros : lat={0}, lon={1}, timestamp={2}, hdop={3}, altitude={4}, speed={5}, bearing={6}.</string>
|
||||
<string name="monitoring_notification">Notificación</string>
|
||||
<string name="monitoring_min_speed">Velocidad mínima</string>
|
||||
<string name="monitoring_min_accuracy">Precisión mínima</string>
|
||||
<string name="monitoring_min_distance">Desplazamiento mínimo</string>
|
||||
<string name="tracks_view_path">Menú — Mis sitios — Trazas</string>
|
||||
<string name="multimedia_notes_view_path">Menú — Mis sitios — Notas</string>
|
||||
<string name="osm_edits_view_path">Menú — Mis sitios — Ediciones de OSM</string>
|
||||
<string name="reset_plugin_to_default">Restablecer ajustes del complemento a valores predefinidos</string>
|
||||
<string name="multimedia_rec_split_title">División de grabación</string>
|
||||
<string name="multimedia_use_system_camera">Usar la aplicación del sistema</string>
|
||||
<string name="multimedia_photo_play_sound">Reproducir sonido al fotografiar</string>
|
||||
<string name="osm_authorization_success">Autorización exitosa</string>
|
||||
</resources>
|
|
@ -3784,7 +3784,7 @@
|
|||
<string name="poi_volcano_type_maar">Maar</string>
|
||||
<string name="poi_volcano_type_caldera">Caldera</string>
|
||||
<string name="poi_volcano_type_lava_dome">Cúpula de lava</string>
|
||||
<string name="poi_volcano_type_dirt">Tierra (lodosa)</string>
|
||||
<string name="poi_volcano_type_mud">Tierra (lodosa)</string>
|
||||
<string name="poi_volcano_last_eruption">Última erupción</string>
|
||||
<string name="poi_volcano_status_extinct">Extinto</string>
|
||||
<string name="poi_volcano_status_dormant">Latente o dormido</string>
|
||||
|
|
|
@ -3403,7 +3403,7 @@ Lon %2$s</string>
|
|||
<string name="add_new_profile_q">¿Añadir el nuevo perfil «%1$s»\?</string>
|
||||
<string name="save_heading">Incluir rumbo</string>
|
||||
<string name="save_heading_descr">Guarda el rumbo para cada punto de la traza durante la grabación.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Personal</string>
|
||||
<string name="shared_string_downloading_formatted">Descargando %s</string>
|
||||
|
|
|
@ -3778,7 +3778,7 @@
|
|||
<string name="poi_volcano_type_maar">Maar</string>
|
||||
<string name="poi_volcano_type_caldera">Caldera</string>
|
||||
<string name="poi_volcano_type_lava_dome">Cúpula de lava</string>
|
||||
<string name="poi_volcano_type_dirt">Tierra</string>
|
||||
<string name="poi_volcano_type_mud">Tierra</string>
|
||||
<string name="poi_volcano_last_eruption">Última erupción</string>
|
||||
<string name="poi_volcano_status_extinct">Extinto</string>
|
||||
<string name="poi_volcano_status_dormant">Latente</string>
|
||||
|
|
|
@ -3394,7 +3394,7 @@
|
|||
<string name="add_new_profile_q">¿Añadir el nuevo perfil «%1$s»\?</string>
|
||||
<string name="save_heading">Incluir rumbo</string>
|
||||
<string name="save_heading_descr">Guarda el rumbo para cada punto de la traza durante la grabación.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Personal</string>
|
||||
<string name="shared_string_downloading_formatted">Descargando %s</string>
|
||||
|
|
|
@ -3759,7 +3759,7 @@
|
|||
<string name="poi_volcano_type_maar">Maar</string>
|
||||
<string name="poi_volcano_type_caldera">Kaldeera</string>
|
||||
<string name="poi_volcano_type_lava_dome">Laava kuppel</string>
|
||||
<string name="poi_volcano_type_dirt">Muld</string>
|
||||
<string name="poi_volcano_type_mud">Muld</string>
|
||||
<string name="poi_volcano_last_eruption">Viimane purse</string>
|
||||
<string name="poi_volcano_status_extinct">Kustunud</string>
|
||||
<string name="poi_volcano_status_dormant">Tegevusetu</string>
|
||||
|
|
|
@ -1032,7 +1032,7 @@
|
|||
<string name="add_new_profile_q">Lisada uus profiil \'%1$s\'\?</string>
|
||||
<string name="save_heading">Kaasa pealkiri</string>
|
||||
<string name="save_heading_descr">Salvestamise ajal salvesta kurss igasse teekonnapunkti.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Isiklik</string>
|
||||
<string name="shared_string_downloading_formatted">Allalaadimine %s</string>
|
||||
|
|
|
@ -3400,7 +3400,7 @@ Area honi dagokio: %1$s x %2$s</string>
|
|||
<string name="add_new_profile_q">Gehitu \'%1$s\' profil berria\?</string>
|
||||
<string name="save_heading">Sartu norabidea</string>
|
||||
<string name="save_heading_descr">Gorde lorratzeko puntu bakoitzerako norabidea grabatzean.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Pertsonala</string>
|
||||
<string name="shared_string_downloading_formatted">%s deskargatzen</string>
|
||||
|
|
|
@ -2,7 +2,7 @@
|
|||
<resources>
|
||||
<string name="local_osm_changes_backup_failed">پشتیبانگیری از تغییرات OSM ناموفق بود.</string>
|
||||
<string name="plugin_distance_point_time">زمان</string>
|
||||
<string name="plugin_distance_point_hdop">دقت</string>
|
||||
<string name="plugin_distance_point_hdop">صحت</string>
|
||||
<string name="plugin_distance_point_speed">سرعت</string>
|
||||
<string name="plugin_distance_point_ele">ارتفاع</string>
|
||||
<string name="plugin_distance_point">نقطه</string>
|
||||
|
@ -162,7 +162,7 @@
|
|||
<string name="map_online_plugin_is_not_installed">افزونهٔ «نقشههای آنلاین» را فعال کنید تا منابع مختلفی را برای نقشه انتخاب کنید</string>
|
||||
<string name="local_osm_changes_backup">پشتیبانگیری در قالب تغییر OSM</string>
|
||||
<string name="delete_point">حذف نقطه</string>
|
||||
<string name="use_kalman_filter_compass">استفاده از فیلتر کالمن</string>
|
||||
<string name="use_kalman_filter_compass">استفاده از پالایهٔ Kalman</string>
|
||||
<string name="cancel_route">حذف مسیر</string>
|
||||
<string name="max_speed_none">هیچکدام</string>
|
||||
<string name="dropbox_plugin_name">افزونهٔ دراپباکس</string>
|
||||
|
@ -192,12 +192,12 @@
|
|||
<string name="destination_point">مقصد %1$s</string>
|
||||
<string name="context_menu_item_destination_point">تنظیم به عنوان مقصد</string>
|
||||
<string name="email">ایمیل</string>
|
||||
<string name="edit_filter_save_as_menu_item">ذخیرهکردن با نام</string>
|
||||
<string name="edit_filter_delete_dialog_title">این فیلتر حذف شود؟</string>
|
||||
<string name="edit_filter_delete_message">فیلتر «{0}» حذف شد</string>
|
||||
<string name="edit_filter_create_message">فیلتر «{0}» ایجاد شد</string>
|
||||
<string name="edit_filter_save_as_menu_item">ذخیره با نام</string>
|
||||
<string name="edit_filter_delete_dialog_title">این پالایه حذف شود؟</string>
|
||||
<string name="edit_filter_delete_message">پالایهٔ «{0}» حذف شد</string>
|
||||
<string name="edit_filter_create_message">پالایهٔ «{0}» ایجاد شد</string>
|
||||
<string name="shared_string_clear">پاککردن</string>
|
||||
<string name="filter_current_poiButton">فیلتر</string>
|
||||
<string name="filter_current_poiButton">پالایش</string>
|
||||
<string name="poi_dialog_other_tags_message">همهٔ برچسبهای دیگر حفظ شد</string>
|
||||
<string name="poi_dialog_opening_hours">باز است</string>
|
||||
<string name="poi_dialog_comment">توضیح</string>
|
||||
|
@ -374,7 +374,7 @@
|
|||
<string name="front_left">چپ-جلو</string>
|
||||
<string name="oclock">ساعت</string>
|
||||
<string name="towards">بهطرف</string>
|
||||
<string name="accuracy">دقت</string>
|
||||
<string name="accuracy">صحت</string>
|
||||
<string name="altitude">ارتفاع</string>
|
||||
<string name="i_am_here">من اینجا هستم</string>
|
||||
<string name="local_openstreetmap_uploadall">آپلود همه</string>
|
||||
|
@ -790,7 +790,7 @@
|
|||
<string name="incremental_search_building">جستوجوی حرفبهحرف نام ساختمانها</string>
|
||||
<string name="incremental_search_street">جستوجوی حرفبهحرف نام خیابانها</string>
|
||||
<string name="reload_tile">بارکردن مجدد کاشی</string>
|
||||
<string name="save_track_to_gpx">ضبط خودکار رد هنگام ناوبری</string>
|
||||
<string name="save_track_to_gpx">ردنگاری خودکار در هنگام ناوبری</string>
|
||||
<string name="loading_postcodes">در حال بارکردن کدهای پستی…</string>
|
||||
<string name="converting_names">در حال تبدیل اسامی محلی/انگلیسی…</string>
|
||||
<string name="failed_op">ناموفق</string>
|
||||
|
@ -850,9 +850,9 @@
|
|||
<string name="background_router_service_descr">زمانی که صفحه خاموش است موقعیت شما را ردگیری میکند.</string>
|
||||
<string name="background_router_service">اجرای OsmAnd در پسزمینه</string>
|
||||
<string name="off_router_service_no_gps_available">برای استفاده از خدمات ناوبری موقعیت مکانی را روشن کنید.</string>
|
||||
<string name="hide_poi_filter">مخفیکردن فیلتر</string>
|
||||
<string name="show_poi_filter">نمایش فیلتر</string>
|
||||
<string name="search_poi_filter">فیلتر</string>
|
||||
<string name="hide_poi_filter">مخفیکردن پالایه</string>
|
||||
<string name="show_poi_filter">نمایش پالایه</string>
|
||||
<string name="search_poi_filter">پالایه</string>
|
||||
<string name="layer_map">منبع نقشه…</string>
|
||||
<string name="context_menu_item_search_poi">جستوجوی POI</string>
|
||||
<string name="use_trackball_descr">استفاده از گوی چرخان (توپک) برای جابهجاکردن نقشه.</string>
|
||||
|
@ -1036,7 +1036,7 @@
|
|||
<string name="renderer_load_exception">بارکردن رندرکننده ناموفق بود.</string>
|
||||
<string name="renderers">رندرکنندهٔ بُرداری</string>
|
||||
<string name="renderers_descr">شکلوشمایل رندرگیری را انتخاب نمایید</string>
|
||||
<string name="download_type_to_filter">فیلتر</string>
|
||||
<string name="download_type_to_filter">بنویسید تا پالایش شود</string>
|
||||
<string name="transport_context_menu">جستوجوی حملونقل در ایستگاه</string>
|
||||
<string name="rotate_map_to_bearing_descr">نحوهٔ چرخش نقشه:</string>
|
||||
<string name="layer_poi">لایهٔ POI…</string>
|
||||
|
@ -1483,7 +1483,7 @@
|
|||
<string name="storage_directory_default">حافظهٔ داخلی</string>
|
||||
<string name="storage_directory">محل ذخیرهسازی نقشه</string>
|
||||
<string name="shared_string_copy">کپی</string>
|
||||
<string name="filter_poi_hint">فیلتر بر اساس نام</string>
|
||||
<string name="filter_poi_hint">پالایش بر اساس نام</string>
|
||||
<string name="search_poi_category_hint">جستوجوی همه</string>
|
||||
<string name="shared_string_is_open">باز است</string>
|
||||
<string name="agps_info">اطلاعات A-GPS</string>
|
||||
|
@ -1860,8 +1860,8 @@
|
|||
<string name="shared_string_record">ضبطکردن</string>
|
||||
<string name="gpx_logging_no_data">اطلاعاتی وجود ندارد</string>
|
||||
<string name="rendering_attr_contourColorScheme_description">رنگبندی منحنیهای میزان</string>
|
||||
<string name="save_track_min_speed">کمترین سرعت برای ورود به سیستم</string>
|
||||
<string name="save_track_precision">کمترین دقت برای ثبت</string>
|
||||
<string name="save_track_min_speed">کمترین سرعت برای ثبت</string>
|
||||
<string name="save_track_precision">کمترین صحت برای ثبت</string>
|
||||
<string name="christmas_poi">POI کریسمس</string>
|
||||
<string name="christmas_desc">در آستانهٔ کریسمس و تعطیلات سال نو، میتوانید نقاط توجه در کریسمس، مانند درختهای کریسمس، فروشگاهها و غیره را ببینید.</string>
|
||||
<string name="christmas_desc_q">نقاط توجه تعطیلات کریسمس نمایش داده شود؟</string>
|
||||
|
@ -1873,14 +1873,14 @@
|
|||
<string name="edit_filter">ویرایش دستهها</string>
|
||||
<string name="subcategories">زیردستهها</string>
|
||||
<string name="selected_categories">دستههای انتخابشده</string>
|
||||
<string name="create_custom_poi">ایجاد فیلتر سفارشی</string>
|
||||
<string name="create_custom_poi">ایجاد پالایهٔ سفارشی</string>
|
||||
<string name="custom_search">جستوجوی سفارشی</string>
|
||||
<string name="shared_string_filters">فیلترها</string>
|
||||
<string name="apply_filters">بهکارگیری فیلترها</string>
|
||||
<string name="save_filter">ذخیره فیلتر</string>
|
||||
<string name="delete_filter">حذف فیلتر</string>
|
||||
<string name="new_filter">فیلتر جدید</string>
|
||||
<string name="new_filter_desc">لطفاً برای فیلتر جدید نامی وارد کنید. این نام به «دستهها» اضافه میشود.</string>
|
||||
<string name="shared_string_filters">پالایهها</string>
|
||||
<string name="apply_filters">بهکارگیری پالایهها</string>
|
||||
<string name="save_filter">ذخیرهٔ پالایه</string>
|
||||
<string name="delete_filter">حذف پالایه</string>
|
||||
<string name="new_filter">پالایهٔ جدید</string>
|
||||
<string name="new_filter_desc">لطفاً برای این پالایه نامی بنویسید. این نام به «دستهها» اضافه میشود.</string>
|
||||
<string name="enter_gpx_name">نام فایل GPX:</string>
|
||||
<string name="show_on_map_after_saving">مشاهده بر روی نقشه پس از ذخیره</string>
|
||||
<string name="measurement_tool_action_bar">نقشه را بپیمایید و نقاط را اضافه کنید</string>
|
||||
|
@ -2053,7 +2053,7 @@
|
|||
\nپهنهٔ متناظر: %1$s × %2$s</string>
|
||||
<string name="increase_search_radius">محدودهٔ جستوجو را بزرگتر کن</string>
|
||||
<string name="nothing_found_descr">جستوجو را تغییر دهید یا شعاع آن را بزرگتر کنید.</string>
|
||||
<string name="save_track_to_gpx_globally_headline">ثبت رد درصورت تقاضا</string>
|
||||
<string name="save_track_to_gpx_globally_headline">ردنگاری بر اساس تقاضا</string>
|
||||
<string name="average">میانگین</string>
|
||||
<string name="of">%1$d از %2$d</string>
|
||||
<string name="ascent_descent">صعود/نزول</string>
|
||||
|
@ -2293,7 +2293,7 @@
|
|||
<string name="mapillary_menu_edit_text_hint">نام کاربری را بنویسید</string>
|
||||
<string name="mapillary_menu_descr_username">فقط تصاویری که کاربر زیر اضافه کرده است</string>
|
||||
<string name="mapillary_menu_title_username">نام کاربری</string>
|
||||
<string name="mapillary_menu_filter_description">فیلتر تصاویر بر اساس ارسالکننده، تاریخ یا نوع. فقط در زوم نزدیک کار میکند.</string>
|
||||
<string name="mapillary_menu_filter_description">پالایش تصاویر بر اساس ارسالکننده، تاریخ یا نوع. فقط در زوم نزدیک کار میکند.</string>
|
||||
<string name="map_widget_ruler_control">خطکش شعاعی</string>
|
||||
<string name="shared_string_permissions">مجوزها</string>
|
||||
<string name="import_gpx_failed_descr">درونبرد فایل ناموفق بود. لطفاً بررسی کنید OsmAnd اجازهٔ خواندن آن را داشته باشد.</string>
|
||||
|
@ -2350,9 +2350,9 @@
|
|||
<string name="upload_osm_note_description">یادداشتهای OSM خود را بهصورت ناشناس یا با نام کاربریتان در سایت OpenStreetMap.org، آپلود کنید.</string>
|
||||
<string name="route_roundabout_short">خروجی %1$d را بگیرید و بروید</string>
|
||||
<string name="trip_rec_notification_settings_desc">در نوار اعلان دستگاه یک اعلان برای ضبط سفر نشان میدهد.</string>
|
||||
<string name="save_track_min_speed_descr">فیلتر: هیچ نقطهای ثبت نمیشود مگر به این سرعت برسد.</string>
|
||||
<string name="save_track_min_distance_descr">فیلتر: کمترین مسافتی که یک نقطه باید از موقعیت قبلی داشته باشد تا ثبت شود.</string>
|
||||
<string name="save_track_precision_descr">فیلتر: هیچ نقطهای ثبت نمیشود مگر به این دقت برسد.</string>
|
||||
<string name="save_track_min_speed_descr">پالایه: هیچ نقطهای ثبت نمیشود مگر به این سرعت برسد.</string>
|
||||
<string name="save_track_min_distance_descr">پالایه: کمترین مسافتی که یک نقطه باید از موقعیت قبلی داشته باشد تا ثبت شود.</string>
|
||||
<string name="save_track_precision_descr">پالایه: ضبط انجام نمیشود مگر با رسیدن به این میزان صحت.</string>
|
||||
<string name="find_parking">پیداکردن پارکینگ</string>
|
||||
<string name="add_time_span">افزودن بازهٔ زمانی</string>
|
||||
<string name="shared_string_undo_all">خنثیکردن همه</string>
|
||||
|
@ -3315,8 +3315,8 @@
|
|||
<string name="paste_Osmand_data_folder_path">مسیر پوشهٔ دادههای OsmAnd را درج کنید</string>
|
||||
<string name="change_osmand_data_folder_question">پوشهٔ دادههای OsmAnd تغییر کند؟</string>
|
||||
<string name="move_maps_to_new_destination">انتقال به مقصد جدید</string>
|
||||
<string name="internal_app_storage_description">ذخیرهگاه داخلی از کاربر و سایر برنامکها پنهان است، منحصراً OsmAnd به آن دسترسی دارد</string>
|
||||
<string name="change_data_storage_folder">تغییر پوشهٔ ذخیرهسازی دادهها</string>
|
||||
<string name="internal_app_storage_description">ذخیرهگاه داخلی OsmAnd (از دید کاربران و سایر برنامهها پنهان است).</string>
|
||||
<string name="change_data_storage_folder">تغییر پوشهٔ ذخیرهسازی</string>
|
||||
<string name="rendering_attr_piste_type_snow_park_name">پارک برفی</string>
|
||||
<string name="rendering_attr_piste_type_sleigh_name">سورتمه کالسکهای</string>
|
||||
<string name="rendering_attr_piste_type_sled_name">سورتمه</string>
|
||||
|
@ -3364,26 +3364,26 @@
|
|||
<string name="update_all_maps">بهروزرسانی همهٔ نقشهها</string>
|
||||
<string name="update_all_maps_q">آیا همهٔ نقشهها (%1$d) را بهروز میکنید؟</string>
|
||||
<string name="release_3_5">• تنظیمات برنامه و پروفایلها بهروز شد: تنظیمات بر اساس نوع مرتب شدهاند و امکان شخصیسازی هر پروفایل اضافه شده است.
|
||||
\n
|
||||
\n
|
||||
\n• کادر جدیدی برای دانلود نقشه اضافه شده که هنگام مرور، نقشهها را پیشنهاد میکند.
|
||||
\n
|
||||
\n• اصلاحاتی در پوستهٔ شب انجام شد.
|
||||
\n
|
||||
\n
|
||||
\n• اصلاحاتی در پوستهٔ تیره انجام شد.
|
||||
\n
|
||||
\n• چند ایراد مسیریابی در سراسر جهان رفع شد.
|
||||
\n
|
||||
\n
|
||||
\n• نقشهٔ پایه با جزئیات بیشتر از شبکهٔ راهها بهروز شد.
|
||||
\n
|
||||
\n
|
||||
\n• مناطق آبگرفته در سراسر جهان اصلاح شد.
|
||||
\n
|
||||
\n
|
||||
\n• مسیریابی اسکی: پروفایل ارتفاعی و دشواری مسیر به جزئیات مسیرها افزوده شد.
|
||||
\n
|
||||
\n
|
||||
\n• اصلاح سایر باگها
|
||||
\n
|
||||
\n</string>
|
||||
<string name="apply_preference_to_all_profiles">این تنظیم را میتوانید بر همهٔ پروفایلها یا فقط بر پروفایل جاری به کار ببندید.</string>
|
||||
<string name="shared_preference">مشترک</string>
|
||||
<string name="routing_attr_driving_style_prefer_unpaved_name">ترجیح جادههای روسازینشده</string>
|
||||
<string name="routing_attr_driving_style_prefer_unpaved_description">جادههای روسازینشده را ترجیح میدهم.</string>
|
||||
<string name="routing_attr_driving_style_prefer_unpaved_description">جادههای روسازینشده را به روسازیشده ترجیح میدهم.</string>
|
||||
<string name="layer_osm_edits">ویرایشهای OSM</string>
|
||||
<string name="quick_action_contour_lines_descr">دکمهای برای آشکار/پنهان کردن منحنیهای میزان روی نقشه.</string>
|
||||
<string name="quick_action_contour_lines_show">نشاندادن منحنیهای میزان</string>
|
||||
|
@ -3431,15 +3431,15 @@
|
|||
<string name="join_segments">پیوند پارهها</string>
|
||||
<string name="save_heading">ثبت جهت</string>
|
||||
<string name="save_heading_descr">هنگام ضبط، جهت را برای هر یک از نقطههای رد ثبت کن.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s، %2$s</string>
|
||||
<string name="personal_category_name">شخصی</string>
|
||||
<string name="shared_string_downloading_formatted">در حال بارگیری %s</string>
|
||||
<string name="rendering_value_thick_name">ضخیم</string>
|
||||
<string name="desert_render_descr">برای بیابانها و سایر نواحی با جمعیت پراکنده. جزئیات بیشتری دارد.</string>
|
||||
<string name="add_new_profile_q">پروفایل تازهٔ «%1$s» اضافه شود؟</string>
|
||||
<string name="select_navigation_icon">نماد ناوبری</string>
|
||||
<string name="select_map_icon">نماد نقشه</string>
|
||||
<string name="select_navigation_icon">نماد موقعیت هنگام حرکت</string>
|
||||
<string name="select_map_icon">نماد موقعیت هنگام توقف</string>
|
||||
<string name="delete_profiles_descr">با لمس «بهکارگیری»، پروفایلهای حذفشده برای همیشه از بین میروند.</string>
|
||||
<string name="master_profile">پروفایل اصلی</string>
|
||||
<string name="select_color">انتخاب رنگ</string>
|
||||
|
@ -3461,4 +3461,21 @@
|
|||
<string name="import_from_file">درونبرد از فایل</string>
|
||||
<string name="import_routing_file">درونبرد فایل مسیریابی</string>
|
||||
<string name="import_profile">درونبرد پروفایل</string>
|
||||
<string name="permission_is_required"></string>
|
||||
<string name="monitoring_min_speed_descr">این یک پالایهٔ قطعکننده برای سرعتهای پایین است تا نقاطی که سرعتشان از حدی پایینتر است ضبط نشوند. میتواند سبب شود که ردهای ضبطشده بهشکل هموارتری روی نقشه دیده شوند.</string>
|
||||
<string name="monitoring_min_speed_descr_side_effect">اثر جانبی: همهٔ قطعههایی که در آنها به حداقل سرعت معیار نرسید از رد حذف خواهد شد (مثلاً هنگامی که دوچرخهتان را بالای یک تپه با شیب تند میبرید). همچنین هیچ اطلاعاتی دربارهٔ بازههای توقف، مانند استراحتها، ضبط نمیشود. این مسئله بر همهٔ تحلیلها یا پسپردازشها تأثیر میگذارد، مانند زمانی که بخواهید مسافت کلی سفر، مدت حرکت یا سرعت متوسط خود را بدانید.</string>
|
||||
<string name="monitoring_min_speed_descr_recommendation">توصیه: ابتدا از پالایهٔ «کمترین جابهجایی» بهمنظور تشخیص حرکت استفاده کنید (B). اینگونه شاید نتایج بهتری بگیرید و همچنین دادهٔ کمتری از دست میدهید. اگر ردها در سرعتهای پایین نویز دارد، برای اینجا از مقدارهای غیرصفر استفاده کنید. لطفاً توجه نمایید که برخی اندازهگیریها ممکن است اصلاً هیچ سرعتی را گزارش نکنند (برخی روشهای مبتنی بر شبکه)، که در این صورت هیچ چیزی ضبط نخواهد شد.</string>
|
||||
<string name="monitoring_min_speed_descr_remark">توجه: بررسی «سرعت>۰»: بیشتر چیپستهای GPS فقط در صورتی مقدار سرعت را گزارش میکنند که الگوریتم، شما را در حال حرکت تشخیص دهد و اگر در حال حرکت نباشید چیزی گزارش نمیکنند. بنابراین استفاده از تنظیم «>۰» در این پالایه، به تشخیص حرکت توسط چیپست GPS وابسته است. البته حتی اگر این پالایش در زمان ضبط انجام نشود، ما از این ویژگی در تحلیلهای GPX خود استفاده میکنیم تا مسافت اصلاحشده را محاسبه کنیم؛ یعنی مقداری که برای «مسافت اصلاحشده» گزارش میکنیم میزان مسافتی است که در هنگام حرکت ضبط شده.</string>
|
||||
<string name="monitoring_min_accuracy_descr">این مورد فقط نقاطی را ضبط میکند که با شاخص کمترین صحت (به متر/فوت، مطابق گزارش اندروید از چیپست) اندازهگیری شدهاند. منظور از صحت، نمودار نقطهای اندازهگیریهای تکراری است و مستقیماً مربوط به دقت نمیشود (دقت: میزان نزدیکی اندازهگیریها به موقعیت واقعی).</string>
|
||||
<string name="monitoring_min_accuracy_descr_side_effect">اثر جانبی: درنتیجهٔ پالایش بر اساس صحت، ممکن است مثلاً زیر پلها، زیر درختان، میان ساختمانهای بلند یا در شرایط جوّی بخصوص، نقاط تماماً از دست بروند.</string>
|
||||
<string name="monitoring_min_accuracy_descr_recommendation">توصیه: سخت است آنچه ثبت میشود یا آنچه ثبت نمیشود را پیشبینی کنیم. شاید بهتر باشد این پالایه را خاموش کنید.</string>
|
||||
<string name="monitoring_min_accuracy_descr_remark">توجه: اگر بلافاصله پیش از ضبط، GPS خاموش بوده، ممکن است نخستین نقطه صحت کمتری داشته باشد؛ بنابراین ممکن است بخواهیم طوری کدنویسی کنیم که یک نقطه با یک یا چند ثانیه تأخیر ضبط شود (یا از سه نقطهٔ پیدرپی بهترینشان را ضبط کنیم و...)، البته این هنوز انجام نشده.</string>
|
||||
<string name="monitoring_notification">اعلان</string>
|
||||
<string name="monitoring_min_speed">کمترین سرعت</string>
|
||||
<string name="monitoring_min_accuracy">کمترین صحت</string>
|
||||
<string name="monitoring_min_distance">کمترین جابجایی</string>
|
||||
<string name="tracks_view_path">منو — مکانهای من — ردها</string>
|
||||
<string name="multimedia_notes_view_path">منو — مکانهای من — یادداشتها</string>
|
||||
<string name="osm_edits_view_path">منو — مکانهای من — ویرایشهای OSM</string>
|
||||
<string name="reset_plugin_to_default">بازنشانی تنظیمات افزونه به پیشفرض</string>
|
||||
</resources>
|
|
@ -596,18 +596,18 @@
|
|||
<string name="map_online_data_descr">Utiliser les cartes en ligne (télécharge et conserve en cache les tuiles sur la carte mémoire).</string>
|
||||
<string name="shared_string_online_maps">Cartes en ligne</string>
|
||||
<string name="online_map_settings_descr">Sélectionnez la source de la carte : en ligne ou tuile en cache.</string>
|
||||
<string name="osmand_rastermaps_plugin_description">Ce greffon permet d\'accéder à une grand nombre de cartes en ligne (aussi appelées tuiles ou cartes raster) qui vont de cartes OpenStreetMap (comme Mapnik) jusqu\'aux images satellites en passant par des cartes spécialisées comme des cartes météo, des cartes de climat, des cartes géologiques, des couches de relief, etc.
|
||||
<string name="osmand_rastermaps_plugin_description">Accédez à une grand nombre de cartes en ligne (aussi appelées tuiles ou cartes raster) qui vont de cartes OpenStreetMap (comme Mapnik) jusqu\'aux images satellites en passant par des cartes spécialisées comme des cartes météo, des cartes de climat, des cartes géologiques, les couches de relief, etc.
|
||||
\n
|
||||
\nChacune de ces cartes est utilisable, comme carte principale, sur-couche ou sous-couche d\'une autre carte. Afin de gérer au mieux la superposition des cartes, vous pouvez masquer certains éléments des cartes vectorielles hors ligne depuis le menu \"Paramétrer la carte\".
|
||||
\nChacune de ces cartes est utilisable, comme carte principale, sur-couche ou sous-couche d\'une autre carte. Afin de gérer au mieux la superposition des cartes et améliorer la lisibilité, vous pouvez masquer certains éléments des cartes vectorielles hors ligne depuis le menu \"Paramétrer la carte\".
|
||||
\n
|
||||
\nLes cartes tuiles peuvent être obtenues directement en ligne ou peuvent être préparées pour un usage hors ligne grâce à des outils tiers puis copiées dans le dossier de données d\'OsmAnd sous forme de base de données SQLite.</string>
|
||||
<string name="osmand_background_plugin_description">Affiche les préférences afin d\'activer le suivi et la navigation en arrière-plan (écran éteint) en réveillant périodiquement le GPS.</string>
|
||||
<string name="osmand_accessibility_description">Ce greffon active dans OsmAnd les options d\'accessibilité de votre appareil (réglage de la vitesse des voix de synthèse vocale, utilisation du trackball pour zoomer ou annonces vocales de votre position).</string>
|
||||
<string name="osmand_development_plugin_description">Ce greffon permet de gérer les paramètres de développement et de débogage tels que la simulation de navigation ou l\'affichage des performances du rendu. Ces paramètres sont conçus pour les développeurs et peuvent être ignorés par les autres utilisateurs.</string>
|
||||
<string name="osmand_accessibility_description">Activez, dans OsmAnd, les options d\'accessibilité de votre appareil (régler la vitesse des voix de synthèse vocale, utiliser le trackball pour zoomer ou activer les annonces vocales de votre position).</string>
|
||||
<string name="osmand_development_plugin_description">Gérez les paramètres de développement et de débogage tels que la simulation de navigation, l\'affichage des performances ou le guidage vocal. Ces paramètres sont conçus pour les développeurs et peuvent être ignorés par les autres utilisateurs.</string>
|
||||
<string name="plugins_screen">Gestionnaire de greffons</string>
|
||||
<string name="prefs_plugins_descr">Les greffons ajoutent à l\'application des fonctionnalités supplémentaires et des paramètres avancés.</string>
|
||||
<string name="prefs_plugins">Gestionnaire de greffons</string>
|
||||
<string name="osm_editing_plugin_description">Grâce à ce greffon vous pouvez gérer vos contributions à OpenStreetMap (OSM) directement depuis l\'application OsmAnd. Par exemple : créer ou modifier les points d\'intérêt OSM, déclarer ou commenter les notes OSM et envoyer vos traces GPX (nécessite un compte OSM). OpenStreetMap est une communauté ouverte de cartographie publique. Pour plus de détails, consultez https://openstreetmap.org.</string>
|
||||
<string name="osm_editing_plugin_description">Contribuez à OpenStreetMap (OSM) directement depuis l\'application OsmAnd. Par exemple : créez ou modifiez les points d\'intérêt OSM, créez ou modifiez les notes OSM et envoyez vos traces GPX (nécessite un compte OSM). OpenStreetMap est une communauté ouverte et mondiale de cartographie publique.</string>
|
||||
<string name="vector_maps_may_display_faster_on_some_devices">Cartes vectorielles (hors-ligne) peuvent s\'afficher plus rapidement. Peut ne pas fonctionner sur certains appareils.</string>
|
||||
<string name="play_commands_of_currently_selected_voice">Sélectionnez une voix et testez les annonces vocales :</string>
|
||||
<string name="debugging_and_development">Débogage et développement OsmAnd</string>
|
||||
|
@ -720,9 +720,8 @@
|
|||
<string name="osmand_parking_pm">PM</string>
|
||||
<string name="osmand_parking_am">AM</string>
|
||||
<string name="osmand_parking_position_name">Lieu de stationnement</string>
|
||||
<string name="osmand_parking_plugin_description">Ce greffon permet d\'enregistrer l\'emplacement de stationnement de votre véhicule et, si besoin, de mesurer la durée de stationnement restante.
|
||||
|
||||
Ces informations sont visibles sur le Tableau de bord comme sur la carte. Un rappel peut même être ajouté à votre calendrier.</string>
|
||||
<string name="osmand_parking_plugin_description">Enregistrez l\'emplacement de stationnement de votre véhicule et, si besoin, mesurez la durée de stationnement restante.
|
||||
\nCes informations sont visibles sur le Tableau de bord comme sur la carte. Un rappel peut même être ajouté à votre calendrier.</string>
|
||||
<string name="osmand_parking_plugin_name">Stationnement</string>
|
||||
<string name="context_menu_item_add_parking_point">Marquer comme stationnement</string>
|
||||
<string name="context_menu_item_delete_parking_point">Supprimer l\'emplacement de stationnement</string>
|
||||
|
@ -892,7 +891,7 @@ Ces informations sont visibles sur le Tableau de bord comme sur la carte. Un rap
|
|||
<string name="index_srtm_parts">parties</string>
|
||||
<string name="audionotes_location_not_defined">Appuyez sur \"Utiliser la position...\" pour ajouter une note sur le point.</string>
|
||||
<string name="map_widget_audionotes">Notes audio</string>
|
||||
<string name="audionotes_plugin_description">Ce greffon permet de prendre des notes (photos, audios ou vidéos) sur un itinéraire soit en utilisant un bouton affiché sur la carte, soit directement depuis le menu contextuel de n\'importe quel point sur la carte.</string>
|
||||
<string name="audionotes_plugin_description">Prenez des notes (photos, audios ou vidéos) pendant votre itinéraire soit en utilisant un bouton, soit depuis le menu contextuel de n\'importe quel point.</string>
|
||||
<string name="audionotes_plugin_name">Notes audio/vidéo</string>
|
||||
<string name="osmand_srtm_short_description_80_chars">Greffon OsmAnd pour les courbes de niveau hors-ligne</string>
|
||||
<string name="osmand_srtm_long_description_1000_chars">Ce greffon permet l\'affichage de courbes de niveau ainsi que du relief (ombres) qui s\'ajoutent au-dessus des cartes standard d\'OsmAnd. Ces informations sont particulièrement utiles pour les sportifs, les randonneurs, les cyclistes et d\'une manière générale par toutes les personnes qui souhaitent connaitre le relief.
|
||||
|
@ -993,7 +992,7 @@ Ces informations sont visibles sur le Tableau de bord comme sur la carte. Un rap
|
|||
<string name="plugin_distance_point_ele">altitude</string>
|
||||
<string name="gpx_file_name">Nom du fichier GPX</string>
|
||||
<string name="gpx_saved_sucessfully">Fichier GPX {0} enregistré</string>
|
||||
<string name="osmand_distance_planning_plugin_description">Ce greffon permet, depuis la carte, de créer un itinéraire soit un cliquant sur la carte, soit en ouvrant ou en modifiant un fichier GPX existant ainsi que de mesurer la distance entre des points. L\'itinéraire créé peut être enregistré dans un fichier GPX qui peut lui-même être utilisé ensuite pour une navigation.</string>
|
||||
<string name="osmand_distance_planning_plugin_description">Créez un itinéraire (soit en appuyant sur la carte soit en ouvrant un fichier GPX existant) et mesurez la distance entre points. Enregistrez ces itinéraires comme fichiers GPX et plus tard charger les pour vous faire guider.</string>
|
||||
<string name="osmand_distance_planning_plugin_name">Mesure de distance et Outil de planification</string>
|
||||
<string name="shared_string_do_not_show_again">Ne plus afficher</string>
|
||||
<string name="local_osm_changes_backup_successful">Fichier de modifications OSM %1$s généré avec succès</string>
|
||||
|
@ -1202,7 +1201,7 @@ Ces informations sont visibles sur le Tableau de bord comme sur la carte. Un rap
|
|||
<string name="gpx_file_is_empty">Fichier GPX vide</string>
|
||||
<string name="shared_string_tracks">Traces</string>
|
||||
<string name="shared_string_my_favorites">Favoris</string>
|
||||
<string name="shared_string_my_places">Favoris</string>
|
||||
<string name="shared_string_my_places">Mes lieux favoris</string>
|
||||
<string name="selected_gpx_info_show">\n\nAppui long pour afficher sur la carte</string>
|
||||
<string name="delay_navigation_start">Démarrer la navigation pas à pas automatiquement</string>
|
||||
<string name="shared_string_selected_lowercase">sélectionné(s)</string>
|
||||
|
@ -1434,7 +1433,7 @@ Ces informations sont visibles sur le Tableau de bord comme sur la carte. Un rap
|
|||
<string name="rendering_attr_pisteGrooming_name">Damage des pistes</string>
|
||||
<string name="free">%1$s libre</string>
|
||||
<string name="device_memory">Mémoire de l\'appareil</string>
|
||||
<string name="notes">Notes OSM</string>
|
||||
<string name="notes">Notes audio / vidéo</string>
|
||||
<string name="online_map">Carte en ligne</string>
|
||||
<string name="roads_only">Routes uniquement</string>
|
||||
<string name="rendering_attr_pisteRoutes_name">Pistes de ski</string>
|
||||
|
@ -1648,7 +1647,7 @@ Ces informations sont visibles sur le Tableau de bord comme sur la carte. Un rap
|
|||
<string name="contact_info">Contact</string>
|
||||
<string name="please_specify_poi_type">Merci d\'indiquer un type de point d\'intérêt.</string>
|
||||
<string name="working_days">Jours travaillés</string>
|
||||
<string name="recent_places">Emplacements récents</string>
|
||||
<string name="recent_places">Lieux récents</string>
|
||||
<string name="favourites">Favoris</string>
|
||||
<string name="show_on_start">Afficher au démarrage</string>
|
||||
<string name="show_gpx">Afficher les données GPX</string>
|
||||
|
@ -1804,7 +1803,7 @@ Ces informations sont visibles sur le Tableau de bord comme sur la carte. Un rap
|
|||
<string name="av_audio_bitrate_descr">Sélectionnez le bitrate audio</string>
|
||||
<string name="no_address_found">Impossible de déterminer l\'adresse</string>
|
||||
<string name="looking_up_address">Recherche de l\'adresse</string>
|
||||
<string name="update">Fréquence de mise à jour</string>
|
||||
<string name="update">Mise à jour</string>
|
||||
<string name="only_download_over_wifi">Télécharger uniquement en WiFi</string>
|
||||
<string name="live_update">Mise à jour en temps réel</string>
|
||||
<string name="rendering_attr_horseRoutes_name">Randonnée à cheval</string>
|
||||
|
@ -3376,7 +3375,7 @@ représentant la zone : %1$s x %2$s</string>
|
|||
<string name="rendering_attr_showCycleNodeNetworkRoutes_name">Afficher les pistes cyclables</string>
|
||||
<string name="rendering_value_walkingRoutesOSMCNodes_name">Réseaux</string>
|
||||
<string name="personal_category_name">Personnel</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="shared_string_downloading_formatted">Téléchargement %s</string>
|
||||
<string name="rendering_value_thick_name">Épais</string>
|
||||
|
@ -3441,4 +3440,15 @@ représentant la zone : %1$s x %2$s</string>
|
|||
<string name="monitoring_min_speed_descr">Filtre interrompant l\'enregistrement en dessous d\'une certaines vitesse. Rend les traces enregistrées plus régulières lorsqu\'elles sont affichées sur la carte.</string>
|
||||
<string name="live_monitoring_time_buffer">Durée de la mémoire tampon</string>
|
||||
<string name="live_monitoring_adress_descr">Indiquez l\'adresse web avec la syntaxe suivante pour les paramètres : lat = {0}, lon = {1}, horodatage = {2}, hdop = {3}, altitude = {4}, vitesse = {5}, direction = {6}.</string>
|
||||
<string name="monitoring_min_accuracy_descr_recommendation">Recommandation : il est difficile de prédire ce qui sera enregistré et ce qui ne le sera pas, il peut être préférable de désactiver ce filtre.</string>
|
||||
<string name="monitoring_min_distance_descr">Ce filtre limite l\'enregistrement de points en double lorsque les déplacements sont très lents donnant une apparence plus régulière aux traces.</string>
|
||||
<string name="monitoring_min_distance_descr_recommendation">Recommandation : un paramètre de 5 mètres est adapté si vous n\'avez pas besoin de détails et ne souhaitez pas enregistrer des points au repos.</string>
|
||||
<string name="monitoring_min_speed_descr_side_effect">Effet secondaire : votre trace ne contiendra pas les parties où la vitesse minimale n\'a pas été atteinte (par exemple lorsque vous poussez votre vélo en montée ou pendant une pause). De ce fait certaines informations de votre trace seront faussées comme la durée de déplacement ou la vitesse moyenne.</string>
|
||||
<string name="monitoring_min_speed_descr_recommendation">Recommandation : commencez par utiliser la détection de mouvement via le filtre de déplacement minimum (B) vous pourriez obtenir de meilleurs résultats en perdant moins de données. Si vos traces restent bruyantes à basse vitesse, essayez ici des valeurs non nulles. Veuillez noter que certaines mesures peuvent retourner une vitesse nulle (en raison de méthodes basées sur le réseau), dans ce cas rien ne sera enregistré.</string>
|
||||
<string name="monitoring_min_accuracy_descr">Seuls les points mesurés avec un minimum de précision en mètres/pieds (information communiquée par votre puce GPS) seront enregistrés. La précision fait référence à la dispersion de plusieurs mesures successives et n\'est pas directement liée à la distance entre ces mesures et votre position réelle.</string>
|
||||
<string name="monitoring_min_accuracy_descr_side_effect">Effet secondaire : avec le filtrage par précision certains points peuvent manquer ; par exemple : sous un pont, en forêt, entre de hauts bâtiments ou dans certaines conditions météorologiques.</string>
|
||||
<string name="monitoring_min_accuracy_descr_remark">Remarque : si la localisation GPS est activée juste avant le début d\'enregistrement, la première position peut être imprécise. L\'application pourrait attendre quelques secondes avant d\'enregistrer un point (ou enregistrer le meilleur de 3 points successifs, etc), mais ces évolutions ne sont pas encore disponibles.</string>
|
||||
<string name="tracks_view_path">Menu > Mes lieux favoris > Traces</string>
|
||||
<string name="multimedia_notes_view_path">Menu > Mes lieux favoris > Notes</string>
|
||||
<string name="osm_edits_view_path">Menu > Mes lieux favoris > Modifications OSM</string>
|
||||
</resources>
|
|
@ -3770,7 +3770,7 @@
|
|||
<string name="poi_volcano_type_maar">Maar</string>
|
||||
<string name="poi_volcano_type_caldera">Caldeira</string>
|
||||
<string name="poi_volcano_type_lava_dome">Cúpula de lava</string>
|
||||
<string name="poi_volcano_type_dirt">Terra</string>
|
||||
<string name="poi_volcano_type_mud">Terra</string>
|
||||
<string name="poi_volcano_last_eruption">Última erupción</string>
|
||||
<string name="poi_volcano_status_extinct">Extinguido</string>
|
||||
<string name="poi_volcano_status_dormant">Dormente</string>
|
||||
|
|
|
@ -3430,7 +3430,7 @@ Lon %2$s</string>
|
|||
<string name="add_new_profile_q">Engadir novo perfil \'%1$s\'\?</string>
|
||||
<string name="save_heading">Incluír encabezamento</string>
|
||||
<string name="save_heading_descr">Gardar encabezamento en cada punto da pista (trackpoint) mentres se grava.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Persoal</string>
|
||||
<string name="shared_string_downloading_formatted">Baixando %s</string>
|
||||
|
|
|
@ -3386,7 +3386,7 @@
|
|||
<string name="add_new_profile_q">להוסיף פרופיל חדש ‚%1&s’\?</string>
|
||||
<string name="save_heading">כולל הכותרת</string>
|
||||
<string name="save_heading_descr">לשמור את הכותרת של כל נקודת דרך בזמן ההקלטה.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">אישי</string>
|
||||
<string name="shared_string_downloading_formatted">%s בהורדה</string>
|
||||
|
|
|
@ -3770,7 +3770,7 @@
|
|||
<string name="poi_volcano_type_maar">Maar-vulkán</string>
|
||||
<string name="poi_volcano_type_caldera">Kaldera</string>
|
||||
<string name="poi_volcano_type_lava_dome">Lávakupola</string>
|
||||
<string name="poi_volcano_type_dirt">Sárvulkán</string>
|
||||
<string name="poi_volcano_type_mud">Sárvulkán</string>
|
||||
<string name="poi_volcano_last_eruption">Utolsó kitörés</string>
|
||||
<string name="poi_volcano_status_extinct">Kialudt</string>
|
||||
<string name="poi_volcano_status_dormant">Szunnyadó</string>
|
||||
|
|
|
@ -2388,7 +2388,7 @@ Ha szereted az OsmAndot és az OSM-et, és szeretnéd támogatni a fejlődésük
|
|||
<string name="ascendingly">A–Z</string>
|
||||
<string name="date_added">Hozzáadva</string>
|
||||
<string name="order_by">Rendezés alapja:</string>
|
||||
<string name="marker_show_distance_descr">"Válassza ki, hogyan jelenjék meg a térképen a térképjelölők távolsága és iránya:"</string>
|
||||
<string name="marker_show_distance_descr">Válassza ki, hogyan jelenjék meg a térképen a térképjelölők távolsága és iránya:</string>
|
||||
<string name="map_orientation_change_in_accordance_with_speed_descr">Válaszd ki, mekkora sebesség alatt váltson a térkép forgatása „Haladási irány”-ról „Iránytű”-re.</string>
|
||||
<string name="all_markers_moved_to_history">Minden térképjelölő áthelyezve az előzményekbe</string>
|
||||
<string name="marker_moved_to_history">Térképjelölő áthelyezve az előzményekhez</string>
|
||||
|
@ -3232,7 +3232,7 @@ Ha szereted az OsmAndot és az OSM-et, és szeretnéd támogatni a fejlődésük
|
|||
<string name="dialogs_and_notifications_descr">Felugró üzenetek, párbeszédablakok és értesítések beállításai.</string>
|
||||
<string name="suggested_maps">Javasolt térképek</string>
|
||||
<string name="add_new_profile_q">Hozzáadja az új „%1$s” profilt\?</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Személyes</string>
|
||||
<string name="shared_string_downloading_formatted">%s letöltése</string>
|
||||
|
|
|
@ -3407,7 +3407,7 @@ Stendur fyrir svæði: %1$s x %2$s</string>
|
|||
<string name="add_new_profile_q">Bæta við nýja sniðinu \'%1$s\'\?</string>
|
||||
<string name="save_heading">Hafa með stefnu</string>
|
||||
<string name="save_heading_descr">Vista stefnu í hvern ferilpunkt á meðan upptöku stendur.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Persónulegt</string>
|
||||
<string name="shared_string_downloading_formatted">Sæki %s</string>
|
||||
|
|
|
@ -3394,7 +3394,7 @@ Rappresenta l\'area: %1$s x %2$s</string>
|
|||
<string name="add_new_profile_q">Aggiungere il nuovo profilo \'%1$s\'\?</string>
|
||||
<string name="save_heading">Salva orientamento</string>
|
||||
<string name="save_heading_descr">Durante la registrazione salva l\'orientamento per ogni punto della traccia</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Personale</string>
|
||||
<string name="shared_string_downloading_formatted">Scaricamento %s</string>
|
||||
|
|
|
@ -3402,7 +3402,7 @@ POIの更新は利用できません</string>
|
|||
<string name="shared_string_downloading_formatted">をダウンロード中</string>
|
||||
<string name="rendering_value_thick_name">濃い</string>
|
||||
<string name="desert_render_descr">砂漠などの過疎地に向いたマップスタイルです。</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="select_navigation_icon">ナビゲーションアイコンの選択</string>
|
||||
<string name="select_map_icon">マップアイコンの選択</string>
|
||||
|
|
|
@ -361,7 +361,7 @@
|
|||
<string name="add_new_profile_q">ಹೊಸ ಪ್ರೊಫೈಲ್ ಸೇರಿಸುವುದೇ \'%1$s\'\?</string>
|
||||
<string name="save_heading">ಶೀರ್ಷಿಕೆಯನ್ನು ಸೇರಿಸಿ</string>
|
||||
<string name="save_heading_descr">ರೆಕಾರ್ಡಿಂಗ್ ಮಾಡುವಾಗ ಪ್ರತಿ ಟ್ರ್ಯಾಕ್ ಪಾಯಿಂಟ್ಗೆ ಶೀರ್ಷಿಕೆ ಉಳಿಸಿ.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">ವೈಯಕ್ತಿಕ</string>
|
||||
<string name="shared_string_downloading_formatted">ಡೌನ್ಲೋಡ್ ಮಾಡಲಾಗುತ್ತಿದೆ%s</string>
|
||||
|
|
|
@ -3405,7 +3405,7 @@
|
|||
<string name="added_profiles_descr">Programtillegg legger til ny profil i OsmAnd</string>
|
||||
<string name="shared_string_turn_off">Skru av</string>
|
||||
<string name="new_plugin_added">Nytt programtillegg lagt til</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Personlig</string>
|
||||
<string name="shared_string_downloading_formatted">Laster ned %s</string>
|
||||
|
|
|
@ -3276,7 +3276,7 @@ voor Gebied: %1$s x %2$s</string>
|
|||
<string name="save_heading_descr">Sla koers naar elk trackpunt op tijdens het opnemen.</string>
|
||||
<string name="save_heading">Richting toevoegen</string>
|
||||
<string name="personal_category_name">Persoonlijk</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="shared_string_downloading_formatted">Downloaden %s</string>
|
||||
<string name="desert_render_descr">Voor woestijnen en andere dunbevolkte gebieden. Toont meer details op schaal.</string>
|
||||
|
|
|
@ -3396,7 +3396,7 @@ Reprezentuje obszar: %1$s x %2$s</string>
|
|||
<string name="add_new_profile_q">Dodać nowy profil \'%1$s\'\?</string>
|
||||
<string name="save_heading">Dołącz kierunek</string>
|
||||
<string name="save_heading_descr">Zapisz podczas nagrywania kierunek do każdego punktu trasy.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Osobiste</string>
|
||||
<string name="shared_string_downloading_formatted">Pobieranie %s</string>
|
||||
|
|
|
@ -3777,7 +3777,7 @@
|
|||
<string name="poi_volcano_type_maar">Maar</string>
|
||||
<string name="poi_volcano_type_caldera">Caldeira</string>
|
||||
<string name="poi_volcano_type_lava_dome">Domo de lava</string>
|
||||
<string name="poi_volcano_type_dirt">Terra (lamacenta)</string>
|
||||
<string name="poi_volcano_type_mud">Terra (lamacenta)</string>
|
||||
<string name="poi_volcano_last_eruption">Última erupção</string>
|
||||
<string name="poi_volcano_status_extinct">Extinto</string>
|
||||
<string name="poi_volcano_status_dormant">Dormente</string>
|
||||
|
|
|
@ -344,7 +344,7 @@
|
|||
<string name="copying_osmand_files">Copiando arquivos de dados…</string>
|
||||
<string name="calculate_osmand_route_gpx">"Calcular rota off-line "</string>
|
||||
<string name="app_mode_truck">Caminhão</string>
|
||||
<string name="auto_zoom_far">Visão intermediária</string>
|
||||
<string name="auto_zoom_far">Para nível intermediário</string>
|
||||
<string name="local_index_tile_data_minzoom">Zoom mínimo: %1$s</string>
|
||||
<string name="edit_tilesource_successfully">A fonte da quadrícula %1$s foi salva</string>
|
||||
<string name="speak_traffic_warnings">Moderadores de tráfego</string>
|
||||
|
@ -537,8 +537,8 @@
|
|||
<string name="animate_routing_route">"Simular usando a rota calculada "</string>
|
||||
<string name="animate_routing_gpx">Simular usando trilha GPX</string>
|
||||
<string name="auto_zoom_none">Sem zoom automático</string>
|
||||
<string name="auto_zoom_close">Aproximar</string>
|
||||
<string name="auto_zoom_farthest">Afastar</string>
|
||||
<string name="auto_zoom_close">Para nível aproximado</string>
|
||||
<string name="auto_zoom_farthest">Para nível afastado</string>
|
||||
<string name="map_magnifier">Lupa</string>
|
||||
<string name="base_world_map">Mapa base mundial</string>
|
||||
<string name="about_version">Versão:</string>
|
||||
|
@ -3391,7 +3391,7 @@ Pôr do Sol: %2$s</string>
|
|||
<string name="add_new_profile_q">Adicionar novo perfil \'%1$s\'\?</string>
|
||||
<string name="save_heading">Incluir direção</string>
|
||||
<string name="save_heading_descr">Salve o cabeçalho em cada ponto da trilha durante a gravação.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Pessoal</string>
|
||||
<string name="shared_string_downloading_formatted">Baixando %s</string>
|
||||
|
|
|
@ -3762,7 +3762,7 @@
|
|||
<string name="poi_volcano_type_maar">Maar</string>
|
||||
<string name="poi_volcano_type_caldera">Caldera</string>
|
||||
<string name="poi_volcano_type_lava_dome">Cúpula de lava</string>
|
||||
<string name="poi_volcano_type_dirt">Sujeira</string>
|
||||
<string name="poi_volcano_type_mud">Sujeira</string>
|
||||
<string name="poi_volcano_last_eruption">Última erupção</string>
|
||||
<string name="poi_volcano_status_extinct">Extinto</string>
|
||||
<string name="poi_volcano_status_dormant">Dormente</string>
|
||||
|
|
|
@ -3376,7 +3376,7 @@
|
|||
<string name="add_new_profile_q">Adicionar novo perfil \'%1$s\'\?</string>
|
||||
<string name="save_heading">Incluir a direção</string>
|
||||
<string name="save_heading_descr">Gravar direção para cada ponto de pista durante a gravação.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Pessoal</string>
|
||||
<string name="shared_string_downloading_formatted">Descarregando %s</string>
|
||||
|
|
|
@ -2653,7 +2653,7 @@
|
|||
<string name="add_new_profile_q">Adăugați un profil nou \'%1$s\'\?</string>
|
||||
<string name="save_heading">Includeți titlu</string>
|
||||
<string name="save_heading_descr">Salvați poziția fiecarui punct al traseului în timpul înregistrării.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Personal</string>
|
||||
<string name="shared_string_downloading_formatted">Descarcarea</string>
|
||||
|
|
|
@ -3650,7 +3650,7 @@
|
|||
<string name="poi_volcano_type_maar">Маар</string>
|
||||
<string name="poi_volcano_type_caldera">Калдера</string>
|
||||
<string name="poi_volcano_type_lava_dome">Лавовый купол</string>
|
||||
<string name="poi_volcano_type_dirt">Грязевой</string>
|
||||
<string name="poi_volcano_type_mud">Грязевой</string>
|
||||
<string name="poi_volcano_last_eruption">Последнее извержение</string>
|
||||
<string name="poi_volcano_status_extinct">Потухший</string>
|
||||
<string name="poi_volcano_status_dormant">Спящий</string>
|
||||
|
|
|
@ -3347,7 +3347,7 @@
|
|||
<string name="rendering_value_walkingRoutesOSMCNodes_name">Узловые сети</string>
|
||||
<string name="suggested_maps">Предлагаемые карты</string>
|
||||
<string name="join_segments">Объединить сегменты</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="desert_render_descr">Для пустынь и других малонаселенных районов. Отображает больше деталей на шкале просмотра.</string>
|
||||
<string name="select_navigation_icon">Выберите значок навигации</string>
|
||||
|
|
|
@ -3775,7 +3775,7 @@
|
|||
<string name="poi_volcano_type_maar">Maar</string>
|
||||
<string name="poi_volcano_type_caldera">Caldera</string>
|
||||
<string name="poi_volcano_type_lava_dome">Cùpola de lava</string>
|
||||
<string name="poi_volcano_type_dirt">Terra</string>
|
||||
<string name="poi_volcano_type_mud">Terra</string>
|
||||
<string name="poi_volcano_last_eruption">Ùrtima erutzione</string>
|
||||
<string name="poi_volcano_status_extinct">Istudadu</string>
|
||||
<string name="poi_volcano_status_dormant">Durmende</string>
|
||||
|
|
|
@ -3398,7 +3398,7 @@ Pro praghere iscrie su còdighe intreu</string>
|
|||
<string name="add_new_profile_q">Annanghere su profilu nou \'%1$s\'\?</string>
|
||||
<string name="save_heading">Inclue sa diretzione</string>
|
||||
<string name="save_heading_descr">Sarva sa diretzione pro cada puntu cando ses registrende.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Personale</string>
|
||||
<string name="shared_string_downloading_formatted">Iscarrighende %s</string>
|
||||
|
@ -3448,4 +3448,25 @@ Pro praghere iscrie su còdighe intreu</string>
|
|||
<string name="select_nav_icon_descr">As a bìdere s\'icona petzi durante sa navigatzione o su movimentu.</string>
|
||||
<string name="select_map_icon_descr">S\'icona de sa mapa aparit in sa mapa ebbia, e divenit s\'icona de navigatzione durante sa navigatzione.</string>
|
||||
<string name="logcat_buffer_descr">Inoghe podes pompiare e cumpartzire sos registros de s\'aplicatzione</string>
|
||||
<string name="search_offline_geo_error">Anàlisi de su geo intent \'%s\' fallida.</string>
|
||||
<string name="permission_is_required">Pro impreare custa optzione b\'at bisòngiu de unu permissu.</string>
|
||||
<string name="monitoring_min_speed_descr">Custu est unu filtru pro non registrare puntos in suta de una lestresa isseberada. Faghet in modu chi sas rastas registradas pàrgiant prus regulares cando benint pompiadas in sa mapa.</string>
|
||||
<string name="monitoring_min_speed_descr_side_effect">Efetu segundàriu: in sa rasta tua ant a mancare totu sas setziones in ue no as rispetadu su critèriu de sa lestresa mìnima (es. cando ispinghes sa bitzicleta tua cara a artu in unu montigru). Annotamala, non b\'ant a èssere informatziones a pitzu de sos perìodos de pasu, che a sas pàusas. Custu at a influentzare totu sas anàlisis o sos post-protzessamentos, a es. cando ses chirchende de determinare sa longària totale de su biàgiu tuo, su tempus in movimentu, o sa lestresa mèdia tua.</string>
|
||||
<string name="live_monitoring_tracking_interval">Intervallu de arrastamentu</string>
|
||||
<string name="live_monitoring_adress">Indiritzu web</string>
|
||||
<string name="live_monitoring_adress_descr">Dislinda s\'indiritzu web cun sa sintassi de paràmetros: lat={0}, lon={1}, marcadesutempus={2}, hdop={3}, artària={4}, lestresa={5}, diretzione={6}.</string>
|
||||
<string name="monitoring_notification">Notìfica</string>
|
||||
<string name="monitoring_min_speed">Lestresa mìnima</string>
|
||||
<string name="monitoring_min_accuracy">Acuradesa mìnima</string>
|
||||
<string name="monitoring_min_distance">Movimentu mìnimu</string>
|
||||
<string name="tracks_view_path">Menù — Logos meos — Rastas</string>
|
||||
<string name="multimedia_notes_view_path">Menù — Logos meos — Notas</string>
|
||||
<string name="osm_edits_view_path">Menù — Logos meos — Modìficas de OSM</string>
|
||||
<string name="reset_plugin_to_default">Riprìstina sas impostatziones predefinidas de s\'estensione</string>
|
||||
<string name="multimedia_use_system_camera">Imprea s\'aplicatzione de sistema</string>
|
||||
<string name="multimedia_photo_play_sound">Sonu de s\'oturadore de sa fotocàmera</string>
|
||||
<string name="osm_authorization_success">S\'autorizatzione est resèssida</string>
|
||||
<string name="monitoring_min_speed_descr_recommendation">Impòsitu: Proa a impreare, in antis, su rilevamentu de movimentu pro mèdiu de sul filtru de movimentu mìnimu (B). Diat pòdere produire risultados mègius, e tue dias pòdere pèrdere datos de mancu. Si sas rastas tuas abarrant burdellosas a lestresas bassas, proa a impreare inoghe valores diferentes dae zero. Pro praghere ammenta·ti chi carchi mèdida diat pòdere non rilevare perunu valore de lestresa (unas àteras maneras basadas in subra de sa retza), e chi in custu casu non dias registrare nudda.</string>
|
||||
<string name="monitoring_min_accuracy_descr_recommendation">Impòsitu: est prus difìtzile a intzertare ite at a èssere registradu e ite nono. Diat èssere mègius a istudare custu filtru.</string>
|
||||
<string name="live_monitoring_time_buffer">Intervallu tampone (buffer)</string>
|
||||
</resources>
|
|
@ -3382,7 +3382,7 @@ Zodpovedá oblasti: %1$s x %2$s</string>
|
|||
<string name="add_new_profile_q">Pridať nový profil \'%1$s\'\?</string>
|
||||
<string name="save_heading">Pridať nadpis</string>
|
||||
<string name="save_heading_descr">Pridať nadpis ku každému bodu trasy pri zázname.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Osobné</string>
|
||||
<string name="shared_string_downloading_formatted">Sťahujem %s</string>
|
||||
|
@ -3418,7 +3418,7 @@ Zodpovedá oblasti: %1$s x %2$s</string>
|
|||
<string name="live_monitoring_descr">Umožňuje zdieľanie polohy a zaznamenávanie výletu.</string>
|
||||
<string name="live_monitoring">Sledovanie online</string>
|
||||
<string name="save_track_logging_accuracy">Presnosť záznamu</string>
|
||||
<string name="tracks_view_descr">Všetky vaše zaznamenané stopy sú v \'Menu\' → \'Moje miesta\' → \'Stopy\', alebo v priečinku OsmAnd.</string>
|
||||
<string name="tracks_view_descr">Všetky vaše zaznamenané stopy sú v %1$s, alebo v priečinku OsmAnd.</string>
|
||||
<string name="multimedia_notes_view_descr">Všetky vaše OSM poznámky sú v \'Menu\' → \'Moje miesta\' → \'Zmeny v OSM\'.</string>
|
||||
<string name="video_notes">Video-poznámky</string>
|
||||
<string name="photo_notes">Foto-poznámky</string>
|
||||
|
|
|
@ -3274,7 +3274,7 @@ Koda predstavlja območje: %1$s x %2$s</string>
|
|||
<string name="rendering_value_walkingRoutesOSMCNodes_name">Omrežja vozlišč</string>
|
||||
<string name="save_heading">Vključi glavo</string>
|
||||
<string name="save_heading_descr">Shrani glavo k vsaki točki sledi med beleženjem.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Osebno</string>
|
||||
<string name="shared_string_downloading_formatted">Poteka prejemanje %s</string>
|
||||
|
|
|
@ -3394,7 +3394,7 @@
|
|||
<string name="add_new_profile_q">Додај нови профил ’%1$s’\?</string>
|
||||
<string name="save_heading">Укључи заглавље</string>
|
||||
<string name="save_heading_descr">Сачувај заглавље свакој тачки праћења приликом снимања.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Лични</string>
|
||||
<string name="shared_string_downloading_formatted">Преузимам %s</string>
|
||||
|
|
|
@ -3359,7 +3359,7 @@
|
|||
<string name="add_new_profile_q">\'%1$s\' yeni profil eklensin mi\?</string>
|
||||
<string name="save_heading">Başlığı dahil et</string>
|
||||
<string name="save_heading_descr">Kayıt sırasında her izleme noktasına başlığı kaydet.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Kişisel</string>
|
||||
<string name="shared_string_downloading_formatted">%s indiriliyor</string>
|
||||
|
|
|
@ -3765,7 +3765,7 @@
|
|||
<string name="poi_volcano_type_maar">Маар</string>
|
||||
<string name="poi_volcano_type_caldera">Кальдера</string>
|
||||
<string name="poi_volcano_type_lava_dome">Лавовий купол</string>
|
||||
<string name="poi_volcano_type_dirt">Брудовий</string>
|
||||
<string name="poi_volcano_type_mud">Брудовий</string>
|
||||
<string name="poi_volcano_last_eruption">Останнє виверження</string>
|
||||
<string name="poi_volcano_status_extinct">Вимерлий</string>
|
||||
<string name="poi_volcano_status_dormant">Сплячий</string>
|
||||
|
|
|
@ -1380,7 +1380,7 @@
|
|||
<string name="shared_string_dismiss">Відхилити</string>
|
||||
<string name="shared_string_audio">Аудіо</string>
|
||||
<string name="share_note">Поділитись нотаткою</string>
|
||||
<string name="notes">OSM примітки</string>
|
||||
<string name="notes">A/V примітки</string>
|
||||
<string name="online_map">Мережева мапа</string>
|
||||
<string name="roads_only">Тільки дороги</string>
|
||||
<string name="free">Вільно %1$s</string>
|
||||
|
@ -3394,7 +3394,7 @@
|
|||
<string name="add_new_profile_q">Додати новий профіль \'%1$s\'\?</string>
|
||||
<string name="save_heading">Зберегти заголовок</string>
|
||||
<string name="save_heading_descr">Зберегти заголовок для кожної точки треку під час запису.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Особистий</string>
|
||||
<string name="shared_string_downloading_formatted">Завантажується %s</string>
|
||||
|
|
|
@ -2798,7 +2798,7 @@
|
|||
<string name="download_map_dialog">下载地图对话框</string>
|
||||
<string name="suggested_maps">建议的地图</string>
|
||||
<string name="shared_string_turn_off">关闭</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="select_navigation_icon">选择导航图标</string>
|
||||
<string name="select_map_icon">选择地图图标</string>
|
||||
<string name="delete_profiles_descr">在您点击“应用”后,已删除的配置将永久丢失。</string>
|
||||
|
|
|
@ -3776,7 +3776,7 @@
|
|||
<string name="poi_volcano_type_maar">低平火山口</string>
|
||||
<string name="poi_volcano_type_caldera">破火山口</string>
|
||||
<string name="poi_volcano_type_lava_dome">火山穹丘</string>
|
||||
<string name="poi_volcano_type_dirt">火山灰</string>
|
||||
<string name="poi_volcano_type_mud">火山灰</string>
|
||||
<string name="poi_volcano_last_eruption">最後一次噴發</string>
|
||||
<string name="poi_volcano_status_extinct">死火山</string>
|
||||
<string name="poi_volcano_status_dormant">休眠火山</string>
|
||||
|
|
|
@ -3394,7 +3394,7 @@
|
|||
<string name="add_new_profile_q">新增新的設定檔「%1$s」?</string>
|
||||
<string name="save_heading">包含標題</string>
|
||||
<string name="save_heading_descr">在記錄時將標題儲存到每個追蹤點。</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">個人</string>
|
||||
<string name="shared_string_downloading_formatted">正在下載 %s</string>
|
||||
|
|
|
@ -422,6 +422,9 @@
|
|||
<color name="app_bar_main_light">#ff8800</color>
|
||||
<color name="status_bar_main_dark">#101112</color>
|
||||
<color name="status_bar_main_light">#E68200</color>
|
||||
<color name="navigation_bar_bg_light">#CCCCCC</color>
|
||||
<color name="navigation_bar_bg_dark">#2B2E31</color>
|
||||
|
||||
<color name="activity_background_dark">#17181a</color>
|
||||
<color name="activity_background_light">#f0f0f0</color>
|
||||
<color name="card_and_list_background_dark">#222526</color>
|
||||
|
|
|
@ -4169,7 +4169,7 @@
|
|||
<string name="poi_volcano_type_maar">Maar</string>
|
||||
<string name="poi_volcano_type_caldera">Caldera</string>
|
||||
<string name="poi_volcano_type_lava_dome">Lava dome</string>
|
||||
<string name="poi_volcano_type_dirt">Dirt</string>
|
||||
<string name="poi_volcano_type_mud">Mud</string>
|
||||
<string name="poi_volcano_last_eruption">Last eruption</string>
|
||||
<string name="poi_volcano_status_extinct">Extinct</string>
|
||||
<string name="poi_volcano_status_dormant">Dormant</string>
|
||||
|
@ -4179,4 +4179,15 @@
|
|||
|
||||
<string name="poi_memorial_ghost_bike">Ghost bike</string>
|
||||
|
||||
<string name="poi_paintball">Paintball</string>
|
||||
|
||||
<string name="poi_mountain_rescue">Mountain rescue</string>
|
||||
<string name="poi_shop_security">Security store</string>
|
||||
|
||||
<string name="poi_bowling_alley">Bowling center</string>
|
||||
|
||||
<string name="poi_piste_ref">Piste reference number</string>
|
||||
|
||||
<string name="poi_resort_hunting">Hunting base</string>
|
||||
|
||||
</resources>
|
||||
|
|
|
@ -11,6 +11,12 @@
|
|||
Thx - Hardy
|
||||
|
||||
-->
|
||||
<string name="rendering_attr_streetLightingNight_name">Show only at night</string>
|
||||
<string name="plugin_prefs_reset_successful">All plugin settings restored to default state.</string>
|
||||
<string name="profile_prefs_reset_successful">All profile settings restored to default state.</string>
|
||||
<string name="ltr_or_rtl_combine_via_slash">%1$s/%2$s</string>
|
||||
<string name="sunset_at">Sunset at %1$s</string>
|
||||
<string name="sunrise_at">Sunrise at %1$s</string>
|
||||
<string name="shared_string_routing">Routing</string>
|
||||
<string name="shared_string_custom_rendering_style">Custom rendering style</string>
|
||||
<string name="shared_string_include_data">Include additional data</string>
|
||||
|
@ -86,7 +92,7 @@
|
|||
<string name="edit_profiles_descr">OsmAnd default profiles cannot be deleted, but disabled (on the previous screen), or be sorted to the bottom.</string>
|
||||
<string name="edit_profiles">Edit profiles</string>
|
||||
<string name="select_nav_profile_dialog_message">The \'Navigation type\' governs how routes are calculated.</string>
|
||||
<string name="distance_and_address">%1$s • %2$s</string>
|
||||
<string name="ltr_or_rtl_combine_via_bold_point">%1$s • %2$s</string>
|
||||
<string name="street_city">%1$s, %2$s</string>
|
||||
<string name="personal_category_name">Personal</string>
|
||||
<string name="add_new_profile_q">Add the new profile \'%1$s\'?</string>
|
||||
|
|
|
@ -33,6 +33,13 @@
|
|||
android:layout="@layout/preference_category_with_descr"
|
||||
android:title="@string/save_track_logging_accuracy" />
|
||||
|
||||
<net.osmand.plus.settings.preferences.ListPreferenceEx
|
||||
android:key="save_global_track_interval"
|
||||
android:layout="@layout/preference_with_descr"
|
||||
android:title="@string/save_global_track_interval"
|
||||
tools:icon="@drawable/ic_action_time_span"
|
||||
tools:summary="3 seconds" />
|
||||
|
||||
<net.osmand.plus.settings.preferences.ListPreferenceEx
|
||||
android:key="save_track_min_distance"
|
||||
android:layout="@layout/preference_with_descr"
|
||||
|
|
|
@ -1,7 +1,6 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android">
|
||||
<Preference android:key="general_settings" android:title="@string/general_settings_2" android:summary="@string/general_settings_descr"/>
|
||||
<Preference android:key="application_profiles" android:title="@string/application_profiles" android:summary="@string/application_profiles_descr"/>
|
||||
<Preference android:key="routing_settings" android:title="@string/routing_settings_2" android:summary="@string/routing_settings_descr"/>
|
||||
<Preference android:key="subscription_settings" android:title="@string/osm_live_subscription" android:summary="@string/osm_live_subscription_desc"/>
|
||||
<Preference android:key="privacy_and_security" android:title="@string/settings_privacy_and_security" android:summary="@string/settings_privacy_and_security_desc"/>
|
||||
|
|
|
@ -180,6 +180,7 @@ public class AccessibilitySettingsFragment extends BaseSettingsFragment implemen
|
|||
OsmandMonitoringPlugin plugin = OsmandPlugin.getPlugin(OsmandMonitoringPlugin.class);
|
||||
if (plugin != null) {
|
||||
app.getSettings().copyProfilePreferences(appMode, getSelectedAppMode(), plugin.getPreferences());
|
||||
updateAllSettings();
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -188,6 +189,8 @@ public class AccessibilitySettingsFragment extends BaseSettingsFragment implemen
|
|||
OsmandMonitoringPlugin plugin = OsmandPlugin.getPlugin(OsmandMonitoringPlugin.class);
|
||||
if (plugin != null) {
|
||||
app.getSettings().resetProfilePreferences(appMode, plugin.getPreferences());
|
||||
app.showToastMessage(R.string.plugin_prefs_reset_successful);
|
||||
updateAllSettings();
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -3,7 +3,6 @@ package net.osmand.data;
|
|||
import java.io.Serializable;
|
||||
|
||||
import android.content.Context;
|
||||
import android.content.res.Resources;
|
||||
import android.support.annotation.DrawableRes;
|
||||
import android.support.annotation.NonNull;
|
||||
import android.support.annotation.StringRes;
|
||||
|
@ -19,7 +18,6 @@ public class FavouritePoint implements Serializable, LocationPoint {
|
|||
|
||||
private static final String HIDDEN = "hidden";
|
||||
private static final String ADDRESS_EXTENSION = "address";
|
||||
private static final String DEFAULT_ICON_NAME = "special_star";
|
||||
|
||||
protected String name = "";
|
||||
protected String description;
|
||||
|
@ -139,6 +137,8 @@ public class FavouritePoint implements Serializable, LocationPoint {
|
|||
public int getOverlayIconId() {
|
||||
if (isSpecialPoint()) {
|
||||
return specialPointType.getIconId();
|
||||
} else if (iconId == 0) {
|
||||
return R.drawable.mx_special_star;
|
||||
}
|
||||
return iconId;
|
||||
}
|
||||
|
@ -202,7 +202,6 @@ public class FavouritePoint implements Serializable, LocationPoint {
|
|||
return "Favourite " + getName(); //$NON-NLS-1$
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public boolean equals(Object o) {
|
||||
if (this == o) return true;
|
||||
|
@ -253,7 +252,6 @@ public class FavouritePoint implements Serializable, LocationPoint {
|
|||
return result;
|
||||
}
|
||||
|
||||
|
||||
public enum SpecialPointType {
|
||||
HOME("home", R.string.home_button, R.drawable.mx_special_house),
|
||||
WORK("work", R.string.work_button, R.drawable.mx_special_building),
|
||||
|
@ -286,7 +284,6 @@ public class FavouritePoint implements Serializable, LocationPoint {
|
|||
}
|
||||
}
|
||||
|
||||
|
||||
public static FavouritePoint fromWpt(@NonNull WptPt pt, @NonNull Context ctx) {
|
||||
String name = pt.name;
|
||||
String categoryName = pt.category != null ? pt.category : "";
|
||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,5 +1,8 @@
|
|||
package net.osmand.plus;
|
||||
|
||||
import android.app.Activity;
|
||||
import android.location.GnssNavigationMessage;
|
||||
import android.location.GnssStatus;
|
||||
import android.os.Build.VERSION;
|
||||
import android.os.Build.VERSION_CODES;
|
||||
import java.util.ArrayList;
|
||||
|
@ -17,7 +20,6 @@ import net.osmand.binary.GeocodingUtilities.GeocodingResult;
|
|||
import net.osmand.binary.RouteDataObject;
|
||||
import net.osmand.data.LatLon;
|
||||
import net.osmand.data.QuadPoint;
|
||||
import net.osmand.plus.OsmandSettings.OsmandPreference;
|
||||
import net.osmand.plus.TargetPointsHelper.TargetPoint;
|
||||
import net.osmand.plus.routing.RoutingHelper;
|
||||
import net.osmand.router.RouteSegmentResult;
|
||||
|
@ -127,7 +129,7 @@ public class OsmAndLocationProvider implements SensorEventListener {
|
|||
|
||||
private List<OsmAndLocationListener> locationListeners = new ArrayList<OsmAndLocationProvider.OsmAndLocationListener>();
|
||||
private List<OsmAndCompassListener> compassListeners = new ArrayList<OsmAndLocationProvider.OsmAndCompassListener>();
|
||||
private Listener gpsStatusListener;
|
||||
private Object gpsStatusListener;
|
||||
private float[] mRotationM = new float[9];
|
||||
|
||||
|
||||
|
@ -249,7 +251,7 @@ public class OsmAndLocationProvider implements SensorEventListener {
|
|||
}
|
||||
}
|
||||
if (isLocationPermissionAvailable(app)) {
|
||||
service.addGpsStatusListener(getGpsStatusListener(service));
|
||||
registerGpsStatusListener(service);
|
||||
try {
|
||||
service.requestLocationUpdates(LocationManager.GPS_PROVIDER, GPS_TIMEOUT_REQUEST, GPS_DIST_REQUEST, gpsListener);
|
||||
} catch (IllegalArgumentException e) {
|
||||
|
@ -291,17 +293,55 @@ public class OsmAndLocationProvider implements SensorEventListener {
|
|||
}
|
||||
}
|
||||
|
||||
private Listener getGpsStatusListener(final LocationManager service) {
|
||||
gpsStatusListener = new Listener() {
|
||||
private GpsStatus gpsStatus;
|
||||
@Override
|
||||
public void onGpsStatusChanged(int event) {
|
||||
gpsStatus = service.getGpsStatus(gpsStatus);
|
||||
updateGPSInfo(gpsStatus);
|
||||
updateLocation(location);
|
||||
}
|
||||
};
|
||||
return gpsStatusListener;
|
||||
private void registerGpsStatusListener(final LocationManager service) {
|
||||
if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
|
||||
gpsStatusListener = new GnssStatus.Callback() {
|
||||
|
||||
@Override
|
||||
public void onStarted() {
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onStopped() {
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onFirstFix(int ttffMillis) {
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onSatelliteStatusChanged(GnssStatus status) {
|
||||
int satCount = 0;
|
||||
boolean fixed = false;
|
||||
int u = 0;
|
||||
if(status != null) {
|
||||
satCount = status.getSatelliteCount();
|
||||
for (int i = 0; i < satCount; i++) {
|
||||
if (status.usedInFix(i)) {
|
||||
u++;
|
||||
fixed = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
gpsInfo.fixed = fixed;
|
||||
gpsInfo.foundSatellites = satCount;
|
||||
gpsInfo.usedSatellites = u;
|
||||
updateLocation(location);
|
||||
}
|
||||
};
|
||||
service.registerGnssStatusCallback((GnssStatus.Callback) gpsStatusListener);
|
||||
} else {
|
||||
gpsStatusListener = new Listener() {
|
||||
private GpsStatus gpsStatus;
|
||||
@Override
|
||||
public void onGpsStatusChanged(int event) {
|
||||
gpsStatus = service.getGpsStatus(gpsStatus);
|
||||
updateGPSInfo(gpsStatus);
|
||||
updateLocation(location);
|
||||
}
|
||||
};
|
||||
service.addGpsStatusListener((Listener) gpsStatusListener);
|
||||
}
|
||||
}
|
||||
|
||||
private void updateGPSInfo(GpsStatus s) {
|
||||
|
@ -642,7 +682,13 @@ public class OsmAndLocationProvider implements SensorEventListener {
|
|||
|
||||
private void stopLocationRequests() {
|
||||
LocationManager service = (LocationManager) app.getSystemService(Context.LOCATION_SERVICE);
|
||||
service.removeGpsStatusListener(gpsStatusListener);
|
||||
if(gpsStatusListener != null) {
|
||||
if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
|
||||
service.unregisterGnssStatusCallback((GnssStatus.Callback) gpsStatusListener);
|
||||
} else {
|
||||
service.removeGpsStatusListener((Listener) gpsStatusListener);
|
||||
}
|
||||
}
|
||||
service.removeUpdates(gpsListener);
|
||||
while(!networkListeners.isEmpty()) {
|
||||
service.removeUpdates(networkListeners.poll());
|
||||
|
@ -975,4 +1021,12 @@ public class OsmAndLocationProvider implements SensorEventListener {
|
|||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
public static void requestFineLocationPermissionIfNeeded(Activity activity) {
|
||||
if (!isLocationPermissionAvailable(activity)) {
|
||||
ActivityCompat.requestPermissions(activity,
|
||||
new String[]{Manifest.permission.ACCESS_FINE_LOCATION},
|
||||
OsmAndLocationProvider.REQUEST_LOCATION_PERMISSION);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -19,6 +19,10 @@ import android.support.annotation.StringRes;
|
|||
import android.support.v4.util.Pair;
|
||||
import android.support.v7.preference.PreferenceDataStore;
|
||||
|
||||
import com.google.gson.Gson;
|
||||
import com.google.gson.GsonBuilder;
|
||||
import com.google.gson.reflect.TypeToken;
|
||||
|
||||
import net.osmand.IndexConstants;
|
||||
import net.osmand.StateChangedListener;
|
||||
import net.osmand.ValueHolder;
|
||||
|
@ -30,6 +34,8 @@ import net.osmand.map.ITileSource;
|
|||
import net.osmand.map.TileSourceManager;
|
||||
import net.osmand.map.TileSourceManager.TileSourceTemplate;
|
||||
import net.osmand.osm.io.NetworkUtils;
|
||||
import net.osmand.plus.ApplicationMode.ApplicationModeBean;
|
||||
import net.osmand.plus.ApplicationMode.ApplicationModeBuilder;
|
||||
import net.osmand.plus.access.AccessibilityMode;
|
||||
import net.osmand.plus.access.RelativeDirectionStyle;
|
||||
import net.osmand.plus.api.SettingsAPI;
|
||||
|
@ -39,7 +45,11 @@ import net.osmand.plus.dialogs.RateUsBottomSheetDialogFragment;
|
|||
import net.osmand.plus.helpers.SearchHistoryHelper;
|
||||
import net.osmand.plus.mapillary.MapillaryPlugin;
|
||||
import net.osmand.plus.mapmarkers.CoordinateInputFormats.Format;
|
||||
import net.osmand.plus.profiles.LocationIcon;
|
||||
import net.osmand.plus.profiles.NavigationIcon;
|
||||
import net.osmand.plus.profiles.ProfileIconColors;
|
||||
import net.osmand.plus.render.RendererRegistry;
|
||||
import net.osmand.plus.routing.RouteProvider.RouteService;
|
||||
import net.osmand.plus.voice.CommandPlayer;
|
||||
import net.osmand.render.RenderingRulesStorage;
|
||||
import net.osmand.util.Algorithms;
|
||||
|
@ -50,6 +60,7 @@ import org.json.JSONObject;
|
|||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
import java.lang.ref.WeakReference;
|
||||
import java.lang.reflect.Type;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Arrays;
|
||||
import java.util.Collections;
|
||||
|
@ -81,6 +92,8 @@ public class OsmandSettings {
|
|||
|
||||
void resetToDefault();
|
||||
|
||||
void resetModeToDefault(ApplicationMode m);
|
||||
|
||||
void overrideDefaultValue(T newDefaultValue);
|
||||
|
||||
void addListener(StateChangedListener<T> listener);
|
||||
|
@ -212,11 +225,16 @@ public class OsmandSettings {
|
|||
}
|
||||
|
||||
public static String getSharedPreferencesName(ApplicationMode mode) {
|
||||
String modeKey = mode != null ? mode.getStringKey() : null;
|
||||
return getSharedPreferencesNameForKey(modeKey);
|
||||
}
|
||||
|
||||
public static String getSharedPreferencesNameForKey(String modeKey) {
|
||||
String sharedPreferencesName = !Algorithms.isEmpty(CUSTOM_SHARED_PREFERENCES_NAME) ? CUSTOM_SHARED_PREFERENCES_NAME : SHARED_PREFERENCES_NAME;
|
||||
if (mode == null) {
|
||||
if (modeKey == null) {
|
||||
return sharedPreferencesName;
|
||||
} else {
|
||||
return sharedPreferencesName + "." + mode.getStringKey().toLowerCase();
|
||||
return sharedPreferencesName + "." + modeKey.toLowerCase();
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -266,6 +284,20 @@ public class OsmandSettings {
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
String json = settingsAPI.getString(globalPreferences, "custom_app_profiles", "");
|
||||
if (!Algorithms.isEmpty(json)) {
|
||||
Gson gson = new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create();
|
||||
Type t = new TypeToken<ArrayList<ApplicationModeBean>>() {
|
||||
}.getType();
|
||||
List<ApplicationModeBean> customProfiles = gson.fromJson(json, t);
|
||||
if (!Algorithms.isEmpty(customProfiles)) {
|
||||
for (ApplicationModeBean modeBean : customProfiles) {
|
||||
ApplicationModeBuilder builder = ApplicationMode.fromModeBean(ctx, modeBean);
|
||||
ApplicationMode.saveProfile(builder, ctx);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void migrateHomeWorkParkingToFavorites() {
|
||||
|
@ -295,6 +327,10 @@ public class OsmandSettings {
|
|||
return settingsAPI.getPreferenceObject(getSharedPreferencesName(mode));
|
||||
}
|
||||
|
||||
public Object getProfilePreferences(String modeKey) {
|
||||
return settingsAPI.getPreferenceObject(getSharedPreferencesNameForKey(modeKey));
|
||||
}
|
||||
|
||||
public OsmandPreference getPreference(String key) {
|
||||
return registeredPreferences.get(key);
|
||||
}
|
||||
|
@ -409,44 +445,41 @@ public class OsmandSettings {
|
|||
return false;
|
||||
}
|
||||
|
||||
public boolean copyPreferencesFromProfile(ApplicationMode modeFrom, ApplicationMode modeTo) {
|
||||
return copyProfilePreferences(modeFrom, modeTo, new ArrayList<OsmandPreference>(registeredPreferences.values()));
|
||||
public void copyPreferencesFromProfile(ApplicationMode modeFrom, ApplicationMode modeTo) {
|
||||
copyProfilePreferences(modeFrom, modeTo, new ArrayList<OsmandPreference>(registeredPreferences.values()));
|
||||
}
|
||||
|
||||
public boolean copyProfilePreferences(ApplicationMode modeFrom, ApplicationMode modeTo, List<OsmandPreference> profilePreferences) {
|
||||
SettingsEditor settingsEditor = settingsAPI.edit(getProfilePreferences(modeTo));
|
||||
public void copyProfilePreferences(ApplicationMode modeFrom, ApplicationMode modeTo, List<OsmandPreference> profilePreferences) {
|
||||
for (OsmandPreference pref : profilePreferences) {
|
||||
if (pref instanceof CommonPreference && !((CommonPreference) pref).global) {
|
||||
if (prefCanBeCopiedOrReset(pref) && !USER_PROFILE_NAME.getId().equals(pref.getId())) {
|
||||
CommonPreference profilePref = (CommonPreference) pref;
|
||||
Object copiedValue = profilePref.getModeValue(modeFrom);
|
||||
if (copiedValue instanceof String) {
|
||||
settingsEditor.putString(pref.getId(), (String) copiedValue);
|
||||
} else if (copiedValue instanceof Boolean) {
|
||||
settingsEditor.putBoolean(pref.getId(), (Boolean) copiedValue);
|
||||
} else if (copiedValue instanceof Float) {
|
||||
settingsEditor.putFloat(pref.getId(), (Float) copiedValue);
|
||||
} else if (copiedValue instanceof Integer) {
|
||||
settingsEditor.putInt(pref.getId(), (Integer) copiedValue);
|
||||
} else if (copiedValue instanceof Long) {
|
||||
settingsEditor.putLong(pref.getId(), (Long) copiedValue);
|
||||
if (PARENT_APP_MODE.getId().equals(pref.getId())) {
|
||||
if (modeTo.isCustomProfile()) {
|
||||
modeTo.setParentAppMode(modeFrom.isCustomProfile() ? modeFrom.getParent() : modeFrom);
|
||||
}
|
||||
} else {
|
||||
Object copiedValue = profilePref.getModeValue(modeFrom);
|
||||
profilePref.setModeValue(modeTo, copiedValue);
|
||||
}
|
||||
}
|
||||
}
|
||||
return settingsEditor.commit();
|
||||
}
|
||||
|
||||
public boolean resetPreferencesForProfile(ApplicationMode mode) {
|
||||
return settingsAPI.edit(getProfilePreferences(mode)).clear().commit();
|
||||
public void resetPreferencesForProfile(ApplicationMode mode) {
|
||||
resetProfilePreferences(mode, new ArrayList<OsmandPreference>(registeredPreferences.values()));
|
||||
}
|
||||
|
||||
public boolean resetProfilePreferences(ApplicationMode mode, List<OsmandPreference> profilePreferences) {
|
||||
SettingsEditor settingsEditor = settingsAPI.edit(getProfilePreferences(mode));
|
||||
public void resetProfilePreferences(ApplicationMode mode, List<OsmandPreference> profilePreferences) {
|
||||
for (OsmandPreference pref : profilePreferences) {
|
||||
if (pref instanceof CommonPreference && !((CommonPreference) pref).global) {
|
||||
settingsEditor.remove(pref.getId());
|
||||
if (prefCanBeCopiedOrReset(pref)) {
|
||||
pref.resetModeToDefault(mode);
|
||||
}
|
||||
}
|
||||
return settingsEditor.commit();
|
||||
}
|
||||
|
||||
private boolean prefCanBeCopiedOrReset(OsmandPreference pref) {
|
||||
return pref instanceof CommonPreference && !((CommonPreference) pref).global
|
||||
&& !APP_MODE_ORDER.getId().equals(pref.getId());
|
||||
}
|
||||
|
||||
public ApplicationMode LAST_ROUTING_APPLICATION_MODE = null;
|
||||
|
@ -474,6 +507,11 @@ public class OsmandSettings {
|
|||
set(ApplicationMode.DEFAULT);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void resetModeToDefault(ApplicationMode m) {
|
||||
throw new UnsupportedOperationException();
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isSet() {
|
||||
return true;
|
||||
|
@ -747,6 +785,16 @@ public class OsmandSettings {
|
|||
set(o);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void resetModeToDefault(ApplicationMode mode) {
|
||||
if (global) {
|
||||
resetToDefault();
|
||||
} else {
|
||||
T o = getProfileDefaultValue(mode);
|
||||
setModeValue(mode, o);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean set(T obj) {
|
||||
Object prefs = getPreferences();
|
||||
|
@ -1219,11 +1267,7 @@ public class OsmandSettings {
|
|||
|
||||
public final OsmandPreference<String> LAST_FAV_CATEGORY_ENTERED = new StringPreference("last_fav_category", "").makeGlobal();
|
||||
|
||||
|
||||
public final OsmandPreference<ApplicationMode> DEFAULT_APPLICATION_MODE = new CommonPreference<ApplicationMode>("default_application_mode_string", ApplicationMode.DEFAULT) {
|
||||
{
|
||||
makeGlobal();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected ApplicationMode getValue(Object prefs, ApplicationMode defaultValue) {
|
||||
|
@ -1271,12 +1315,9 @@ public class OsmandSettings {
|
|||
public ApplicationMode parseString(String s) {
|
||||
return appModeFromString(s);
|
||||
}
|
||||
};
|
||||
}.makeGlobal();
|
||||
|
||||
public final OsmandPreference<ApplicationMode> LAST_ROUTE_APPLICATION_MODE = new CommonPreference<ApplicationMode>("last_route_application_mode_backup_string", ApplicationMode.DEFAULT) {
|
||||
{
|
||||
makeGlobal();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected ApplicationMode getValue(Object prefs, ApplicationMode defaultValue) {
|
||||
|
@ -1319,7 +1360,7 @@ public class OsmandSettings {
|
|||
public ApplicationMode parseString(String s) {
|
||||
return appModeFromString(s);
|
||||
}
|
||||
};
|
||||
}.makeGlobal();
|
||||
|
||||
public final OsmandPreference<Boolean> FIRST_MAP_IS_DOWNLOADED = new BooleanPreference(
|
||||
"first_map_is_downloaded", false);
|
||||
|
@ -1334,8 +1375,6 @@ public class OsmandSettings {
|
|||
return super.setValue(prefs, val);
|
||||
}
|
||||
|
||||
;
|
||||
|
||||
protected DrivingRegion getDefaultValue() {
|
||||
Locale df = Locale.getDefault();
|
||||
if (df == null) {
|
||||
|
@ -1349,9 +1388,8 @@ public class OsmandSettings {
|
|||
return DrivingRegion.JAPAN;
|
||||
} else if (df.getCountry().equalsIgnoreCase("au")) {
|
||||
return DrivingRegion.AUSTRALIA;
|
||||
// potentially wrong in Europe
|
||||
// } else if(df.getCountry().equalsIgnoreCase(Locale.UK.getCountry())) {
|
||||
// return DrivingRegion.UK_AND_OTHERS;
|
||||
} else if(df.getCountry().equalsIgnoreCase(Locale.UK.getCountry())) {
|
||||
return DrivingRegion.UK_AND_OTHERS;
|
||||
}
|
||||
return DrivingRegion.EUROPE_ASIA;
|
||||
}
|
||||
|
@ -1373,6 +1411,29 @@ public class OsmandSettings {
|
|||
public final OsmandPreference<AngularConstants> ANGULAR_UNITS = new EnumIntPreference<AngularConstants>(
|
||||
"angular_measurement", AngularConstants.DEGREES, AngularConstants.values()).makeProfile();
|
||||
|
||||
public static final String LAST_START_LAT = "last_searched_lat"; //$NON-NLS-1$
|
||||
public static final String LAST_START_LON = "last_searched_lon"; //$NON-NLS-1$
|
||||
|
||||
public LatLon getLastStartPoint() {
|
||||
if (settingsAPI.contains(globalPreferences, LAST_START_LAT) && settingsAPI.contains(globalPreferences, LAST_START_LON)) {
|
||||
return new LatLon(settingsAPI.getFloat(globalPreferences, LAST_START_LAT, 0),
|
||||
settingsAPI.getFloat(globalPreferences, LAST_START_LON, 0));
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public boolean setLastStartPoint(LatLon l) {
|
||||
if (l == null) {
|
||||
return settingsAPI.edit(globalPreferences).remove(LAST_START_LAT).remove(LAST_START_LON).commit();
|
||||
} else {
|
||||
return setLastStartPoint(l.getLatitude(), l.getLongitude());
|
||||
}
|
||||
}
|
||||
|
||||
public boolean setLastStartPoint(double lat, double lon) {
|
||||
return settingsAPI.edit(globalPreferences).putFloat(LAST_START_LAT, (float) lat).
|
||||
putFloat(LAST_START_LON, (float) lon).commit();
|
||||
}
|
||||
|
||||
public final OsmandPreference<SpeedConstants> SPEED_SYSTEM = new EnumIntPreference<SpeedConstants>(
|
||||
"default_speed_system", SpeedConstants.KILOMETERS_PER_HOUR, SpeedConstants.values()) {
|
||||
|
@ -1398,9 +1459,6 @@ public class OsmandSettings {
|
|||
return SpeedConstants.MILES_PER_HOUR;
|
||||
}
|
||||
}
|
||||
|
||||
;
|
||||
|
||||
}.makeProfile();
|
||||
|
||||
|
||||
|
@ -1424,8 +1482,17 @@ public class OsmandSettings {
|
|||
public final OsmandPreference<Float> SPEED_LIMIT_EXCEED =
|
||||
new FloatPreference("speed_limit_exceed", 5f).makeProfile();
|
||||
|
||||
public final OsmandPreference<Float> DEFAULT_SPEED = new FloatPreference(
|
||||
"default_speed", 0f).makeProfile().cache();
|
||||
public final CommonPreference<Float> DEFAULT_SPEED = new FloatPreference("default_speed", 10f).makeProfile().cache();
|
||||
|
||||
{
|
||||
DEFAULT_SPEED.setModeDefaultValue(ApplicationMode.DEFAULT, 1.5f);
|
||||
DEFAULT_SPEED.setModeDefaultValue(ApplicationMode.CAR, 12.5f);
|
||||
DEFAULT_SPEED.setModeDefaultValue(ApplicationMode.BICYCLE, 2.77f);
|
||||
DEFAULT_SPEED.setModeDefaultValue(ApplicationMode.PEDESTRIAN, 1.11f);
|
||||
DEFAULT_SPEED.setModeDefaultValue(ApplicationMode.BOAT, 1.38f);
|
||||
DEFAULT_SPEED.setModeDefaultValue(ApplicationMode.AIRCRAFT, 40f);
|
||||
DEFAULT_SPEED.setModeDefaultValue(ApplicationMode.SKI, 1.38f);
|
||||
}
|
||||
|
||||
public final OsmandPreference<Float> MIN_SPEED = new FloatPreference(
|
||||
"min_speed", 0f).makeProfile().cache();
|
||||
|
@ -1433,6 +1500,67 @@ public class OsmandSettings {
|
|||
public final OsmandPreference<Float> MAX_SPEED = new FloatPreference(
|
||||
"max_speed", 0f).makeProfile().cache();
|
||||
|
||||
public final CommonPreference<String> ICON_RES_NAME = new StringPreference("app_mode_icon_res_name", "ic_world_globe_dark").makeProfile().cache();
|
||||
|
||||
{
|
||||
ICON_RES_NAME.setModeDefaultValue(ApplicationMode.DEFAULT, "ic_world_globe_dark");
|
||||
ICON_RES_NAME.setModeDefaultValue(ApplicationMode.CAR, "ic_action_car_dark");
|
||||
ICON_RES_NAME.setModeDefaultValue(ApplicationMode.BICYCLE, "ic_action_bicycle_dark");
|
||||
ICON_RES_NAME.setModeDefaultValue(ApplicationMode.PEDESTRIAN, "ic_action_pedestrian_dark");
|
||||
ICON_RES_NAME.setModeDefaultValue(ApplicationMode.PUBLIC_TRANSPORT, "ic_action_bus_dark");
|
||||
ICON_RES_NAME.setModeDefaultValue(ApplicationMode.BOAT, "ic_action_sail_boat_dark");
|
||||
ICON_RES_NAME.setModeDefaultValue(ApplicationMode.AIRCRAFT, "ic_action_aircraft");
|
||||
ICON_RES_NAME.setModeDefaultValue(ApplicationMode.SKI, "ic_action_skiing");
|
||||
}
|
||||
|
||||
public final CommonPreference<ProfileIconColors> ICON_COLOR = new EnumIntPreference<>("app_mode_icon_color", ProfileIconColors.DEFAULT, ProfileIconColors.values()).makeProfile().cache();
|
||||
|
||||
public final CommonPreference<String> USER_PROFILE_NAME = new StringPreference("user_profile_name", "").makeProfile().cache();
|
||||
|
||||
public final CommonPreference<String> PARENT_APP_MODE = new StringPreference("parent_app_mode", null).makeProfile().cache();
|
||||
|
||||
public final CommonPreference<String> ROUTING_PROFILE = new StringPreference("routing_profile", "").makeProfile().cache();
|
||||
|
||||
{
|
||||
ROUTING_PROFILE.setModeDefaultValue(ApplicationMode.CAR, "car");
|
||||
ROUTING_PROFILE.setModeDefaultValue(ApplicationMode.BICYCLE, "bicycle");
|
||||
ROUTING_PROFILE.setModeDefaultValue(ApplicationMode.PEDESTRIAN, "pedestrian");
|
||||
ROUTING_PROFILE.setModeDefaultValue(ApplicationMode.PUBLIC_TRANSPORT, "public_transport");
|
||||
ROUTING_PROFILE.setModeDefaultValue(ApplicationMode.BOAT, "boat");
|
||||
ROUTING_PROFILE.setModeDefaultValue(ApplicationMode.AIRCRAFT, "STRAIGHT_LINE_MODE");
|
||||
ROUTING_PROFILE.setModeDefaultValue(ApplicationMode.SKI, "ski");
|
||||
}
|
||||
|
||||
public final CommonPreference<RouteService> ROUTE_SERVICE = new EnumIntPreference<>("route_service", RouteService.OSMAND, RouteService.values()).makeProfile().cache();
|
||||
|
||||
{
|
||||
ROUTE_SERVICE.setModeDefaultValue(ApplicationMode.AIRCRAFT, RouteService.STRAIGHT);
|
||||
}
|
||||
|
||||
public final CommonPreference<NavigationIcon> NAVIGATION_ICON = new EnumIntPreference<>("navigation_icon", NavigationIcon.DEFAULT, NavigationIcon.values()).makeProfile().cache();
|
||||
|
||||
{
|
||||
NAVIGATION_ICON.setModeDefaultValue(ApplicationMode.DEFAULT, NavigationIcon.DEFAULT);
|
||||
NAVIGATION_ICON.setModeDefaultValue(ApplicationMode.CAR, NavigationIcon.DEFAULT);
|
||||
NAVIGATION_ICON.setModeDefaultValue(ApplicationMode.BICYCLE, NavigationIcon.DEFAULT);
|
||||
NAVIGATION_ICON.setModeDefaultValue(ApplicationMode.BOAT, NavigationIcon.NAUTICAL);
|
||||
NAVIGATION_ICON.setModeDefaultValue(ApplicationMode.AIRCRAFT, NavigationIcon.DEFAULT);
|
||||
NAVIGATION_ICON.setModeDefaultValue(ApplicationMode.SKI, NavigationIcon.DEFAULT);
|
||||
}
|
||||
|
||||
public final CommonPreference<LocationIcon> LOCATION_ICON = new EnumIntPreference<>("location_icon", LocationIcon.DEFAULT, LocationIcon.values()).makeProfile().cache();
|
||||
|
||||
{
|
||||
LOCATION_ICON.setModeDefaultValue(ApplicationMode.DEFAULT, LocationIcon.DEFAULT);
|
||||
LOCATION_ICON.setModeDefaultValue(ApplicationMode.CAR, LocationIcon.CAR);
|
||||
LOCATION_ICON.setModeDefaultValue(ApplicationMode.BICYCLE, LocationIcon.BICYCLE);
|
||||
LOCATION_ICON.setModeDefaultValue(ApplicationMode.BOAT, LocationIcon.DEFAULT);
|
||||
LOCATION_ICON.setModeDefaultValue(ApplicationMode.AIRCRAFT, LocationIcon.CAR);
|
||||
LOCATION_ICON.setModeDefaultValue(ApplicationMode.SKI, LocationIcon.BICYCLE);
|
||||
}
|
||||
|
||||
public final CommonPreference<Integer> APP_MODE_ORDER = new IntPreference("app_mode_order", 0).makeProfile().cache();
|
||||
|
||||
public final OsmandPreference<Float> SWITCH_MAP_DIRECTION_TO_COMPASS =
|
||||
new FloatPreference("speed_for_map_to_direction_of_movement", 0f).makeProfile();
|
||||
|
||||
|
@ -1588,8 +1716,6 @@ public class OsmandSettings {
|
|||
}
|
||||
return -1;
|
||||
}
|
||||
|
||||
;
|
||||
}.makeGlobal().cache();
|
||||
|
||||
public final CommonPreference<Boolean> SNAP_TO_ROAD = new BooleanPreference("snap_to_road", false).makeProfile().cache();
|
||||
|
@ -3057,9 +3183,6 @@ public class OsmandSettings {
|
|||
|
||||
// this value string is synchronized with settings_pref.xml preference name
|
||||
public final CommonPreference<String> RENDERER = new StringPreference("renderer", RendererRegistry.DEFAULT_RENDER) {
|
||||
{
|
||||
makeProfile();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected boolean setValue(Object prefs, String val) {
|
||||
|
@ -3068,13 +3191,12 @@ public class OsmandSettings {
|
|||
}
|
||||
RenderingRulesStorage loaded = ctx.getRendererRegistry().getRenderer(val);
|
||||
if (loaded != null) {
|
||||
super.setValue(prefs, val);
|
||||
return true;
|
||||
return super.setValue(prefs, val);
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
};
|
||||
}.makeProfile();
|
||||
|
||||
{
|
||||
RENDERER.setModeDefaultValue(ApplicationMode.BOAT, RendererRegistry.NAUTICAL_RENDER);
|
||||
|
@ -3256,12 +3378,18 @@ public class OsmandSettings {
|
|||
RateUsBottomSheetDialogFragment.RateUsState.INITIAL_STATE, RateUsBottomSheetDialogFragment.RateUsState.values())
|
||||
.makeGlobal();
|
||||
|
||||
public final CommonPreference<String> DEFAULT_APP_PROFILES =
|
||||
new StringPreference("default_app_profiles", "").makeGlobal().cache();
|
||||
|
||||
public final CommonPreference<String> CUSTOM_APP_PROFILES =
|
||||
new StringPreference("custom_app_profiles", "").makeGlobal().cache();
|
||||
public final CommonPreference<String> CUSTOM_APP_MODES_KEYS =
|
||||
new StringPreference("custom_app_modes_keys", "").makeGlobal().cache();
|
||||
|
||||
public Set<String> getCustomAppModesKeys() {
|
||||
String appModesKeys = CUSTOM_APP_MODES_KEYS.get();
|
||||
StringTokenizer toks = new StringTokenizer(appModesKeys, ",");
|
||||
Set<String> res = new LinkedHashSet<String>();
|
||||
while (toks.hasMoreTokens()) {
|
||||
res.add(toks.nextToken());
|
||||
}
|
||||
return res;
|
||||
}
|
||||
|
||||
public enum DayNightMode {
|
||||
AUTO(R.string.daynight_mode_auto, R.drawable.ic_action_map_sunset),
|
||||
|
@ -3555,6 +3683,18 @@ public class OsmandSettings {
|
|||
DRIVING_REGION_AUTOMATIC
|
||||
};
|
||||
|
||||
String[] appModeBeanPrefsIds = new String[] {
|
||||
ICON_COLOR.getId(),
|
||||
ICON_RES_NAME.getId(),
|
||||
PARENT_APP_MODE.getId(),
|
||||
ROUTING_PROFILE.getId(),
|
||||
ROUTE_SERVICE.getId(),
|
||||
USER_PROFILE_NAME.getId(),
|
||||
LOCATION_ICON.getId(),
|
||||
NAVIGATION_ICON.getId(),
|
||||
APP_MODE_ORDER.getId()
|
||||
};
|
||||
|
||||
public class PreferencesDataStore extends PreferenceDataStore {
|
||||
|
||||
private ApplicationMode appMode;
|
||||
|
|
|
@ -10,6 +10,7 @@ import android.support.annotation.Nullable;
|
|||
import android.support.v7.app.AlertDialog;
|
||||
|
||||
import net.osmand.PlatformUtil;
|
||||
import net.osmand.plus.ApplicationMode.ApplicationModeBean;
|
||||
import net.osmand.plus.ApplicationMode.ApplicationModeBuilder;
|
||||
import net.osmand.plus.OsmandSettings.OsmandPreference;
|
||||
import net.osmand.plus.poi.PoiUIFilter;
|
||||
|
@ -38,10 +39,12 @@ import java.io.InputStreamReader;
|
|||
import java.io.OutputStream;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Arrays;
|
||||
import java.util.HashSet;
|
||||
import java.util.Iterator;
|
||||
import java.util.LinkedHashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Set;
|
||||
import java.util.zip.ZipEntry;
|
||||
import java.util.zip.ZipInputStream;
|
||||
import java.util.zip.ZipOutputStream;
|
||||
|
@ -411,15 +414,20 @@ public class SettingsHelper {
|
|||
|
||||
private ApplicationMode appMode;
|
||||
private ApplicationModeBuilder builder;
|
||||
private ApplicationModeBean modeBean;
|
||||
private Set<String> appModeBeanPrefsIds;
|
||||
|
||||
|
||||
public ProfileSettingsItem(@NonNull OsmandSettings settings, @NonNull ApplicationMode appMode) {
|
||||
super(SettingsItemType.PROFILE, settings);
|
||||
this.appMode = appMode;
|
||||
appModeBeanPrefsIds = new HashSet<>(Arrays.asList(settings.appModeBeanPrefsIds));
|
||||
}
|
||||
|
||||
public ProfileSettingsItem(@NonNull OsmandSettings settings, @NonNull JSONObject json) throws JSONException {
|
||||
super(SettingsItemType.PROFILE, settings, json);
|
||||
readFromJson(settings.getContext(), json);
|
||||
appModeBeanPrefsIds = new HashSet<>(Arrays.asList(settings.appModeBeanPrefsIds));
|
||||
}
|
||||
|
||||
@NonNull
|
||||
|
@ -432,7 +440,7 @@ public class SettingsHelper {
|
|||
@Override
|
||||
public String getPublicName(@NonNull Context ctx) {
|
||||
if (appMode.isCustomProfile()) {
|
||||
return appMode.getCustomProfileName();
|
||||
return modeBean.userProfileName;
|
||||
} else if (appMode.getNameKeyResource() != -1) {
|
||||
return ctx.getString(appMode.getNameKeyResource());
|
||||
} else {
|
||||
|
@ -448,7 +456,8 @@ public class SettingsHelper {
|
|||
|
||||
void readFromJson(@NonNull OsmandApplication app, @NonNull JSONObject json) throws JSONException {
|
||||
String appModeJson = json.getString("appMode");
|
||||
builder = ApplicationMode.fromJson(app, appModeJson);
|
||||
modeBean = ApplicationMode.fromJson(appModeJson);
|
||||
builder = ApplicationMode.fromModeBean(app, modeBean);
|
||||
ApplicationMode appMode = builder.getApplicationMode();
|
||||
if (!appMode.isCustomProfile()) {
|
||||
appMode = ApplicationMode.valueOfStringKey(appMode.getStringKey(), appMode);
|
||||
|
@ -485,7 +494,9 @@ public class SettingsHelper {
|
|||
return new OsmandSettingsItemReader(this, getSettings()) {
|
||||
@Override
|
||||
protected void readPreferenceFromJson(@NonNull OsmandPreference<?> preference, @NonNull JSONObject json) throws JSONException {
|
||||
preference.readFromJson(json, appMode);
|
||||
if (!appModeBeanPrefsIds.contains(preference.getId())) {
|
||||
preference.readFromJson(json, appMode);
|
||||
}
|
||||
}
|
||||
};
|
||||
}
|
||||
|
@ -496,7 +507,9 @@ public class SettingsHelper {
|
|||
return new OsmandSettingsItemWriter(this, getSettings()) {
|
||||
@Override
|
||||
protected void writePreferenceToJson(@NonNull OsmandPreference<?> preference, @NonNull JSONObject json) throws JSONException {
|
||||
preference.writeToJson(json, appMode);
|
||||
if (!appModeBeanPrefsIds.contains(preference.getId())) {
|
||||
preference.writeToJson(json, appMode);
|
||||
}
|
||||
}
|
||||
};
|
||||
}
|
||||
|
|
|
@ -445,6 +445,7 @@ public class TargetPointsHelper {
|
|||
Location lastKnownLocation = ctx.getLocationProvider().getLastKnownLocation();
|
||||
LatLon latLon = lastKnownLocation != null ?
|
||||
new LatLon(lastKnownLocation.getLatitude(), lastKnownLocation.getLongitude()) : null;
|
||||
routingHelper.checkAndUpdateStartLocation(latLon);
|
||||
setMyLocationPoint(latLon, false, null);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -954,7 +954,7 @@ public class FavoritesTreeFragment extends OsmandExpandableListFragment implemen
|
|||
name.setTextColor(getResources().getColor(visible ? enabledColor : disabledColor));
|
||||
distanceText.setText(distance);
|
||||
if (model.isAddressSpecified()) {
|
||||
distanceText.setText(String.format(getString(R.string.distance_and_address), distance.trim(), model.getAddress()));
|
||||
distanceText.setText(String.format(getString(R.string.ltr_or_rtl_combine_via_bold_point), distance.trim(), model.getAddress()));
|
||||
}
|
||||
icon.setImageDrawable(FavoriteImageDrawable.getOrCreate(getActivity(),
|
||||
visible ? model.getColor() : getResources().getColor(disabledIconColor), false, model));
|
||||
|
|
|
@ -116,7 +116,6 @@ import net.osmand.plus.mapmarkers.PlanRouteFragment;
|
|||
import net.osmand.plus.measurementtool.MeasurementEditingContext;
|
||||
import net.osmand.plus.measurementtool.MeasurementToolFragment;
|
||||
import net.osmand.plus.measurementtool.NewGpxData;
|
||||
import net.osmand.plus.profiles.EditProfileFragment;
|
||||
import net.osmand.plus.quickaction.QuickActionListFragment;
|
||||
import net.osmand.plus.render.RendererRegistry;
|
||||
import net.osmand.plus.resources.ResourceManager;
|
||||
|
@ -675,13 +674,6 @@ public class MapActivity extends OsmandActionBarActivity implements DownloadEven
|
|||
chooseRouteFragment.dismiss(true);
|
||||
return;
|
||||
}
|
||||
EditProfileFragment editProfileFragment = getEditProfileFragment();
|
||||
if (editProfileFragment != null) {
|
||||
if (!editProfileFragment.onBackPressedAllowed()) {
|
||||
editProfileFragment.confirmCancelDialog(this);
|
||||
return;
|
||||
}
|
||||
}
|
||||
ProfileAppearanceFragment profileAppearanceFragment = getProfileAppearanceFragment();
|
||||
if (profileAppearanceFragment != null) {
|
||||
if (profileAppearanceFragment.isProfileAppearanceChanged(this)) {
|
||||
|
@ -859,21 +851,21 @@ public class MapActivity extends OsmandActionBarActivity implements DownloadEven
|
|||
}
|
||||
setIntent(null);
|
||||
}
|
||||
if (intent.hasExtra(EditProfileFragment.OPEN_SETTINGS)) {
|
||||
String settingsType = intent.getStringExtra(EditProfileFragment.OPEN_SETTINGS);
|
||||
String appMode = intent.getStringExtra(EditProfileFragment.SELECTED_ITEM);
|
||||
if (EditProfileFragment.OPEN_CONFIG_PROFILE.equals(settingsType)) {
|
||||
if (intent.hasExtra(BaseSettingsFragment.OPEN_SETTINGS)) {
|
||||
String settingsType = intent.getStringExtra(BaseSettingsFragment.OPEN_SETTINGS);
|
||||
String appMode = intent.getStringExtra(BaseSettingsFragment.APP_MODE_KEY);
|
||||
if (BaseSettingsFragment.OPEN_CONFIG_PROFILE.equals(settingsType)) {
|
||||
BaseSettingsFragment.showInstance(this, SettingsScreenType.CONFIGURE_PROFILE, ApplicationMode.valueOfStringKey(appMode, null));
|
||||
}
|
||||
setIntent(null);
|
||||
}
|
||||
if (intent.hasExtra(EditProfileFragment.OPEN_CONFIG_ON_MAP)) {
|
||||
switch (intent.getStringExtra(EditProfileFragment.OPEN_CONFIG_ON_MAP)) {
|
||||
case EditProfileFragment.MAP_CONFIG:
|
||||
if (intent.hasExtra(BaseSettingsFragment.OPEN_CONFIG_ON_MAP)) {
|
||||
switch (intent.getStringExtra(BaseSettingsFragment.OPEN_CONFIG_ON_MAP)) {
|
||||
case BaseSettingsFragment.MAP_CONFIG:
|
||||
this.getDashboard().setDashboardVisibility(true, DashboardType.CONFIGURE_MAP, null);
|
||||
break;
|
||||
|
||||
case EditProfileFragment.SCREEN_CONFIG:
|
||||
case BaseSettingsFragment.SCREEN_CONFIG:
|
||||
this.getDashboard().setDashboardVisibility(true, DashboardType.CONFIGURE_SCREEN, null);
|
||||
break;
|
||||
}
|
||||
|
@ -1520,6 +1512,7 @@ public class MapActivity extends OsmandActionBarActivity implements DownloadEven
|
|||
|
||||
mapLayers.updateLayers(mapView);
|
||||
mapActions.updateDrawerMenu();
|
||||
updateNavigationBarColor();
|
||||
mapView.setComplexZoom(mapView.getZoom(), mapView.getSettingsMapDensity());
|
||||
app.getDaynightHelper().startSensorIfNeeded(new StateChangedListener<Boolean>() {
|
||||
|
||||
|
@ -1532,6 +1525,16 @@ public class MapActivity extends OsmandActionBarActivity implements DownloadEven
|
|||
applyScreenOrientation();
|
||||
}
|
||||
|
||||
public void updateNavigationBarColor() {
|
||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
|
||||
if (getMyApplication().getDaynightHelper().isNightModeForMapControls() || getMyApplication().getDaynightHelper().isNightMode()) {
|
||||
getWindow().setNavigationBarColor(ContextCompat.getColor(app, R.color.navigation_bar_bg_dark));
|
||||
} else {
|
||||
getWindow().setNavigationBarColor(ContextCompat.getColor(app, R.color.navigation_bar_bg_light));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void updateMapSettings() {
|
||||
if (app.isApplicationInitializing()) {
|
||||
return;
|
||||
|
@ -1655,7 +1658,7 @@ public class MapActivity extends OsmandActionBarActivity implements DownloadEven
|
|||
}
|
||||
return super.onKeyUp(keyCode, event);
|
||||
}
|
||||
|
||||
|
||||
private void scrollMap(int dx, int dy) {
|
||||
final RotatedTileBox tb = mapView.getCurrentRotatedTileBox();
|
||||
final QuadPoint cp = tb.getCenterPixelPoint();
|
||||
|
@ -2009,7 +2012,7 @@ public class MapActivity extends OsmandActionBarActivity implements DownloadEven
|
|||
}
|
||||
|
||||
if (requestCode == DataStorageFragment.PERMISSIONS_REQUEST_WRITE_EXTERNAL_STORAGE
|
||||
&& grantResults.length > 0 && permissions.length > 0
|
||||
&& permissions.length > 0
|
||||
&& Manifest.permission.WRITE_EXTERNAL_STORAGE.equals(permissions[0])) {
|
||||
if (grantResults[0] != PackageManager.PERMISSION_GRANTED) {
|
||||
Toast.makeText(this,
|
||||
|
@ -2017,12 +2020,12 @@ public class MapActivity extends OsmandActionBarActivity implements DownloadEven
|
|||
Toast.LENGTH_LONG).show();
|
||||
}
|
||||
} else if (requestCode == DownloadActivity.PERMISSIONS_REQUEST_WRITE_EXTERNAL_STORAGE
|
||||
&& grantResults.length > 0 && permissions.length > 0
|
||||
&& permissions.length > 0
|
||||
&& Manifest.permission.WRITE_EXTERNAL_STORAGE.equals(permissions[0])) {
|
||||
permissionAsked = true;
|
||||
permissionGranted = grantResults[0] == PackageManager.PERMISSION_GRANTED;
|
||||
} else if (requestCode == FirstUsageWizardFragment.FIRST_USAGE_REQUEST_WRITE_EXTERNAL_STORAGE_PERMISSION
|
||||
&& grantResults.length > 0 && permissions.length > 0
|
||||
&& permissions.length > 0
|
||||
&& Manifest.permission.WRITE_EXTERNAL_STORAGE.equals(permissions[0])) {
|
||||
|
||||
new Timer().schedule(new TimerTask() {
|
||||
|
@ -2045,7 +2048,7 @@ public class MapActivity extends OsmandActionBarActivity implements DownloadEven
|
|||
}
|
||||
}, 1);
|
||||
} else if (requestCode == MapActivityActions.REQUEST_LOCATION_FOR_DIRECTIONS_NAVIGATION_PERMISSION
|
||||
&& grantResults.length > 0 && permissions.length > 0
|
||||
&& permissions.length > 0
|
||||
&& Manifest.permission.ACCESS_FINE_LOCATION.equals(permissions[0])) {
|
||||
if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {
|
||||
LatLon latLon = getContextMenu().getLatLon();
|
||||
|
@ -2409,10 +2412,6 @@ public class MapActivity extends OsmandActionBarActivity implements DownloadEven
|
|||
return getFragment(ChooseRouteFragment.TAG);
|
||||
}
|
||||
|
||||
public EditProfileFragment getEditProfileFragment() {
|
||||
return getFragment(EditProfileFragment.TAG);
|
||||
}
|
||||
|
||||
public ProfileAppearanceFragment getProfileAppearanceFragment() {
|
||||
return getFragment(ProfileAppearanceFragment.TAG);
|
||||
}
|
||||
|
|
|
@ -673,7 +673,7 @@ public class MapActivityActions implements DialogProvider {
|
|||
for (final ApplicationMode appMode : activeModes) {
|
||||
if (appMode.isCustomProfile()) {
|
||||
modeDescription = String.format(app.getString(R.string.profile_type_descr_string),
|
||||
Algorithms.capitalizeFirstLetterAndLowercase(appMode.getParent().toHumanString(app)));
|
||||
Algorithms.capitalizeFirstLetterAndLowercase(appMode.getParent().toHumanString()));
|
||||
} else {
|
||||
modeDescription = getString(R.string.profile_type_base_string);
|
||||
}
|
||||
|
@ -684,7 +684,7 @@ public class MapActivityActions implements DialogProvider {
|
|||
.setIcon(appMode.getIconRes())
|
||||
.setColor(appMode.getIconColorInfo().getColor(nightMode))
|
||||
.setTag(tag)
|
||||
.setTitle(appMode.toHumanString(app))
|
||||
.setTitle(appMode.toHumanString())
|
||||
.setDescription(modeDescription)
|
||||
.setListener(new ItemClickListener() {
|
||||
@Override
|
||||
|
@ -994,7 +994,7 @@ public class MapActivityActions implements DialogProvider {
|
|||
String modeDescription;
|
||||
if (currentMode.isCustomProfile()) {
|
||||
modeDescription = String.format(app.getString(R.string.profile_type_descr_string),
|
||||
Algorithms.capitalizeFirstLetterAndLowercase(currentMode.getParent().toHumanString(app)));
|
||||
Algorithms.capitalizeFirstLetterAndLowercase(currentMode.getParent().toHumanString()));
|
||||
} else {
|
||||
modeDescription = getString(R.string.profile_type_base_string);
|
||||
}
|
||||
|
@ -1004,7 +1004,7 @@ public class MapActivityActions implements DialogProvider {
|
|||
.setIcon(currentMode.getIconRes())
|
||||
.setSecondaryIcon(icArrowResId)
|
||||
.setColor(currentMode.getIconColorInfo().getColor(nightMode))
|
||||
.setTitle(currentMode.toHumanString(app))
|
||||
.setTitle(currentMode.toHumanString())
|
||||
.setDescription(modeDescription)
|
||||
.setListener(new ItemClickListener() {
|
||||
@Override
|
||||
|
|
|
@ -14,7 +14,6 @@ import net.osmand.plus.OsmandPlugin;
|
|||
import net.osmand.plus.R;
|
||||
import net.osmand.plus.Version;
|
||||
import net.osmand.plus.liveupdates.OsmLiveActivity;
|
||||
import net.osmand.plus.profiles.SettingsProfileActivity;
|
||||
|
||||
public class SettingsActivity extends SettingsBaseActivity {
|
||||
|
||||
|
@ -29,7 +28,6 @@ public class SettingsActivity extends SettingsBaseActivity {
|
|||
private Preference general;
|
||||
private Preference routing;
|
||||
private Preference subscription;
|
||||
private Preference profiles;
|
||||
private Preference privacy;
|
||||
|
||||
|
||||
|
@ -43,8 +41,6 @@ public class SettingsActivity extends SettingsBaseActivity {
|
|||
general.setOnPreferenceClickListener(this);
|
||||
routing = (Preference) screen.findPreference("routing_settings");
|
||||
routing.setOnPreferenceClickListener(this);
|
||||
profiles = (Preference) screen.findPreference("application_profiles");
|
||||
profiles.setOnPreferenceClickListener(this);
|
||||
subscription = (Preference) screen.findPreference("subscription_settings");
|
||||
subscription.setOnPreferenceClickListener(this);
|
||||
privacy = (Preference) screen.findPreference("privacy_and_security");
|
||||
|
@ -95,9 +91,6 @@ public class SettingsActivity extends SettingsBaseActivity {
|
|||
if (preference == general) {
|
||||
startActivity(new Intent(this, SettingsGeneralActivity.class));
|
||||
return true;
|
||||
} else if (preference == profiles){
|
||||
startActivity(new Intent(this, SettingsProfileActivity.class));
|
||||
return true;
|
||||
} else if (preference == routing) {
|
||||
startActivity(new Intent(this, SettingsNavigationActivity.class));
|
||||
return true;
|
||||
|
|
|
@ -386,7 +386,7 @@ public abstract class SettingsBaseActivity extends ActionBarPreferenceActivity
|
|||
|
||||
if (am != ApplicationMode.DEFAULT || !(this instanceof SettingsNavigationActivity)) {
|
||||
activeModes.add(new ProfileDataObject(
|
||||
am.toHumanString(getMyApplication()),
|
||||
am.toHumanString(),
|
||||
getAppModeDescription(am),
|
||||
am.getStringKey(),
|
||||
am.getIconRes(),
|
||||
|
@ -429,7 +429,7 @@ public abstract class SettingsBaseActivity extends ActionBarPreferenceActivity
|
|||
void updateModeButton(ApplicationMode mode) {
|
||||
OsmandApplication app = getMyApplication();
|
||||
boolean nightMode = !app.getSettings().isLightContent();
|
||||
String title = mode.toHumanString(SettingsBaseActivity.this);
|
||||
String title = mode.toHumanString();
|
||||
|
||||
getModeTitleTV().setText(title);
|
||||
getModeSubTitleTV().setText(getAppModeDescription(mode));
|
||||
|
@ -448,7 +448,7 @@ public abstract class SettingsBaseActivity extends ActionBarPreferenceActivity
|
|||
descr = getString(R.string.profile_type_base_string);
|
||||
} else {
|
||||
descr = String.format(getString(R.string.profile_type_descr_string),
|
||||
mode.getParent().toHumanString(getMyApplication()));
|
||||
mode.getParent().toHumanString());
|
||||
if (mode.getRoutingProfile() != null && mode.getRoutingProfile().contains("/")) {
|
||||
descr = descr.concat(", " + mode.getRoutingProfile()
|
||||
.substring(0, mode.getRoutingProfile().indexOf("/")));
|
||||
|
|
|
@ -1,7 +1,6 @@
|
|||
package net.osmand.plus.activities;
|
||||
|
||||
|
||||
import android.app.Activity;
|
||||
import android.app.Dialog;
|
||||
import android.content.Context;
|
||||
import android.content.DialogInterface;
|
||||
|
@ -91,7 +90,7 @@ public class SettingsGeneralActivity extends SettingsBaseActivity implements OnR
|
|||
ApplicationMode[] appModes = ApplicationMode.values(app).toArray(new ApplicationMode[0]);
|
||||
entries = new String[appModes.length];
|
||||
for (int i = 0; i < entries.length; i++) {
|
||||
entries[i] = appModes[i].toHumanString(app);
|
||||
entries[i] = appModes[i].toHumanString();
|
||||
}
|
||||
registerListPreference(settings.DEFAULT_APPLICATION_MODE, screen, entries, appModes);
|
||||
|
||||
|
@ -545,7 +544,7 @@ public class SettingsGeneralActivity extends SettingsBaseActivity implements OnR
|
|||
super.updateAllSettings();
|
||||
updateApplicationDirTextAndSummary();
|
||||
applicationModePreference.setTitle(getString(R.string.settings_preset) + " ["
|
||||
+ settings.APPLICATION_MODE.get().toHumanString(getMyApplication()) + "]");
|
||||
+ settings.APPLICATION_MODE.get().toHumanString() + "]");
|
||||
drivingRegionPreference.setTitle(getString(R.string.driving_region) + " ["
|
||||
+ getString(settings.DRIVING_REGION_AUTOMATIC.get() ? R.string.driving_region_automatic : settings.DRIVING_REGION.get().name) + "]");
|
||||
}
|
||||
|
|
|
@ -755,8 +755,8 @@ public class SettingsNavigationActivity extends SettingsBaseActivity {
|
|||
break;
|
||||
}
|
||||
|
||||
float settingsMinSpeed = settings.MIN_SPEED.getModeValue(mode);
|
||||
float settingsMaxSpeed = settings.MAX_SPEED.getModeValue(mode);
|
||||
float settingsMinSpeed = mode.getMinSpeed();
|
||||
float settingsMaxSpeed = mode.getMaxSpeed();
|
||||
|
||||
final int[] defaultValue = {Math.round(mode.getDefaultSpeed() * ratio[0])};
|
||||
final int[] minValue = new int[1];
|
||||
|
@ -783,10 +783,10 @@ public class SettingsNavigationActivity extends SettingsBaseActivity {
|
|||
builder.setPositiveButton(R.string.shared_string_ok, new OnClickListener() {
|
||||
@Override
|
||||
public void onClick(DialogInterface dialog, int which) {
|
||||
mode.setDefaultSpeed(app, defaultValue[0] / ratio[0]);
|
||||
mode.setDefaultSpeed(defaultValue[0] / ratio[0]);
|
||||
if (!defaultSpeedOnly) {
|
||||
settings.MIN_SPEED.setModeValue(mode, minValue[0] / ratio[0]);
|
||||
settings.MAX_SPEED.setModeValue(mode, maxValue[0] / ratio[0]);
|
||||
mode.setMinSpeed(minValue[0] / ratio[0]);
|
||||
mode.setMaxSpeed(maxValue[0] / ratio[0]);
|
||||
}
|
||||
RoutingHelper routingHelper = app.getRoutingHelper();
|
||||
if (mode.equals(routingHelper.getAppMode()) && (routingHelper.isRouteCalculated() || routingHelper.isRouteBeingCalculated())) {
|
||||
|
@ -798,10 +798,10 @@ public class SettingsNavigationActivity extends SettingsBaseActivity {
|
|||
builder.setNeutralButton(R.string.shared_string_revert, new OnClickListener() {
|
||||
@Override
|
||||
public void onClick(DialogInterface dialog, int which) {
|
||||
mode.resetDefaultSpeed(app);
|
||||
mode.resetDefaultSpeed();
|
||||
if (!defaultSpeedOnly) {
|
||||
settings.MIN_SPEED.setModeValue(mode,0f);
|
||||
settings.MAX_SPEED.setModeValue(mode,0f);
|
||||
mode.setMinSpeed(0f);
|
||||
mode.setMaxSpeed(0f);
|
||||
}
|
||||
RoutingHelper routingHelper = app.getRoutingHelper();
|
||||
if (mode.equals(routingHelper.getAppMode()) && (routingHelper.isRouteCalculated() || routingHelper.isRouteBeingCalculated())) {
|
||||
|
|
|
@ -1,7 +1,6 @@
|
|||
package net.osmand.plus.activities.actions;
|
||||
|
||||
import android.app.Activity;
|
||||
import android.content.res.Configuration;
|
||||
import android.graphics.drawable.Drawable;
|
||||
import android.os.Build;
|
||||
import android.os.Build.VERSION_CODES;
|
||||
|
@ -117,7 +116,7 @@ public class AppModeDialog {
|
|||
ImageView iv = (ImageView) tb.findViewById(R.id.app_mode_icon);
|
||||
if (checked) {
|
||||
iv.setImageDrawable(ctx.getUIUtilities().getIcon(mode.getIconRes(), mode.getIconColorInfo().getColor(nightMode)));
|
||||
iv.setContentDescription(String.format("%s %s", mode.toHumanString(ctx), ctx.getString(R.string.item_checked)));
|
||||
iv.setContentDescription(String.format("%s %s", mode.toHumanString(), ctx.getString(R.string.item_checked)));
|
||||
selection.setBackgroundResource(mode.getIconColorInfo().getColor(nightMode));
|
||||
selection.setVisibility(View.VISIBLE);
|
||||
} else {
|
||||
|
@ -127,7 +126,7 @@ public class AppModeDialog {
|
|||
} else {
|
||||
iv.setImageDrawable(ctx.getUIUtilities().getThemedIcon(mode.getIconRes()));
|
||||
}
|
||||
iv.setContentDescription(String.format("%s %s", mode.toHumanString(ctx), ctx.getString(R.string.item_unchecked)));
|
||||
iv.setContentDescription(String.format("%s %s", mode.toHumanString(), ctx.getString(R.string.item_unchecked)));
|
||||
selection.setVisibility(View.INVISIBLE);
|
||||
}
|
||||
iv.setOnClickListener(new View.OnClickListener() {
|
||||
|
@ -170,7 +169,7 @@ public class AppModeDialog {
|
|||
Drawable drawable = ctx.getUIUtilities().getIcon(mode.getIconRes(), mode.getIconColorInfo().getColor(nightMode));
|
||||
if (checked) {
|
||||
iv.setImageDrawable(drawable);
|
||||
iv.setContentDescription(String.format("%s %s", mode.toHumanString(ctx), ctx.getString(R.string.item_checked)));
|
||||
iv.setContentDescription(String.format("%s %s", mode.toHumanString(), ctx.getString(R.string.item_checked)));
|
||||
if (Build.VERSION.SDK_INT > Build.VERSION_CODES.LOLLIPOP) {
|
||||
AndroidUtils.setBackground(ctx, iv, nightMode, R.drawable.btn_checked_border_light, R.drawable.btn_checked_border_light);
|
||||
AndroidUtils.setBackground(ctx, selection, nightMode, R.drawable.ripple_light, R.drawable.ripple_light);
|
||||
|
@ -193,7 +192,7 @@ public class AppModeDialog {
|
|||
} else {
|
||||
iv.setImageDrawable(ctx.getUIUtilities().getIcon(mode.getIconRes(), mode.getIconColorInfo().getColor(nightMode)));
|
||||
}
|
||||
iv.setContentDescription(String.format("%s %s", mode.toHumanString(ctx), ctx.getString(R.string.item_unchecked)));
|
||||
iv.setContentDescription(String.format("%s %s", mode.toHumanString(), ctx.getString(R.string.item_unchecked)));
|
||||
}
|
||||
tb.setOnClickListener(new View.OnClickListener() {
|
||||
|
||||
|
@ -229,7 +228,7 @@ public class AppModeDialog {
|
|||
View tb = layoutInflater.inflate(layoutId, null);
|
||||
ImageView iv = (ImageView) tb.findViewById(R.id.app_mode_icon);
|
||||
iv.setImageDrawable(ctx.getUIUtilities().getIcon(mode.getIconRes(), mode.getIconColorInfo().getColor(isNightMode(ctx, useMapTheme))));
|
||||
iv.setContentDescription(mode.toHumanString(ctx));
|
||||
iv.setContentDescription(mode.toHumanString());
|
||||
// tb.setCompoundDrawablesWithIntrinsicBounds(null, ctx.getIconsCache().getIcon(mode.getIconId(), R.color.app_mode_icon_color), null, null);
|
||||
LayoutParams lp = new LinearLayout.LayoutParams(metricsX, metricsY);
|
||||
// lp.setMargins(left, 0, 0, 0);
|
||||
|
|
|
@ -475,6 +475,7 @@ public class MultimediaNotesFragment extends BaseSettingsFragment implements Cop
|
|||
AudioVideoNotesPlugin plugin = OsmandPlugin.getPlugin(AudioVideoNotesPlugin.class);
|
||||
if (plugin != null) {
|
||||
app.getSettings().copyProfilePreferences(appMode, getSelectedAppMode(), plugin.getPreferences());
|
||||
updateAllSettings();
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -483,6 +484,8 @@ public class MultimediaNotesFragment extends BaseSettingsFragment implements Cop
|
|||
AudioVideoNotesPlugin plugin = OsmandPlugin.getPlugin(AudioVideoNotesPlugin.class);
|
||||
if (plugin != null) {
|
||||
app.getSettings().resetProfilePreferences(appMode, plugin.getPreferences());
|
||||
app.showToastMessage(R.string.plugin_prefs_reset_successful);
|
||||
updateAllSettings();
|
||||
}
|
||||
}
|
||||
}
|
|
@ -7,7 +7,6 @@ import android.view.WindowManager;
|
|||
|
||||
import net.osmand.Location;
|
||||
import net.osmand.StateChangedListener;
|
||||
import net.osmand.binary.BinaryMapDataObject;
|
||||
import net.osmand.data.LatLon;
|
||||
import net.osmand.data.RotatedTileBox;
|
||||
import net.osmand.map.IMapLocationListener;
|
||||
|
@ -28,6 +27,7 @@ import net.osmand.plus.views.AnimateDraggingMapThread;
|
|||
import net.osmand.plus.views.OsmandMapTileView;
|
||||
import net.osmand.util.MapUtils;
|
||||
|
||||
|
||||
import java.io.IOException;
|
||||
import java.text.SimpleDateFormat;
|
||||
|
||||
|
@ -155,7 +155,7 @@ public class MapViewTrackingUtilities implements OsmAndLocationListener, IMapLoc
|
|||
return movingToMyLocation;
|
||||
}
|
||||
|
||||
private void detectDrivingRegion(final LatLon latLon) {
|
||||
public void detectDrivingRegion(final LatLon latLon) {
|
||||
new DetectDrivingRegionTask(app).executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR, latLon);
|
||||
}
|
||||
|
||||
|
@ -167,7 +167,7 @@ public class MapViewTrackingUtilities implements OsmAndLocationListener, IMapLoc
|
|||
locationProvider = location.getProvider();
|
||||
if (settings.DRIVING_REGION_AUTOMATIC.get() && !drivingRegionUpdated && !app.isApplicationInitializing()) {
|
||||
drivingRegionUpdated = true;
|
||||
detectDrivingRegion(new LatLon(location.getLatitude(), location.getLongitude()));
|
||||
app.getRoutingHelper().checkAndUpdateStartLocation(location);
|
||||
}
|
||||
}
|
||||
if (mapView != null) {
|
||||
|
@ -444,7 +444,7 @@ public class MapViewTrackingUtilities implements OsmAndLocationListener, IMapLoc
|
|||
isUserZoomed = true;
|
||||
}
|
||||
|
||||
private static class DetectDrivingRegionTask extends AsyncTask<LatLon, Void, BinaryMapDataObject> {
|
||||
private static class DetectDrivingRegionTask extends AsyncTask<LatLon, Void, WorldRegion> {
|
||||
|
||||
private OsmandApplication app;
|
||||
|
||||
|
@ -453,10 +453,10 @@ public class MapViewTrackingUtilities implements OsmAndLocationListener, IMapLoc
|
|||
}
|
||||
|
||||
@Override
|
||||
protected BinaryMapDataObject doInBackground(LatLon... latLons) {
|
||||
protected WorldRegion doInBackground(LatLon... latLons) {
|
||||
try {
|
||||
if (latLons != null && latLons.length > 0) {
|
||||
return app.getRegions().getSmallestBinaryMapDataObjectAt(latLons[0]);
|
||||
return app.getRegions().getSmallestBinaryMapDataObjectAt(latLons[0]).getKey();
|
||||
}
|
||||
} catch (IOException e) {
|
||||
// ignore
|
||||
|
@ -465,13 +465,9 @@ public class MapViewTrackingUtilities implements OsmAndLocationListener, IMapLoc
|
|||
}
|
||||
|
||||
@Override
|
||||
protected void onPostExecute(BinaryMapDataObject o) {
|
||||
if (o != null) {
|
||||
String fullName = app.getRegions().getFullName(o);
|
||||
WorldRegion worldRegion = app.getRegions().getRegionData(fullName);
|
||||
if (worldRegion != null) {
|
||||
app.setupDrivingRegion(worldRegion);
|
||||
}
|
||||
protected void onPostExecute(WorldRegion worldRegion) {
|
||||
if (worldRegion != null) {
|
||||
app.setupDrivingRegion(worldRegion);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -583,9 +583,29 @@ public class ConfigureMapMenu {
|
|||
}
|
||||
}).createItem());
|
||||
|
||||
String description = "";
|
||||
SunriseSunset sunriseSunset = activity.getMyApplication().getDaynightHelper().getSunriseSunset();
|
||||
if (sunriseSunset != null) {
|
||||
DateFormat dateFormat = DateFormat.getTimeInstance(DateFormat.SHORT);
|
||||
String sunriseTime = dateFormat.format(sunriseSunset.getSunrise());
|
||||
String sunsetTime = dateFormat.format(sunriseSunset.getSunset());
|
||||
OsmandSettings.DayNightMode dayNightMode = activity.getMyApplication().getSettings().DAYNIGHT_MODE.get();
|
||||
if (dayNightMode.isDay() || dayNightMode.isNight()) {
|
||||
if (sunriseSunset.isDaytime()) {
|
||||
description = String.format(app.getString(R.string.sunset_at), sunsetTime);
|
||||
} else {
|
||||
description = String.format(app.getString(R.string.sunrise_at), sunriseTime);
|
||||
}
|
||||
} else if (dayNightMode.isAuto() || dayNightMode.isSensor()) {
|
||||
description = String.format(app.getString(R.string.ltr_or_rtl_combine_via_slash), sunriseTime, sunsetTime);
|
||||
}
|
||||
description = String.format(app.getString(R.string.ltr_or_rtl_combine_via_bold_point), getDayNightDescr(activity), description);
|
||||
} else {
|
||||
description = getDayNightDescr(activity);
|
||||
}
|
||||
adapter.addItem(new ContextMenuItem.ItemBuilder().setTitleId(R.string.map_mode, activity)
|
||||
.setId(MAP_MODE_ID)
|
||||
.setDescription(getDayNightDescr(activity)).setLayout(R.layout.list_item_single_line_descrition_narrow)
|
||||
.setDescription(description)
|
||||
.setIcon(getDayNightIcon(activity)).setListener(new ItemClickListener() {
|
||||
@Override
|
||||
public boolean onContextMenuClick(final ArrayAdapter<ContextMenuItem> ad, int itemId,
|
||||
|
@ -595,18 +615,7 @@ public class ConfigureMapMenu {
|
|||
bld.setTitle(R.string.daynight);
|
||||
final String[] items = new String[OsmandSettings.DayNightMode.values().length];
|
||||
for (int i = 0; i < items.length; i++) {
|
||||
items[i] = OsmandSettings.DayNightMode.values()[i].toHumanString(activity
|
||||
.getMyApplication());
|
||||
}
|
||||
|
||||
SunriseSunset sunriseSunset = activity.getMyApplication().getDaynightHelper().getSunriseSunset();
|
||||
if (sunriseSunset != null) {
|
||||
DateFormat dateFormat = DateFormat.getTimeInstance(DateFormat.SHORT);
|
||||
String sunriseSunsetTime = "\n" + dateFormat.format(activity.getMyApplication()
|
||||
.getDaynightHelper().getSunriseSunset().getSunrise()) + "/" +
|
||||
dateFormat.format(activity.getMyApplication()
|
||||
.getDaynightHelper().getSunriseSunset().getSunset());
|
||||
items[0] += sunriseSunsetTime;
|
||||
items[i] = OsmandSettings.DayNightMode.values()[i].toHumanString(app);
|
||||
}
|
||||
int i = view.getSettings().DAYNIGHT_MODE.get().ordinal();
|
||||
bld.setNegativeButton(R.string.shared_string_dismiss, null);
|
||||
|
|
|
@ -198,7 +198,7 @@ public class PluginInstalledBottomSheetDialog extends MenuBottomSheetDialogFragm
|
|||
appModeItem[0] = (BottomSheetItemWithCompoundButton) new BottomSheetItemWithCompoundButton.Builder()
|
||||
.setChecked(ApplicationMode.values(app).contains(mode))
|
||||
.setDescription(BaseSettingsFragment.getAppModeDescription(app, mode))
|
||||
.setTitle(mode.toHumanString(app))
|
||||
.setTitle(mode.toHumanString())
|
||||
.setIcon(getActiveIcon(mode.getIconRes()))
|
||||
.setLayoutId(R.layout.bottom_sheet_item_with_descr_and_switch_56dp)
|
||||
.setOnClickListener(new View.OnClickListener() {
|
||||
|
|
|
@ -468,7 +468,7 @@ public class DownloadResources extends DownloadResourceGroup {
|
|||
List<IndexItem> res = new ArrayList<>();
|
||||
OsmandRegions regions = app.getRegions();
|
||||
DownloadIndexesThread downloadThread = app.getDownloadThread();
|
||||
List<WorldRegion> downloadRegions = regions.getWoldRegionsAt(latLon);
|
||||
List<WorldRegion> downloadRegions = regions.getWorldRegionsAt(latLon);
|
||||
for (WorldRegion downloadRegion : downloadRegions) {
|
||||
if (includeDownloaded || !isIndexItemDownloaded(downloadThread, type, downloadRegion, res)) {
|
||||
addIndexItem(downloadThread, type, downloadRegion, res);
|
||||
|
|
|
@ -1,7 +1,6 @@
|
|||
package net.osmand.plus.download.ui;
|
||||
|
||||
import android.content.res.TypedArray;
|
||||
import android.graphics.Color;
|
||||
import android.graphics.drawable.Drawable;
|
||||
import android.os.AsyncTask;
|
||||
import android.os.Bundle;
|
||||
|
@ -32,7 +31,6 @@ import net.osmand.Collator;
|
|||
import net.osmand.CollatorStringMatcher;
|
||||
import net.osmand.OsmAndCollator;
|
||||
import net.osmand.ResultMatcher;
|
||||
import net.osmand.binary.BinaryMapDataObject;
|
||||
import net.osmand.binary.BinaryMapIndexReader;
|
||||
import net.osmand.binary.BinaryMapIndexReader.SearchRequest;
|
||||
import net.osmand.data.Amenity;
|
||||
|
@ -416,15 +414,13 @@ public class SearchDialogFragment extends DialogFragment implements DownloadEven
|
|||
@Override
|
||||
protected IndexItem doInBackground(Void... params) {
|
||||
Amenity amenity = cityItem.getAmenity();
|
||||
BinaryMapDataObject o = null;
|
||||
WorldRegion downloadRegion = null;
|
||||
try {
|
||||
o = osmandRegions.getSmallestBinaryMapDataObjectAt(amenity.getLocation());
|
||||
downloadRegion = osmandRegions.getSmallestBinaryMapDataObjectAt(amenity.getLocation()).getKey();
|
||||
} catch (IOException e) {
|
||||
// ignore
|
||||
}
|
||||
if (o != null) {
|
||||
String selectedFullName = osmandRegions.getFullName(o);
|
||||
WorldRegion downloadRegion = osmandRegions.getRegionData(selectedFullName);
|
||||
if (downloadRegion != null) {
|
||||
List<IndexItem> indexItems = ctx.getDownloadThread().getIndexes().getIndexItems(downloadRegion);
|
||||
for (IndexItem item : indexItems) {
|
||||
if (item.getType() == DownloadActivityType.NORMAL_FILE) {
|
||||
|
|
|
@ -1280,8 +1280,10 @@ public class MapContextMenuFragment extends BaseOsmAndFragment implements Downlo
|
|||
final ImageView iconView = (ImageView) view.findViewById(R.id.context_menu_icon_view);
|
||||
Drawable icon = menu.getRightIcon();
|
||||
int iconId = menu.getRightIconId();
|
||||
|
||||
int sizeId = menu.isBigRightIcon() ? R.dimen.context_menu_big_icon_size : R.dimen.map_widget_icon;
|
||||
if (menu.getPointDescription().isFavorite() || menu.getPointDescription().isWpt()) {
|
||||
sizeId = R.dimen.dialog_button_height;
|
||||
}
|
||||
int iconViewSize = getResources().getDimensionPixelSize(sizeId);
|
||||
ViewGroup.LayoutParams params = iconView.getLayoutParams();
|
||||
params.width = iconViewSize;
|
||||
|
|
|
@ -1,9 +1,11 @@
|
|||
package net.osmand.plus.mapcontextmenu.other;
|
||||
|
||||
import android.Manifest;
|
||||
import android.app.Activity;
|
||||
import android.graphics.drawable.Drawable;
|
||||
import android.os.Bundle;
|
||||
import android.support.annotation.NonNull;
|
||||
import android.support.v4.app.ActivityCompat;
|
||||
import android.support.v4.app.Fragment;
|
||||
import android.support.v7.widget.LinearLayoutManager;
|
||||
import android.support.v7.widget.RecyclerView;
|
||||
|
@ -156,7 +158,10 @@ public class FavouritesBottomSheetMenuFragment extends MenuBottomSheetDialogFrag
|
|||
targetPointsHelper.setStartPoint(ll, true, point.getPointDescription(app));
|
||||
break;
|
||||
case TARGET:
|
||||
targetPointsHelper.navigateToPoint(ll, true, -1, point.getPointDescription(app));
|
||||
if (getActivity() != null) {
|
||||
targetPointsHelper.navigateToPoint(ll, true, -1, point.getPointDescription(app));
|
||||
OsmAndLocationProvider.requestFineLocationPermissionIfNeeded(getActivity());
|
||||
}
|
||||
break;
|
||||
case INTERMEDIATE:
|
||||
targetPointsHelper.navigateToPoint(ll, true, targetPointsHelper.getIntermediatePoints().size(), point.getPointDescription(app));
|
||||
|
|
|
@ -53,6 +53,12 @@ public class MultiSelectionArrayAdapter extends ArrayAdapter<MapMultiSelectionMe
|
|||
UiUtilities iconsCache = menu.getMapActivity().getMyApplication().getUIUtilities();
|
||||
final View iconLayout = convertView.findViewById(R.id.context_menu_icon_layout);
|
||||
final ImageView iconView = (ImageView) convertView.findViewById(R.id.context_menu_icon_view);
|
||||
if (item.getPointDescription().isFavorite() || item.getPointDescription().isWpt()) {
|
||||
int iconSize = getContext().getResources().getDimensionPixelSize(R.dimen.dialog_button_height);
|
||||
iconView.getLayoutParams().height = iconSize;
|
||||
iconView.getLayoutParams().width = iconSize;
|
||||
iconView.requestLayout();
|
||||
}
|
||||
Drawable icon = item.getRightIcon();
|
||||
int iconId = item.getRightIconId();
|
||||
if (icon != null) {
|
||||
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue