Fix maps order in multi menu

This commit is contained in:
Alexey Kulish 2015-11-12 16:45:11 +03:00
parent 0d684eb21e
commit 657eeeaaf3

View file

@ -30,6 +30,7 @@ public class MapMultiSelectionMenu extends BaseMenuController {
private LatLon latLon; private LatLon latLon;
private PointDescription pointDescription; private PointDescription pointDescription;
private Object object; private Object object;
private int order;
private MapActivity mapActivity; private MapActivity mapActivity;
private MenuController controller; private MenuController controller;
@ -107,8 +108,6 @@ public class MapMultiSelectionMenu extends BaseMenuController {
this.selectedObjects.clear(); this.selectedObjects.clear();
this.selectedObjects.putAll(selectedObjects); this.selectedObjects.putAll(selectedObjects);
objects.clear(); objects.clear();
int order = Integer.MAX_VALUE;
MenuObject topObject = null;
for (Map.Entry<Object, IContextMenuProvider> e : selectedObjects.entrySet()) { for (Map.Entry<Object, IContextMenuProvider> e : selectedObjects.entrySet()) {
Object selectedObj = e.getKey(); Object selectedObj = e.getKey();
IContextMenuProvider contextObject = selectedObjects.get(selectedObj); IContextMenuProvider contextObject = selectedObjects.get(selectedObj);
@ -130,25 +129,20 @@ public class MapMultiSelectionMenu extends BaseMenuController {
objects.add(menuObject); objects.add(menuObject);
if (contextObject instanceof ContextMenuLayer.IContextMenuProviderSelection) { if (contextObject instanceof ContextMenuLayer.IContextMenuProviderSelection) {
int i = ((ContextMenuLayer.IContextMenuProviderSelection) contextObject).getOrder(selectedObj); menuObject.order = ((ContextMenuLayer.IContextMenuProviderSelection) contextObject).getOrder(selectedObj);
if (i < order) {
topObject = menuObject;
order = i;
}
} }
} }
Collections.sort(objects, new Comparator<MenuObject>() { Collections.sort(objects, new Comparator<MenuObject>() {
@Override @Override
public int compare(MenuObject obj1, MenuObject obj2) { public int compare(MenuObject obj1, MenuObject obj2) {
return obj1.getTitleStr().compareToIgnoreCase(obj2.getTitleStr()); if (obj1.order == obj2.order) {
return obj1.getTitleStr().compareToIgnoreCase(obj2.getTitleStr());
} else {
return obj1.order - obj2.order;
}
} }
}); });
if (topObject != null) {
objects.remove(topObject);
objects.add(0, topObject);
}
} }
private void clearMenu() { private void clearMenu() {