From 228c44b395ff4b1977391e790a2889aa17771d15 Mon Sep 17 00:00:00 2001 From: vshcherb Date: Mon, 24 Feb 2014 02:37:08 +0100 Subject: [PATCH 1/3] Reduce number of icons for square meter --- .../osmand/plus/render/OsmandRenderer.java | 39 +++++++++++-------- 1 file changed, 22 insertions(+), 17 deletions(-) diff --git a/OsmAnd/src/net/osmand/plus/render/OsmandRenderer.java b/OsmAnd/src/net/osmand/plus/render/OsmandRenderer.java index 653477147c..e7c6654d59 100644 --- a/OsmAnd/src/net/osmand/plus/render/OsmandRenderer.java +++ b/OsmAnd/src/net/osmand/plus/render/OsmandRenderer.java @@ -16,6 +16,8 @@ import net.osmand.NativeLibrary.NativeSearchResult; import net.osmand.PlatformUtil; import net.osmand.binary.BinaryMapDataObject; 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.plus.render.TextRenderer.TextDrawInfo; import net.osmand.render.RenderingRuleProperty; @@ -300,36 +302,39 @@ public class OsmandRenderer { return object1.iconOrder - object2.iconOrder; } }); - int skewConstant = (int) rc.getDensityValue(32); - int iconsW = rc.width / skewConstant; - int iconsH = rc.height / skewConstant; - int[] alreadyDrawnIcons = new int[iconsW * iconsH / 32]; + QuadRect bounds = new QuadRect(0, 0, rc.width, rc.height); + bounds.inset(-bounds.width()/4, -bounds.height()/4); + QuadTree boundIntersections = new QuadTree(bounds, 4, 0.6f); + List result = new ArrayList(); + for (IconDrawInfo icon : rc.iconsToDraw) { if (icon.resId != null) { Bitmap ico = RenderingIcons.getIcon(context, icon.resId); if (ico != null) { 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; + float left = icon.x - ico.getWidth() / 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; + } } - 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 top = icon.y - ico.getHeight() / 2 * rc.screenDensityRatio; + if (!intersects) { 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 .getHeight()); cv.drawBitmap(ico, src, rf, paintIcon); } else { 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)); } } } From c7e764239bbf946c9d92e1363178c3de21e6ee4b Mon Sep 17 00:00:00 2001 From: vshcherb Date: Wed, 26 Feb 2014 20:23:29 +0100 Subject: [PATCH 2/3] Add dynamic routing parameters for osmand routing.xml --- .../src/net/osmand/router/GeneralRouter.java | 5 +- .../osmand/router/RoutingConfiguration.java | 11 +- .../src/net/osmand/plus/OsmandSettings.java | 22 ++- .../plus/activities/SettingsBaseActivity.java | 42 ++++++ .../SettingsNavigationActivity.java | 142 ++++++++++++++---- .../osmand/plus/routing/RouteProvider.java | 43 ++++-- 6 files changed, 218 insertions(+), 47 deletions(-) diff --git a/OsmAnd-java/src/net/osmand/router/GeneralRouter.java b/OsmAnd-java/src/net/osmand/router/GeneralRouter.java index 1194c52ea5..ad2364ee0f 100644 --- a/OsmAnd-java/src/net/osmand/router/GeneralRouter.java +++ b/OsmAnd-java/src/net/osmand/router/GeneralRouter.java @@ -101,7 +101,7 @@ public class GeneralRouter implements VehicleRouter { ruleToValue = new ArrayList(); parameters = new LinkedHashMap(); } - + public GeneralRouter(GeneralRouter parent, Map params) { this.attributes = new LinkedHashMap(); Iterator> e = parent.attributes.entrySet().iterator(); @@ -127,6 +127,9 @@ public class GeneralRouter implements VehicleRouter { } + public Map getParameters() { + return parameters; + } public void addAttribute(String k, String v) { attributes.put(k, v); diff --git a/OsmAnd-java/src/net/osmand/router/RoutingConfiguration.java b/OsmAnd-java/src/net/osmand/router/RoutingConfiguration.java index 6498017233..e9cae01794 100644 --- a/OsmAnd-java/src/net/osmand/router/RoutingConfiguration.java +++ b/OsmAnd-java/src/net/osmand/router/RoutingConfiguration.java @@ -98,6 +98,15 @@ public class RoutingConfiguration { 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) { @@ -128,7 +137,7 @@ public class RoutingConfiguration { } return DEFAULT; } - + public static RoutingConfiguration.Builder parseFromInputStream(InputStream is) throws IOException, XmlPullParserException { XmlPullParser parser = PlatformUtil.newXMLPullParser(); final RoutingConfiguration.Builder config = new RoutingConfiguration.Builder(); diff --git a/OsmAnd/src/net/osmand/plus/OsmandSettings.java b/OsmAnd/src/net/osmand/plus/OsmandSettings.java index 513f3f6e19..13e3a77263 100644 --- a/OsmAnd/src/net/osmand/plus/OsmandSettings.java +++ b/OsmAnd/src/net/osmand/plus/OsmandSettings.java @@ -1394,12 +1394,32 @@ public class OsmandSettings { Map> customBooleanRendersProps = new LinkedHashMap>(); public CommonPreference getCustomRenderBooleanProperty(String attrName){ - if(!customRendersProps.containsKey(attrName)){ + if(!customBooleanRendersProps.containsKey(attrName)){ customBooleanRendersProps.put(attrName, new BooleanPreference("nrenderer_"+attrName, false).makeProfile()); } return customBooleanRendersProps.get(attrName); } + Map> customRoutingProps = new LinkedHashMap>(); + public CommonPreference getCustomRoutingProperty(String attrName){ + if(!customRoutingProps.containsKey(attrName)){ + customRoutingProps.put(attrName, new StringPreference("prouting_"+attrName, "").makeProfile()); + } + return customRoutingProps.get(attrName); + } + { +// CommonPreference pref = getCustomRoutingProperty("appMode"); +// pref.setModeDefaultValue(ApplicationMode.CAR, "car"); + } + + Map> customBooleanRoutingProps = new LinkedHashMap>(); + public CommonPreference getCustomRoutingBooleanProperty(String attrName){ + if(!customBooleanRoutingProps.containsKey(attrName)){ + customBooleanRoutingProps.put(attrName, new BooleanPreference("prouting_"+attrName, false).makeProfile()); + } + return customBooleanRoutingProps.get(attrName); + } + public final OsmandPreference VOICE_MUTE = new BooleanPreference("voice_mute", false).makeGlobal(); // for background service diff --git a/OsmAnd/src/net/osmand/plus/activities/SettingsBaseActivity.java b/OsmAnd/src/net/osmand/plus/activities/SettingsBaseActivity.java index e2ba19169f..300663bf9d 100644 --- a/OsmAnd/src/net/osmand/plus/activities/SettingsBaseActivity.java +++ b/OsmAnd/src/net/osmand/plus/activities/SettingsBaseActivity.java @@ -82,6 +82,15 @@ public abstract class SettingsBaseActivity extends SherlockPreferenceActivity im booleanPreferences.put(b.getId(), b); return p; } + + public CheckBoxPreference createCheckBoxPreference(OsmandPreference 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 b, PreferenceScreen screen) { SeekBarPreference p = (SeekBarPreference) screen.findPreference(b.getId()); @@ -89,6 +98,32 @@ public abstract class SettingsBaseActivity extends SherlockPreferenceActivity im screenPreferences.put(b.getId(), p); 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) { try { @@ -143,6 +178,13 @@ public abstract class SettingsBaseActivity extends SherlockPreferenceActivity im prepareListPreference(b, names, values, p); return p; } + + public ListPreference createListPreference(OsmandPreference b, String[] names, T[] values) { + ListPreference p = new ListPreference(this); + p.setKey(b.getId()); + prepareListPreference(b, names, values, p); + return p; + } private void prepareListPreference(OsmandPreference b, String[] names, T[] values, ListPreference p) { p.setOnPreferenceChangeListener(this); diff --git a/OsmAnd/src/net/osmand/plus/activities/SettingsNavigationActivity.java b/OsmAnd/src/net/osmand/plus/activities/SettingsNavigationActivity.java index e45bb8c9ae..7bf386dc86 100644 --- a/OsmAnd/src/net/osmand/plus/activities/SettingsNavigationActivity.java +++ b/OsmAnd/src/net/osmand/plus/activities/SettingsNavigationActivity.java @@ -2,21 +2,30 @@ package net.osmand.plus.activities; import java.io.File; +import java.util.ArrayList; import java.util.LinkedHashSet; +import java.util.List; +import java.util.Map; import java.util.Set; import net.osmand.IndexConstants; +import net.osmand.plus.ApplicationMode; import net.osmand.plus.OsmandSettings; import net.osmand.plus.OsmandSettings.AutoZoomMap; import net.osmand.plus.OsmandSettings.OsmandPreference; import net.osmand.plus.R; 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.Builder; import android.content.DialogInterface; import android.content.DialogInterface.OnMultiChoiceClickListener; import android.content.Intent; import android.os.Bundle; +import android.preference.CheckBoxPreference; import android.preference.ListPreference; import android.preference.Preference; import android.preference.PreferenceCategory; @@ -32,6 +41,9 @@ public class SettingsNavigationActivity extends SettingsBaseActivity { private ListPreference autoZoomMapPreference; public static final String MORE_VALUE = "MORE_VALUE"; + private List avoidParameters = new ArrayList(); + private List preferParameters = new ArrayList(); + public SettingsNavigationActivity() { super(true); } @@ -63,34 +75,28 @@ public class SettingsNavigationActivity extends SettingsBaseActivity { addPreferencesFromResource(R.xml.navigation_settings); PreferenceScreen screen = getPreferenceScreen(); 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 parameters = router.getParameters(); + if(parameters.containsKey("short_way")) { + cat.addPreference(fastRoute); + } + List others = new ArrayList(); + for(Map.Entry 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) { @@ -137,6 +221,7 @@ public class SettingsNavigationActivity extends SettingsBaseActivity { public void updateAllSettings() { reloadVoiceListPreference(getPreferenceScreen()); + prepareRoutingPrefs(getPreferenceScreen()); super.updateAllSettings(); routerServicePreference.setSummary(getString(R.string.router_service_descr) + " [" + settings.ROUTER_SERVICE.get() + "]"); } @@ -156,11 +241,11 @@ public class SettingsNavigationActivity extends SettingsBaseActivity { } return true; } - boolean changed = super.onPreferenceChange(preference, newValue); - + super.onPreferenceChange(preference, newValue); if (id.equals(settings.ROUTER_SERVICE.getId())) { routerServicePreference.setSummary(getString(R.string.router_service_descr) + " [" + settings.ROUTER_SERVICE.get() + "]"); + prepareRoutingPrefs(getPreferenceScreen()); } return true; } @@ -169,15 +254,16 @@ public class SettingsNavigationActivity extends SettingsBaseActivity { @SuppressWarnings("unchecked") @Override public boolean onPreferenceClick(Preference preference) { - if (preference == avoidRouting) { - showBooleanSettings(new String[] { getString(R.string.avoid_toll_roads), getString(R.string.avoid_ferries), - getString(R.string.avoid_unpaved), getString(R.string.avoid_motorway) - }, new OsmandPreference[] { settings.AVOID_TOLL_ROADS, - settings.AVOID_FERRIES, settings.AVOID_UNPAVED_ROADS, settings.AVOID_MOTORWAY }); - return true; - } else if (preference == preferRouting) { - showBooleanSettings(new String[] { getString(R.string.prefer_motorways)}, - new OsmandPreference[] { settings.PREFER_MOTORWAYS}); + if (preference == avoidRouting || preference == preferRouting) { + List prms = preference == avoidRouting ? avoidParameters : preferParameters; + String[] vals = new String[prms.size()]; + OsmandPreference[] bls = new OsmandPreference[prms.size()]; + for(int i = 0; i < prms.size(); i++) { + RoutingParameter p = prms.get(i); + vals[i] = SettingsBaseActivity.getRoutingStringPropertyName(this, p.getId(), p.getName()); + bls[i] = settings.getCustomRoutingBooleanProperty(p.getId()); + } + showBooleanSettings(vals, bls); return true; } else if (preference == showAlarms) { showBooleanSettings(new String[] { getString(R.string.show_traffic_warnings), getString(R.string.show_cameras), diff --git a/OsmAnd/src/net/osmand/plus/routing/RouteProvider.java b/OsmAnd/src/net/osmand/plus/routing/RouteProvider.java index 9246dfaadd..05c6d9feeb 100644 --- a/OsmAnd/src/net/osmand/plus/routing/RouteProvider.java +++ b/OsmAnd/src/net/osmand/plus/routing/RouteProvider.java @@ -39,11 +39,15 @@ import net.osmand.plus.GPXUtilities.TrkSegment; import net.osmand.plus.GPXUtilities.WptPt; import net.osmand.plus.OsmandApplication; import net.osmand.plus.OsmandSettings; +import net.osmand.plus.OsmandSettings.CommonPreference; import net.osmand.plus.R; import net.osmand.plus.TargetPointsHelper; import net.osmand.plus.Version; +import net.osmand.plus.activities.SettingsNavigationActivity; import net.osmand.router.GeneralRouter; 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.RouteCalculationMode; import net.osmand.router.RouteSegmentResult; @@ -391,23 +395,28 @@ public class RouteProvider { } else { return applicationModeNotSupported(params); } + GeneralRouter generalRouter = SettingsNavigationActivity.getRouter(params.mode); + if(generalRouter == null) { + return applicationModeNotSupported(params); + } Map paramsR = new LinkedHashMap(); - if (!settings.FAST_ROUTE_MODE.getModeValue(params.mode)) { - paramsR.put(GeneralRouter.USE_SHORTEST_WAY, "true"); - } - if(settings.AVOID_FERRIES.getModeValue(params.mode)){ - paramsR.put(GeneralRouter.AVOID_FERRIES, "true"); - } - 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"); + for(Map.Entry e : generalRouter.getParameters().entrySet()){ + 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 pref = settings.getCustomRoutingBooleanProperty(key); + Boolean bool = pref.getModeValue(params.mode); + vl = bool ? "true" : null; + } else { + vl = settings.getCustomRoutingProperty(key).getModeValue(params.mode); + } + if(vl != null && vl.length() > 0) { + paramsR.put(key, vl); + } } float mb = (1 << 20); Runtime rt = Runtime.getRuntime(); @@ -957,4 +966,6 @@ public class RouteProvider { return new RouteCalculationResult(res, null, params, null); } + + } From 72f846ca75880f8fe452df1afd89a6bfce275a54 Mon Sep 17 00:00:00 2001 From: vshcherb Date: Wed, 26 Feb 2014 22:12:28 +0100 Subject: [PATCH 3/3] Fix app mode selection in top widget --- OsmAnd/src/net/osmand/plus/views/MapInfoLayer.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/OsmAnd/src/net/osmand/plus/views/MapInfoLayer.java b/OsmAnd/src/net/osmand/plus/views/MapInfoLayer.java index 2be5b5db4a..32878fe3f8 100644 --- a/OsmAnd/src/net/osmand/plus/views/MapInfoLayer.java +++ b/OsmAnd/src/net/osmand/plus/views/MapInfoLayer.java @@ -419,7 +419,7 @@ public class MapInfoLayer extends OsmandMapLayer { View confirmDialog = view.inflate(view.getContext(), R.layout.configuration_dialog, null); final ListView lv = (ListView) confirmDialog.findViewById(android.R.id.list); NavigateAction.prepareAppModeView(map, selected, true, - (ViewGroup) confirmDialog.findViewById(R.id.TopBar), false, + (ViewGroup) confirmDialog.findViewById(R.id.TopBar), true, new View.OnClickListener() { @Override public void onClick(View v) {