From 0a6d6923c53fefc5efb696e67021a7b759344e9e Mon Sep 17 00:00:00 2001 From: Dima-1 Date: Wed, 13 Nov 2019 11:30:01 +0300 Subject: [PATCH 1/2] Issue #7224 Show POI category icons for Add POI quick action --- .../quickaction/actions/AddPOIAction.java | 26 ++++++++++++++++++- 1 file changed, 25 insertions(+), 1 deletion(-) diff --git a/OsmAnd/src/net/osmand/plus/quickaction/actions/AddPOIAction.java b/OsmAnd/src/net/osmand/plus/quickaction/actions/AddPOIAction.java index 6c9fea7834..c2b87c5c2a 100644 --- a/OsmAnd/src/net/osmand/plus/quickaction/actions/AddPOIAction.java +++ b/OsmAnd/src/net/osmand/plus/quickaction/actions/AddPOIAction.java @@ -1,5 +1,6 @@ package net.osmand.plus.quickaction.actions; +import android.content.Context; import android.content.Intent; import android.content.res.Resources; import android.graphics.drawable.Drawable; @@ -36,7 +37,6 @@ import net.osmand.osm.edit.Entity; import net.osmand.osm.edit.Node; import net.osmand.plus.OsmandApplication; import net.osmand.plus.OsmandPlugin; -import net.osmand.plus.OsmandSettings; import net.osmand.plus.R; import net.osmand.plus.activities.MapActivity; import net.osmand.plus.osmedit.EditPoiData; @@ -49,6 +49,7 @@ import net.osmand.plus.osmedit.OsmPoint; import net.osmand.plus.osmedit.dialogs.PoiSubTypeDialogFragment; import net.osmand.plus.quickaction.CreateEditActionDialog; import net.osmand.plus.quickaction.QuickAction; +import net.osmand.plus.render.RenderingIcons; import net.osmand.util.Algorithms; import java.lang.reflect.Type; @@ -79,6 +80,29 @@ public class AddPOIAction extends QuickAction { super(quickAction); } + @Override + public int getIconRes(Context context) { + if (context instanceof MapActivity) { + final OsmandApplication application = (OsmandApplication) (context).getApplicationContext(); + final MapPoiTypes poiTypes = application.getPoiTypes(); + final Map allTranslatedNames = poiTypes.getAllTranslatedNames(true); + PoiCategory category = getCategory(allTranslatedNames); + + if (category != null) { + + category.getIconKeyName(); + + String res = category.getIconKeyName(); + if (res instanceof String && RenderingIcons.containsBigIcon(res)) { + return RenderingIcons.getBigIconResourceId(res); + } else { + return super.getIconRes(); + } + } + } + return super.getIconRes(); + } + @Override public void execute(final MapActivity activity) { From e2e06194543dc78a8895e18b72268bde280faeb3 Mon Sep 17 00:00:00 2001 From: Dima-1 Date: Wed, 13 Nov 2019 16:20:06 +0300 Subject: [PATCH 2/2] Fix remarks --- .../quickaction/actions/AddPOIAction.java | 46 ++++++++++--------- 1 file changed, 25 insertions(+), 21 deletions(-) diff --git a/OsmAnd/src/net/osmand/plus/quickaction/actions/AddPOIAction.java b/OsmAnd/src/net/osmand/plus/quickaction/actions/AddPOIAction.java index c2b87c5c2a..c65893a54b 100644 --- a/OsmAnd/src/net/osmand/plus/quickaction/actions/AddPOIAction.java +++ b/OsmAnd/src/net/osmand/plus/quickaction/actions/AddPOIAction.java @@ -71,6 +71,8 @@ public class AddPOIAction extends QuickAction { private transient EditText title; private transient String prevType = ""; + private transient MapPoiTypes poiTypes; + private transient Map allTranslatedNames; public AddPOIAction() { super(TYPE); @@ -80,26 +82,31 @@ public class AddPOIAction extends QuickAction { super(quickAction); } + private MapPoiTypes getPoiTypes(Context context) { + if (poiTypes == null) { + final OsmandApplication application = (OsmandApplication) (context).getApplicationContext(); + poiTypes = application.getPoiTypes(); + } + return poiTypes; + } + + private Map getAllTranslatedNames(Context context) { + if (allTranslatedNames == null) { + allTranslatedNames = getPoiTypes(context).getAllTranslatedNames(true); + } + return allTranslatedNames; + } + @Override public int getIconRes(Context context) { - if (context instanceof MapActivity) { - final OsmandApplication application = (OsmandApplication) (context).getApplicationContext(); - final MapPoiTypes poiTypes = application.getPoiTypes(); - final Map allTranslatedNames = poiTypes.getAllTranslatedNames(true); - PoiCategory category = getCategory(allTranslatedNames); - + PoiCategory category = getCategory(getAllTranslatedNames(context)); if (category != null) { - category.getIconKeyName(); - String res = category.getIconKeyName(); - if (res instanceof String && RenderingIcons.containsBigIcon(res)) { + if (res != null && RenderingIcons.containsBigIcon(res)) { return RenderingIcons.getBigIconResourceId(res); - } else { - return super.getIconRes(); } } - } return super.getIconRes(); } @@ -206,17 +213,14 @@ public class AddPOIAction extends QuickAction { final LinearLayout editTagsLineaLayout = (LinearLayout) view.findViewById(R.id.editTagsList); - final MapPoiTypes poiTypes = application.getPoiTypes(); - final Map allTranslatedNames = poiTypes.getAllTranslatedNames(true); final TagAdapterLinearLayoutHack mAdapter = new TagAdapterLinearLayoutHack(editTagsLineaLayout, getTagsFromParams(), deleteDrawable); // It is possible to not restart initialization every time, and probably move initialization to appInit - Map translatedTypes = poiTypes.getAllTranslatedNames(true); HashSet tagKeys = new HashSet<>(); HashSet valueKeys = new HashSet<>(); - for (AbstractPoiType abstractPoiType : translatedTypes.values()) { + for (AbstractPoiType abstractPoiType : getAllTranslatedNames(application).values()) { addPoiToStringSet(abstractPoiType, tagKeys, valueKeys); } - addPoiToStringSet(poiTypes.getOtherMapCategory(), tagKeys, valueKeys); + addPoiToStringSet(getPoiTypes(activity).getOtherMapCategory(), tagKeys, valueKeys); tagKeys.addAll(EditPoiDialogFragment.BASIC_TAGS); mAdapter.setTagData(tagKeys.toArray(new String[tagKeys.size()])); mAdapter.setValueData(valueKeys.toArray(new String[valueKeys.size()])); @@ -261,7 +265,7 @@ public class AddPOIAction extends QuickAction { public void afterTextChanged(Editable s) { String tp = s.toString(); putTagIntoParams(POI_TYPE_TAG, tp); - PoiCategory category = getCategory(allTranslatedNames); + PoiCategory category = getCategory(getAllTranslatedNames(application)); if (category != null) { poiTypeTextInputLayout.setHint(category.getTranslation()); @@ -294,8 +298,8 @@ public class AddPOIAction extends QuickAction { if (event.getX() >= (editText.getRight() - editText.getCompoundDrawables()[DRAWABLE_RIGHT].getBounds().width() - editText.getPaddingRight())) { - PoiCategory category = getCategory(allTranslatedNames); - PoiCategory tempPoiCategory = (category != null) ? category : poiTypes.getOtherPoiCategory(); + PoiCategory category = getCategory(getAllTranslatedNames(activity)); + PoiCategory tempPoiCategory = (category != null) ? category : getPoiTypes(activity).getOtherPoiCategory(); PoiSubTypeDialogFragment f = PoiSubTypeDialogFragment.createInstance(tempPoiCategory); f.setOnItemSelectListener(new PoiSubTypeDialogFragment.OnItemSelectListener() { @@ -315,7 +319,7 @@ public class AddPOIAction extends QuickAction { } }); - setUpAdapterForPoiTypeEditText(activity, allTranslatedNames, poiTypeEditText); + setUpAdapterForPoiTypeEditText(activity, getAllTranslatedNames(activity), poiTypeEditText); ImageButton onlineDocumentationButton = (ImageButton) view.findViewById(R.id.onlineDocumentationButton);