Merge branch 'master' of ssh://github.com/osmandapp/Osmand
This commit is contained in:
commit
e6e5d2c32b
13 changed files with 253 additions and 73 deletions
|
@ -61,8 +61,7 @@ public class BinaryInspector {
|
||||||
// "-vaddress", "-vcities", "-vstreets", "-vstreetgroups","-vbuildings",
|
// "-vaddress", "-vcities", "-vstreets", "-vstreetgroups","-vbuildings",
|
||||||
//"-zoom=16",
|
//"-zoom=16",
|
||||||
//"-bbox=4,55,7,50",
|
//"-bbox=4,55,7,50",
|
||||||
//"/home/victor/osmand/Test.obf"
|
// "/home/victor/projects/osmand/osm-gen/Test.obf"
|
||||||
//"/home/victor/projects/osmand/osm-gen/Map.obf"
|
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
in.inspector(args);
|
in.inspector(args);
|
||||||
|
|
|
@ -520,6 +520,8 @@ public class MapRenderingTypes {
|
||||||
rt.applyToTagValue.addAll(mapRulType.applyToTagValue);
|
rt.applyToTagValue.addAll(mapRulType.applyToTagValue);
|
||||||
mapRulType.applyToTagValue.add(rt.tagValuePattern);
|
mapRulType.applyToTagValue.add(rt.tagValuePattern);
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
mapRulType.applyToTagValue = null;
|
||||||
}
|
}
|
||||||
if(rt.isMain()) {
|
if(rt.isMain()) {
|
||||||
mapRulType.main = true;
|
mapRulType.main = true;
|
||||||
|
|
|
@ -127,6 +127,9 @@ public class GeneralRouter implements VehicleRouter {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Map<String, RoutingParameter> getParameters() {
|
||||||
|
return parameters;
|
||||||
|
}
|
||||||
|
|
||||||
public void addAttribute(String k, String v) {
|
public void addAttribute(String k, String v) {
|
||||||
attributes.put(k, v);
|
attributes.put(k, v);
|
||||||
|
|
|
@ -98,6 +98,15 @@ public class RoutingConfiguration {
|
||||||
return attributes.get(propertyName);
|
return attributes.get(propertyName);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public String getDefaultRouter() {
|
||||||
|
return defaultRouter;
|
||||||
|
}
|
||||||
|
|
||||||
|
public GeneralRouter getRouter(String applicationMode) {
|
||||||
|
return routers.get(applicationMode);
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static int parseSilentInt(String t, int v) {
|
private static int parseSilentInt(String t, int v) {
|
||||||
|
|
|
@ -174,7 +174,7 @@ public class ApplicationMode {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static List<ApplicationMode> allPossibleValues(OsmandSettings settings) {
|
public static List<ApplicationMode> allPossibleValues(OsmandSettings settings) {
|
||||||
return values;
|
return new ArrayList<ApplicationMode>(values);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1394,12 +1394,32 @@ public class OsmandSettings {
|
||||||
|
|
||||||
Map<String, CommonPreference<Boolean>> customBooleanRendersProps = new LinkedHashMap<String, OsmandSettings.CommonPreference<Boolean>>();
|
Map<String, CommonPreference<Boolean>> customBooleanRendersProps = new LinkedHashMap<String, OsmandSettings.CommonPreference<Boolean>>();
|
||||||
public CommonPreference<Boolean> getCustomRenderBooleanProperty(String attrName){
|
public CommonPreference<Boolean> getCustomRenderBooleanProperty(String attrName){
|
||||||
if(!customRendersProps.containsKey(attrName)){
|
if(!customBooleanRendersProps.containsKey(attrName)){
|
||||||
customBooleanRendersProps.put(attrName, new BooleanPreference("nrenderer_"+attrName, false).makeProfile());
|
customBooleanRendersProps.put(attrName, new BooleanPreference("nrenderer_"+attrName, false).makeProfile());
|
||||||
}
|
}
|
||||||
return customBooleanRendersProps.get(attrName);
|
return customBooleanRendersProps.get(attrName);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Map<String, CommonPreference<String>> customRoutingProps = new LinkedHashMap<String, OsmandSettings.CommonPreference<String>>();
|
||||||
|
public CommonPreference<String> getCustomRoutingProperty(String attrName){
|
||||||
|
if(!customRoutingProps.containsKey(attrName)){
|
||||||
|
customRoutingProps.put(attrName, new StringPreference("prouting_"+attrName, "").makeProfile());
|
||||||
|
}
|
||||||
|
return customRoutingProps.get(attrName);
|
||||||
|
}
|
||||||
|
{
|
||||||
|
// CommonPreference<String> pref = getCustomRoutingProperty("appMode");
|
||||||
|
// pref.setModeDefaultValue(ApplicationMode.CAR, "car");
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, CommonPreference<Boolean>> customBooleanRoutingProps = new LinkedHashMap<String, OsmandSettings.CommonPreference<Boolean>>();
|
||||||
|
public CommonPreference<Boolean> getCustomRoutingBooleanProperty(String attrName){
|
||||||
|
if(!customBooleanRoutingProps.containsKey(attrName)){
|
||||||
|
customBooleanRoutingProps.put(attrName, new BooleanPreference("prouting_"+attrName, false).makeProfile());
|
||||||
|
}
|
||||||
|
return customBooleanRoutingProps.get(attrName);
|
||||||
|
}
|
||||||
|
|
||||||
public final OsmandPreference<Boolean> VOICE_MUTE = new BooleanPreference("voice_mute", false).makeGlobal();
|
public final OsmandPreference<Boolean> VOICE_MUTE = new BooleanPreference("voice_mute", false).makeGlobal();
|
||||||
|
|
||||||
// for background service
|
// for background service
|
||||||
|
|
|
@ -83,6 +83,15 @@ public abstract class SettingsBaseActivity extends SherlockPreferenceActivity im
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public CheckBoxPreference createCheckBoxPreference(OsmandPreference<Boolean> b) {
|
||||||
|
CheckBoxPreference p = new CheckBoxPreference(this);
|
||||||
|
p.setKey(b.getId());
|
||||||
|
p.setOnPreferenceChangeListener(this);
|
||||||
|
screenPreferences.put(b.getId(), p);
|
||||||
|
booleanPreferences.put(b.getId(), b);
|
||||||
|
return p;
|
||||||
|
}
|
||||||
|
|
||||||
public void registerSeekBarPreference(OsmandPreference<Integer> b, PreferenceScreen screen) {
|
public void registerSeekBarPreference(OsmandPreference<Integer> b, PreferenceScreen screen) {
|
||||||
SeekBarPreference p = (SeekBarPreference) screen.findPreference(b.getId());
|
SeekBarPreference p = (SeekBarPreference) screen.findPreference(b.getId());
|
||||||
p.setOnPreferenceChangeListener(this);
|
p.setOnPreferenceChangeListener(this);
|
||||||
|
@ -90,6 +99,32 @@ public abstract class SettingsBaseActivity extends SherlockPreferenceActivity im
|
||||||
seekBarPreferences.put(b.getId(), b);
|
seekBarPreferences.put(b.getId(), b);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static String getRoutingStringPropertyName(Context ctx, String propertyName, String defValue) {
|
||||||
|
try {
|
||||||
|
Field f = R.string.class.getField("routing_attr_" + propertyName + "_name");
|
||||||
|
if (f != null) {
|
||||||
|
Integer in = (Integer) f.get(null);
|
||||||
|
return ctx.getString(in);
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.err.println(e.getMessage());
|
||||||
|
}
|
||||||
|
return defValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String getRoutingStringPropertyDescription(Context ctx, String propertyName, String defValue) {
|
||||||
|
try {
|
||||||
|
Field f = R.string.class.getField("routing_attr_" + propertyName + "_description");
|
||||||
|
if (f != null) {
|
||||||
|
Integer in = (Integer) f.get(null);
|
||||||
|
return ctx.getString(in);
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.err.println(e.getMessage());
|
||||||
|
}
|
||||||
|
return defValue;
|
||||||
|
}
|
||||||
|
|
||||||
public static String getStringPropertyName(Context ctx, String propertyName, String defValue) {
|
public static String getStringPropertyName(Context ctx, String propertyName, String defValue) {
|
||||||
try {
|
try {
|
||||||
Field f = R.string.class.getField("rendering_attr_" + propertyName + "_name");
|
Field f = R.string.class.getField("rendering_attr_" + propertyName + "_name");
|
||||||
|
@ -144,6 +179,13 @@ public abstract class SettingsBaseActivity extends SherlockPreferenceActivity im
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public <T> ListPreference createListPreference(OsmandPreference<T> b, String[] names, T[] values) {
|
||||||
|
ListPreference p = new ListPreference(this);
|
||||||
|
p.setKey(b.getId());
|
||||||
|
prepareListPreference(b, names, values, p);
|
||||||
|
return p;
|
||||||
|
}
|
||||||
|
|
||||||
private <T> void prepareListPreference(OsmandPreference<T> b, String[] names, T[] values, ListPreference p) {
|
private <T> void prepareListPreference(OsmandPreference<T> b, String[] names, T[] values, ListPreference p) {
|
||||||
p.setOnPreferenceChangeListener(this);
|
p.setOnPreferenceChangeListener(this);
|
||||||
LinkedHashMap<String, Object> vals = new LinkedHashMap<String, Object>();
|
LinkedHashMap<String, Object> vals = new LinkedHashMap<String, Object>();
|
||||||
|
@ -311,6 +353,7 @@ public abstract class SettingsBaseActivity extends SherlockPreferenceActivity im
|
||||||
@Override
|
@Override
|
||||||
public void onClick(View v) {
|
public void onClick(View v) {
|
||||||
if(selected.size() > 0) {
|
if(selected.size() > 0) {
|
||||||
|
// test
|
||||||
setSelectedAppMode(selected.iterator().next());
|
setSelectedAppMode(selected.iterator().next());
|
||||||
}
|
}
|
||||||
if(profileDialog != null && profileDialog.isShowing()) {
|
if(profileDialog != null && profileDialog.isShowing()) {
|
||||||
|
|
|
@ -2,21 +2,30 @@ package net.osmand.plus.activities;
|
||||||
|
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.LinkedHashSet;
|
import java.util.LinkedHashSet;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
import net.osmand.IndexConstants;
|
import net.osmand.IndexConstants;
|
||||||
|
import net.osmand.plus.ApplicationMode;
|
||||||
import net.osmand.plus.OsmandSettings;
|
import net.osmand.plus.OsmandSettings;
|
||||||
import net.osmand.plus.OsmandSettings.AutoZoomMap;
|
import net.osmand.plus.OsmandSettings.AutoZoomMap;
|
||||||
import net.osmand.plus.OsmandSettings.OsmandPreference;
|
import net.osmand.plus.OsmandSettings.OsmandPreference;
|
||||||
import net.osmand.plus.R;
|
import net.osmand.plus.R;
|
||||||
import net.osmand.plus.routing.RouteProvider.RouteService;
|
import net.osmand.plus.routing.RouteProvider.RouteService;
|
||||||
|
import net.osmand.router.GeneralRouter;
|
||||||
|
import net.osmand.router.GeneralRouter.RoutingParameter;
|
||||||
|
import net.osmand.router.GeneralRouter.RoutingParameterType;
|
||||||
|
import net.osmand.router.RoutingConfiguration;
|
||||||
import android.app.AlertDialog;
|
import android.app.AlertDialog;
|
||||||
import android.app.AlertDialog.Builder;
|
import android.app.AlertDialog.Builder;
|
||||||
import android.content.DialogInterface;
|
import android.content.DialogInterface;
|
||||||
import android.content.DialogInterface.OnMultiChoiceClickListener;
|
import android.content.DialogInterface.OnMultiChoiceClickListener;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
|
import android.preference.CheckBoxPreference;
|
||||||
import android.preference.ListPreference;
|
import android.preference.ListPreference;
|
||||||
import android.preference.Preference;
|
import android.preference.Preference;
|
||||||
import android.preference.PreferenceCategory;
|
import android.preference.PreferenceCategory;
|
||||||
|
@ -32,6 +41,9 @@ public class SettingsNavigationActivity extends SettingsBaseActivity {
|
||||||
private ListPreference autoZoomMapPreference;
|
private ListPreference autoZoomMapPreference;
|
||||||
public static final String MORE_VALUE = "MORE_VALUE";
|
public static final String MORE_VALUE = "MORE_VALUE";
|
||||||
|
|
||||||
|
private List<RoutingParameter> avoidParameters = new ArrayList<RoutingParameter>();
|
||||||
|
private List<RoutingParameter> preferParameters = new ArrayList<RoutingParameter>();
|
||||||
|
|
||||||
public SettingsNavigationActivity() {
|
public SettingsNavigationActivity() {
|
||||||
super(true);
|
super(true);
|
||||||
}
|
}
|
||||||
|
@ -63,34 +75,28 @@ public class SettingsNavigationActivity extends SettingsBaseActivity {
|
||||||
addPreferencesFromResource(R.xml.navigation_settings);
|
addPreferencesFromResource(R.xml.navigation_settings);
|
||||||
PreferenceScreen screen = getPreferenceScreen();
|
PreferenceScreen screen = getPreferenceScreen();
|
||||||
settings = getMyApplication().getSettings();
|
settings = getMyApplication().getSettings();
|
||||||
|
routerServicePreference = (ListPreference) screen.findPreference(settings.ROUTER_SERVICE.getId());
|
||||||
|
|
||||||
|
RouteService[] vls = RouteService.getAvailableRouters(getMyApplication());
|
||||||
|
String[] entries = new String[vls.length];
|
||||||
|
for(int i=0; i<entries.length; i++){
|
||||||
|
entries[i] = vls[i].getName();
|
||||||
|
}
|
||||||
|
registerListPreference(settings.ROUTER_SERVICE, screen, entries, vls);
|
||||||
|
|
||||||
registerBooleanPreference(settings.FAST_ROUTE_MODE, screen);
|
|
||||||
PreferenceCategory cat = (PreferenceCategory) screen.findPreference("routing_preferences");
|
|
||||||
avoidRouting = (Preference) screen.findPreference("avoid_in_routing");
|
|
||||||
avoidRouting.setOnPreferenceClickListener(this);
|
|
||||||
// routing_preferences
|
|
||||||
preferRouting = (Preference) screen.findPreference("prefer_in_routing");
|
|
||||||
preferRouting.setOnPreferenceClickListener(this);
|
|
||||||
|
|
||||||
registerBooleanPreference(settings.SNAP_TO_ROAD, screen);
|
registerBooleanPreference(settings.SNAP_TO_ROAD, screen);
|
||||||
registerBooleanPreference(settings.USE_COMPASS_IN_NAVIGATION, screen);
|
registerBooleanPreference(settings.USE_COMPASS_IN_NAVIGATION, screen);
|
||||||
|
|
||||||
Integer[] intValues = new Integer[] { 0, 5, 10, 15, 20, 25, 30, 45, 60, 90};
|
Integer[] intValues = new Integer[] { 0, 5, 10, 15, 20, 25, 30, 45, 60, 90};
|
||||||
String[] entries = new String[intValues.length];
|
entries = new String[intValues.length];
|
||||||
entries[0] = getString(R.string.auto_follow_route_never);
|
entries[0] = getString(R.string.auto_follow_route_never);
|
||||||
for (int i = 1; i < intValues.length; i++) {
|
for (int i = 1; i < intValues.length; i++) {
|
||||||
entries[i] = (int) intValues[i] + " " + getString(R.string.int_seconds);
|
entries[i] = (int) intValues[i] + " " + getString(R.string.int_seconds);
|
||||||
}
|
}
|
||||||
registerListPreference(settings.AUTO_FOLLOW_ROUTE, screen, entries, intValues);
|
registerListPreference(settings.AUTO_FOLLOW_ROUTE, screen, entries, intValues);
|
||||||
|
|
||||||
RouteService[] vls = RouteService.getAvailableRouters(getMyApplication());
|
|
||||||
entries = new String[vls.length];
|
|
||||||
for(int i=0; i<entries.length; i++){
|
|
||||||
entries[i] = vls[i].getName();
|
|
||||||
}
|
|
||||||
registerListPreference(settings.ROUTER_SERVICE, screen, entries, vls);
|
|
||||||
|
|
||||||
routerServicePreference = (ListPreference) screen.findPreference(settings.ROUTER_SERVICE.getId());
|
|
||||||
|
|
||||||
entries = new String[AutoZoomMap.values().length];
|
entries = new String[AutoZoomMap.values().length];
|
||||||
for(int i=0; i<entries.length; i++){
|
for(int i=0; i<entries.length; i++){
|
||||||
|
@ -108,12 +114,90 @@ public class SettingsNavigationActivity extends SettingsBaseActivity {
|
||||||
speakAlarms = (Preference) screen.findPreference("speak_routing_alarms");
|
speakAlarms = (Preference) screen.findPreference("speak_routing_alarms");
|
||||||
speakAlarms.setOnPreferenceClickListener(this);
|
speakAlarms.setOnPreferenceClickListener(this);
|
||||||
|
|
||||||
reloadVoiceListPreference(screen);
|
|
||||||
|
|
||||||
profileDialog();
|
profileDialog();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
private void prepareRoutingPrefs(PreferenceScreen screen) {
|
||||||
|
PreferenceCategory cat = (PreferenceCategory) screen.findPreference("routing_preferences");
|
||||||
|
cat.removeAll();
|
||||||
|
CheckBoxPreference fastRoute = createCheckBoxPreference(settings.FAST_ROUTE_MODE, R.string.fast_route_mode, R.string.fast_route_mode_descr);
|
||||||
|
if(settings.ROUTER_SERVICE.get() != RouteService.OSMAND) {
|
||||||
|
cat.addPreference(fastRoute);
|
||||||
|
} else {
|
||||||
|
ApplicationMode am = settings.getApplicationMode();
|
||||||
|
GeneralRouter router = getRouter(am);
|
||||||
|
clearParameters();
|
||||||
|
if (router != null) {
|
||||||
|
Map<String, RoutingParameter> parameters = router.getParameters();
|
||||||
|
if(parameters.containsKey("short_way")) {
|
||||||
|
cat.addPreference(fastRoute);
|
||||||
|
}
|
||||||
|
List<RoutingParameter> others = new ArrayList<GeneralRouter.RoutingParameter>();
|
||||||
|
for(Map.Entry<String, RoutingParameter> e : parameters.entrySet()) {
|
||||||
|
String param = e.getKey();
|
||||||
|
if(param.startsWith("avoid_")) {
|
||||||
|
avoidParameters.add(e.getValue());
|
||||||
|
} else if(param.startsWith("prefer_")) {
|
||||||
|
preferParameters.add(e.getValue());
|
||||||
|
} else if(!param.equals("short_way")) {
|
||||||
|
others.add(e.getValue());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (avoidParameters.size() > 0) {
|
||||||
|
avoidRouting = new Preference(this);
|
||||||
|
avoidRouting.setTitle(R.string.avoid_in_routing_title);
|
||||||
|
avoidRouting.setSummary(R.string.avoid_in_routing_descr);
|
||||||
|
avoidRouting.setOnPreferenceClickListener(this);
|
||||||
|
cat.addPreference(avoidRouting);
|
||||||
|
}
|
||||||
|
if (preferParameters.size() > 0) {
|
||||||
|
preferRouting = new Preference(this);
|
||||||
|
preferRouting.setTitle(R.string.prefer_in_routing_title);
|
||||||
|
preferRouting.setSummary(R.string.prefer_in_routing_descr);
|
||||||
|
preferRouting.setOnPreferenceClickListener(this);
|
||||||
|
cat.addPreference(preferRouting);
|
||||||
|
}
|
||||||
|
for(RoutingParameter p : others) {
|
||||||
|
Preference basePref;
|
||||||
|
if(p.getType() == RoutingParameterType.BOOLEAN) {
|
||||||
|
basePref = createCheckBoxPreference(settings.getCustomRoutingBooleanProperty(p.getId()));
|
||||||
|
} else {
|
||||||
|
Object[] vls = p.getPossibleValues();
|
||||||
|
String[] svlss = new String[vls.length];
|
||||||
|
int i = 0;
|
||||||
|
for(Object o : vls) {
|
||||||
|
svlss[i++] = o.toString();
|
||||||
|
}
|
||||||
|
basePref = createListPreference(settings.getCustomRoutingProperty(p.getId()),
|
||||||
|
p.getPossibleValueDescriptions(), svlss);
|
||||||
|
}
|
||||||
|
basePref.setTitle(SettingsBaseActivity.getRoutingStringPropertyName(this, p.getId(), p.getName()));
|
||||||
|
basePref.setSummary(SettingsBaseActivity.getRoutingStringPropertyName(this, p.getId(), p.getDescription()));
|
||||||
|
cat.addPreference(basePref);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private void clearParameters() {
|
||||||
|
preferParameters.clear();
|
||||||
|
avoidParameters.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public static GeneralRouter getRouter(ApplicationMode am) {
|
||||||
|
GeneralRouter router = RoutingConfiguration.getDefault().getRouter(am.getStringKey());
|
||||||
|
if(router == null && am.getParent() != null) {
|
||||||
|
router = RoutingConfiguration.getDefault().getRouter(am.getParent().getStringKey());
|
||||||
|
}
|
||||||
|
return router;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
private void reloadVoiceListPreference(PreferenceScreen screen) {
|
private void reloadVoiceListPreference(PreferenceScreen screen) {
|
||||||
String[] entries;
|
String[] entries;
|
||||||
String[] entrieValues;
|
String[] entrieValues;
|
||||||
|
@ -137,6 +221,7 @@ public class SettingsNavigationActivity extends SettingsBaseActivity {
|
||||||
|
|
||||||
public void updateAllSettings() {
|
public void updateAllSettings() {
|
||||||
reloadVoiceListPreference(getPreferenceScreen());
|
reloadVoiceListPreference(getPreferenceScreen());
|
||||||
|
prepareRoutingPrefs(getPreferenceScreen());
|
||||||
super.updateAllSettings();
|
super.updateAllSettings();
|
||||||
routerServicePreference.setSummary(getString(R.string.router_service_descr) + " [" + settings.ROUTER_SERVICE.get() + "]");
|
routerServicePreference.setSummary(getString(R.string.router_service_descr) + " [" + settings.ROUTER_SERVICE.get() + "]");
|
||||||
}
|
}
|
||||||
|
@ -156,11 +241,11 @@ public class SettingsNavigationActivity extends SettingsBaseActivity {
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
boolean changed = super.onPreferenceChange(preference, newValue);
|
super.onPreferenceChange(preference, newValue);
|
||||||
|
|
||||||
if (id.equals(settings.ROUTER_SERVICE.getId())) {
|
if (id.equals(settings.ROUTER_SERVICE.getId())) {
|
||||||
routerServicePreference.setSummary(getString(R.string.router_service_descr) + " ["
|
routerServicePreference.setSummary(getString(R.string.router_service_descr) + " ["
|
||||||
+ settings.ROUTER_SERVICE.get() + "]");
|
+ settings.ROUTER_SERVICE.get() + "]");
|
||||||
|
prepareRoutingPrefs(getPreferenceScreen());
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -169,15 +254,16 @@ public class SettingsNavigationActivity extends SettingsBaseActivity {
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
@Override
|
@Override
|
||||||
public boolean onPreferenceClick(Preference preference) {
|
public boolean onPreferenceClick(Preference preference) {
|
||||||
if (preference == avoidRouting) {
|
if (preference == avoidRouting || preference == preferRouting) {
|
||||||
showBooleanSettings(new String[] { getString(R.string.avoid_toll_roads), getString(R.string.avoid_ferries),
|
List<RoutingParameter> prms = preference == avoidRouting ? avoidParameters : preferParameters;
|
||||||
getString(R.string.avoid_unpaved), getString(R.string.avoid_motorway)
|
String[] vals = new String[prms.size()];
|
||||||
}, new OsmandPreference[] { settings.AVOID_TOLL_ROADS,
|
OsmandPreference[] bls = new OsmandPreference[prms.size()];
|
||||||
settings.AVOID_FERRIES, settings.AVOID_UNPAVED_ROADS, settings.AVOID_MOTORWAY });
|
for(int i = 0; i < prms.size(); i++) {
|
||||||
return true;
|
RoutingParameter p = prms.get(i);
|
||||||
} else if (preference == preferRouting) {
|
vals[i] = SettingsBaseActivity.getRoutingStringPropertyName(this, p.getId(), p.getName());
|
||||||
showBooleanSettings(new String[] { getString(R.string.prefer_motorways)},
|
bls[i] = settings.getCustomRoutingBooleanProperty(p.getId());
|
||||||
new OsmandPreference[] { settings.PREFER_MOTORWAYS});
|
}
|
||||||
|
showBooleanSettings(vals, bls);
|
||||||
return true;
|
return true;
|
||||||
} else if (preference == showAlarms) {
|
} else if (preference == showAlarms) {
|
||||||
showBooleanSettings(new String[] { getString(R.string.show_traffic_warnings), getString(R.string.show_cameras),
|
showBooleanSettings(new String[] { getString(R.string.show_traffic_warnings), getString(R.string.show_cameras),
|
||||||
|
|
|
@ -373,7 +373,9 @@ public class NavigateAction {
|
||||||
if(!showDefault) {
|
if(!showDefault) {
|
||||||
values.remove(ApplicationMode.DEFAULT);
|
values.remove(ApplicationMode.DEFAULT);
|
||||||
}
|
}
|
||||||
|
if (showDefault || settings.getApplicationMode() != ApplicationMode.DEFAULT) {
|
||||||
selected.add(settings.getApplicationMode());
|
selected.add(settings.getApplicationMode());
|
||||||
|
}
|
||||||
return prepareAppModeView(a, values, selected, parent, singleSelection, onClickListener);
|
return prepareAppModeView(a, values, selected, parent, singleSelection, onClickListener);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,6 +16,8 @@ import net.osmand.NativeLibrary.NativeSearchResult;
|
||||||
import net.osmand.PlatformUtil;
|
import net.osmand.PlatformUtil;
|
||||||
import net.osmand.binary.BinaryMapDataObject;
|
import net.osmand.binary.BinaryMapDataObject;
|
||||||
import net.osmand.binary.BinaryMapIndexReader.TagValuePair;
|
import net.osmand.binary.BinaryMapIndexReader.TagValuePair;
|
||||||
|
import net.osmand.data.QuadRect;
|
||||||
|
import net.osmand.data.QuadTree;
|
||||||
import net.osmand.map.MapTileDownloader.IMapDownloaderCallback;
|
import net.osmand.map.MapTileDownloader.IMapDownloaderCallback;
|
||||||
import net.osmand.plus.render.TextRenderer.TextDrawInfo;
|
import net.osmand.plus.render.TextRenderer.TextDrawInfo;
|
||||||
import net.osmand.render.RenderingRuleProperty;
|
import net.osmand.render.RenderingRuleProperty;
|
||||||
|
@ -300,36 +302,39 @@ public class OsmandRenderer {
|
||||||
return object1.iconOrder - object2.iconOrder;
|
return object1.iconOrder - object2.iconOrder;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
int skewConstant = (int) rc.getDensityValue(16);
|
QuadRect bounds = new QuadRect(0, 0, rc.width, rc.height);
|
||||||
int iconsW = rc.width / skewConstant;
|
bounds.inset(-bounds.width()/4, -bounds.height()/4);
|
||||||
int iconsH = rc.height / skewConstant;
|
QuadTree<RectF> boundIntersections = new QuadTree<RectF>(bounds, 4, 0.6f);
|
||||||
int[] alreadyDrawnIcons = new int[iconsW * iconsH / 32];
|
List<RectF> result = new ArrayList<RectF>();
|
||||||
|
|
||||||
for (IconDrawInfo icon : rc.iconsToDraw) {
|
for (IconDrawInfo icon : rc.iconsToDraw) {
|
||||||
if (icon.resId != null) {
|
if (icon.resId != null) {
|
||||||
Bitmap ico = RenderingIcons.getIcon(context, icon.resId);
|
Bitmap ico = RenderingIcons.getIcon(context, icon.resId);
|
||||||
if (ico != null) {
|
if (ico != null) {
|
||||||
if (icon.y >= 0 && icon.y < rc.height && icon.x >= 0 && icon.x < rc.width) {
|
if (icon.y >= 0 && icon.y < rc.height && icon.x >= 0 && icon.x < rc.width) {
|
||||||
int z = (((int) icon.x / skewConstant) + ((int) icon.y / skewConstant) * iconsW);
|
|
||||||
int i = z / 32;
|
|
||||||
if (i >= alreadyDrawnIcons.length) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
int ind = alreadyDrawnIcons[i];
|
|
||||||
int b = z % 32;
|
|
||||||
// check bit b if it is set
|
|
||||||
if (((ind >> b) & 1) == 0) {
|
|
||||||
alreadyDrawnIcons[i] = ind | (1 << b);
|
|
||||||
float left = icon.x - ico.getWidth() / 2 * rc.screenDensityRatio;
|
float left = icon.x - ico.getWidth() / 2 * rc.screenDensityRatio;
|
||||||
float top = icon.y - ico.getHeight() / 2 * rc.screenDensityRatio;
|
float top = icon.y - ico.getHeight() / 2 * rc.screenDensityRatio;
|
||||||
|
float right = left + ico.getWidth() * rc.screenDensityRatio;
|
||||||
|
float bottom = top + ico.getHeight() * rc.screenDensityRatio;
|
||||||
|
RectF rf = new RectF(left, top, right , bottom);
|
||||||
|
boundIntersections.queryInBox(new QuadRect(left, top, right, bottom), result);
|
||||||
|
boolean intersects = false;
|
||||||
|
for(RectF r : result) {
|
||||||
|
if(r.intersect(rf)) {
|
||||||
|
intersects = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!intersects) {
|
||||||
if(rc.screenDensityRatio != 1f){
|
if(rc.screenDensityRatio != 1f){
|
||||||
RectF rf = new RectF(left, top, left + ico.getWidth() * rc.screenDensityRatio ,
|
|
||||||
top + ico.getHeight() * rc.screenDensityRatio);
|
|
||||||
Rect src = new Rect(0, 0, ico.getWidth(), ico
|
Rect src = new Rect(0, 0, ico.getWidth(), ico
|
||||||
.getHeight());
|
.getHeight());
|
||||||
cv.drawBitmap(ico, src, rf, paintIcon);
|
cv.drawBitmap(ico, src, rf, paintIcon);
|
||||||
} else {
|
} else {
|
||||||
cv.drawBitmap(ico, left, top, paintIcon);
|
cv.drawBitmap(ico, left, top, paintIcon);
|
||||||
}
|
}
|
||||||
|
rf.inset(-rf.width()/4, -rf.height()/4);
|
||||||
|
boundIntersections.insert(rf, new QuadRect(rf.left, rf.top, rf.right, rf.bottom));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -39,11 +39,15 @@ import net.osmand.plus.GPXUtilities.TrkSegment;
|
||||||
import net.osmand.plus.GPXUtilities.WptPt;
|
import net.osmand.plus.GPXUtilities.WptPt;
|
||||||
import net.osmand.plus.OsmandApplication;
|
import net.osmand.plus.OsmandApplication;
|
||||||
import net.osmand.plus.OsmandSettings;
|
import net.osmand.plus.OsmandSettings;
|
||||||
|
import net.osmand.plus.OsmandSettings.CommonPreference;
|
||||||
import net.osmand.plus.R;
|
import net.osmand.plus.R;
|
||||||
import net.osmand.plus.TargetPointsHelper;
|
import net.osmand.plus.TargetPointsHelper;
|
||||||
import net.osmand.plus.Version;
|
import net.osmand.plus.Version;
|
||||||
|
import net.osmand.plus.activities.SettingsNavigationActivity;
|
||||||
import net.osmand.router.GeneralRouter;
|
import net.osmand.router.GeneralRouter;
|
||||||
import net.osmand.router.GeneralRouter.GeneralRouterProfile;
|
import net.osmand.router.GeneralRouter.GeneralRouterProfile;
|
||||||
|
import net.osmand.router.GeneralRouter.RoutingParameter;
|
||||||
|
import net.osmand.router.GeneralRouter.RoutingParameterType;
|
||||||
import net.osmand.router.RoutePlannerFrontEnd;
|
import net.osmand.router.RoutePlannerFrontEnd;
|
||||||
import net.osmand.router.RoutePlannerFrontEnd.RouteCalculationMode;
|
import net.osmand.router.RoutePlannerFrontEnd.RouteCalculationMode;
|
||||||
import net.osmand.router.RouteSegmentResult;
|
import net.osmand.router.RouteSegmentResult;
|
||||||
|
@ -391,23 +395,28 @@ public class RouteProvider {
|
||||||
} else {
|
} else {
|
||||||
return applicationModeNotSupported(params);
|
return applicationModeNotSupported(params);
|
||||||
}
|
}
|
||||||
|
GeneralRouter generalRouter = SettingsNavigationActivity.getRouter(params.mode);
|
||||||
|
if(generalRouter == null) {
|
||||||
|
return applicationModeNotSupported(params);
|
||||||
|
}
|
||||||
Map<String, String> paramsR = new LinkedHashMap<String, String>();
|
Map<String, String> paramsR = new LinkedHashMap<String, String>();
|
||||||
if (!settings.FAST_ROUTE_MODE.getModeValue(params.mode)) {
|
for(Map.Entry<String, RoutingParameter> e : generalRouter.getParameters().entrySet()){
|
||||||
paramsR.put(GeneralRouter.USE_SHORTEST_WAY, "true");
|
String key = e.getKey();
|
||||||
|
RoutingParameter pr = e.getValue();
|
||||||
|
String vl;
|
||||||
|
if(key.equals(GeneralRouter.USE_SHORTEST_WAY)) {
|
||||||
|
Boolean bool = settings.FAST_ROUTE_MODE.getModeValue(params.mode);
|
||||||
|
vl = bool ? "true" : null;
|
||||||
|
} else if(pr.getType() == RoutingParameterType.BOOLEAN) {
|
||||||
|
CommonPreference<Boolean> pref = settings.getCustomRoutingBooleanProperty(key);
|
||||||
|
Boolean bool = pref.getModeValue(params.mode);
|
||||||
|
vl = bool ? "true" : null;
|
||||||
|
} else {
|
||||||
|
vl = settings.getCustomRoutingProperty(key).getModeValue(params.mode);
|
||||||
}
|
}
|
||||||
if(settings.AVOID_FERRIES.getModeValue(params.mode)){
|
if(vl != null && vl.length() > 0) {
|
||||||
paramsR.put(GeneralRouter.AVOID_FERRIES, "true");
|
paramsR.put(key, vl);
|
||||||
}
|
}
|
||||||
if(settings.AVOID_TOLL_ROADS.getModeValue(params.mode)){
|
|
||||||
paramsR.put(GeneralRouter.AVOID_TOLL, "true");
|
|
||||||
}
|
|
||||||
if(settings.AVOID_MOTORWAY.getModeValue(params.mode)){
|
|
||||||
paramsR.put(GeneralRouter.AVOID_MOTORWAY, "true");
|
|
||||||
} else if(settings.PREFER_MOTORWAYS.getModeValue(params.mode)){
|
|
||||||
paramsR.put(GeneralRouter.PREFER_MOTORWAYS, "true");
|
|
||||||
}
|
|
||||||
if(settings.AVOID_UNPAVED_ROADS.getModeValue(params.mode)){
|
|
||||||
paramsR.put(GeneralRouter.AVOID_UNPAVED, "true");
|
|
||||||
}
|
}
|
||||||
float mb = (1 << 20);
|
float mb = (1 << 20);
|
||||||
Runtime rt = Runtime.getRuntime();
|
Runtime rt = Runtime.getRuntime();
|
||||||
|
@ -957,4 +966,6 @@ public class RouteProvider {
|
||||||
return new RouteCalculationResult(res, null, params, null);
|
return new RouteCalculationResult(res, null, params, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -419,7 +419,7 @@ public class MapInfoLayer extends OsmandMapLayer {
|
||||||
View confirmDialog = view.inflate(view.getContext(), R.layout.configuration_dialog, null);
|
View confirmDialog = view.inflate(view.getContext(), R.layout.configuration_dialog, null);
|
||||||
final ListView lv = (ListView) confirmDialog.findViewById(android.R.id.list);
|
final ListView lv = (ListView) confirmDialog.findViewById(android.R.id.list);
|
||||||
NavigateAction.prepareAppModeView(map, selected, true,
|
NavigateAction.prepareAppModeView(map, selected, true,
|
||||||
(ViewGroup) confirmDialog.findViewById(R.id.TopBar), false,
|
(ViewGroup) confirmDialog.findViewById(R.id.TopBar), true,
|
||||||
new View.OnClickListener() {
|
new View.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(View v) {
|
public void onClick(View v) {
|
||||||
|
|
|
@ -233,10 +233,10 @@ public class RouteInfoWidgetsFactory {
|
||||||
public boolean updateInfo(DrawSettings drawSettings) {
|
public boolean updateInfo(DrawSettings drawSettings) {
|
||||||
int time = 0;
|
int time = 0;
|
||||||
if (routingHelper != null && routingHelper.isRouteCalculated()) {
|
if (routingHelper != null && routingHelper.isRouteCalculated()) {
|
||||||
boolean followingMode = routingHelper.isFollowingMode();
|
//boolean followingMode = routingHelper.isFollowingMode();
|
||||||
time = routingHelper.getLeftTime();
|
time = routingHelper.getLeftTime();
|
||||||
if (time != 0) {
|
if (time != 0) {
|
||||||
if (followingMode && showArrival.get()) {
|
if (/*followingMode && */showArrival.get()) {
|
||||||
long toFindTime = time * 1000 + System.currentTimeMillis();
|
long toFindTime = time * 1000 + System.currentTimeMillis();
|
||||||
if (Math.abs(toFindTime - cachedLeftTime) > 30000) {
|
if (Math.abs(toFindTime - cachedLeftTime) > 30000) {
|
||||||
cachedLeftTime = toFindTime;
|
cachedLeftTime = toFindTime;
|
||||||
|
|
Loading…
Reference in a new issue