Context menu code refactor, remove bold tag

This commit is contained in:
Alexey Kulish 2015-09-10 11:21:58 +03:00
parent 25abde3308
commit 2aef26dfc9
5 changed files with 37 additions and 43 deletions

View file

@ -62,8 +62,7 @@
android:layout_marginRight="12dp"
android:text="@string/search_address_building"
android:textSize="@dimen/default_list_text_size_large"
android:textColor="?android:textColorPrimary"
android:textStyle="bold"/>
android:textColor="?android:textColorPrimary"/>
<TextView
android:id="@+id/context_menu_line2"

View file

@ -125,6 +125,7 @@ public class MapActivity extends AccessibleActivity {
private boolean intentLocation = false;
private DashboardOnMap dashboardOnMap = new DashboardOnMap(this);
private MapContextMenu contextMenuOnMap;
private AppInitializeListener initListener;
private IMapDownloaderCallback downloaderCallback;
private DrawerLayout drawerLayout;
@ -156,6 +157,7 @@ public class MapActivity extends AccessibleActivity {
app = getMyApplication();
settings = app.getSettings();
app.applyTheme(this);
contextMenuOnMap = new MapContextMenu(app);
supportRequestWindowFeature(Window.FEATURE_NO_TITLE);
super.onCreate(savedInstanceState);
// Full screen is not used here
@ -249,9 +251,6 @@ public class MapActivity extends AccessibleActivity {
});
drawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
MapContextMenu.getInstance().setApp(app);
MapContextMenu.getInstance().setMapActivity(this);
}
@ -975,6 +974,10 @@ public class MapActivity extends AccessibleActivity {
return dashboardOnMap;
}
public MapContextMenu getContextMenu() {
return contextMenuOnMap;
}
public void openDrawer() {
drawerLayout.openDrawer(Gravity.LEFT);
}

View file

@ -21,7 +21,6 @@ import net.osmand.util.Algorithms;
public class MapContextMenu {
private MapActivity mapActivity;
private OsmandApplication app;
private OsmandSettings settings;
@ -30,7 +29,7 @@ public class MapContextMenu {
private String foundStreetName;
public boolean isMenuVisible() {
public boolean isMenuVisible(MapActivity mapActivity) {
return mapActivity.getSupportFragmentManager().findFragmentByTag("MapContextMenuFragment") != null;
}
@ -42,29 +41,15 @@ public class MapContextMenu {
return object;
}
public void setMapActivity(MapActivity mapActivity) {
this.mapActivity = mapActivity;
}
public void setApp(OsmandApplication app) {
public MapContextMenu(OsmandApplication app) {
this.app = app;
settings = app.getSettings();
}
private static MapContextMenu ourInstance = new MapContextMenu();
public void show(MapActivity mapActivity, PointDescription pointDescription, Object object) {
public static MapContextMenu getInstance() {
return ourInstance;
}
private MapContextMenu() {
}
public void show(PointDescription pointDescription, Object object) {
if (isMenuVisible())
hide();
if (isMenuVisible(mapActivity))
hide(mapActivity);
this.pointDescription = pointDescription;
this.object = object;
@ -75,7 +60,7 @@ public class MapContextMenu {
}
public void hide() {
public void hide(MapActivity mapActivity) {
Fragment fragment = mapActivity.getSupportFragmentManager().findFragmentByTag("MapContextMenuFragment");
if (fragment != null)
@ -139,7 +124,7 @@ public class MapContextMenu {
return Algorithms.isEmpty(res) ? "Address is unknown yet" : res; // todo: text constant
}
public String getLocationStr() {
public String getLocationStr(MapActivity mapActivity) {
if (foundStreetName == null)
return pointDescription.getLocationName(mapActivity, true).replaceAll("\n", "");
else
@ -157,11 +142,11 @@ public class MapContextMenu {
return null;
}
public void buttonNavigatePressed() {
public void buttonNavigatePressed(MapActivity mapActivity) {
mapActivity.getMapActions().showNavigationContextMenuPoint(pointDescription.getLat(), pointDescription.getLon());
}
public void buttonFavoritePressed() {
public void buttonFavoritePressed(MapActivity mapActivity) {
if (object != null && object instanceof FavouritePoint) {
mapActivity.getMapActions().editFavoritePoint((FavouritePoint)object);
} else {
@ -169,11 +154,11 @@ public class MapContextMenu {
}
}
public void buttonSharePressed() {
public void buttonSharePressed(MapActivity mapActivity) {
mapActivity.getMapActions().shareLocation(pointDescription.getLat(), pointDescription.getLon());
}
public void buttonMorePressed() {
public void buttonMorePressed(MapActivity mapActivity) {
final ContextMenuAdapter menuAdapter = new ContextMenuAdapter(mapActivity);
if (object != null) {
for (OsmandMapLayer layer : mapActivity.getMapView().getLayers()) {

View file

@ -241,7 +241,7 @@ public class MapContextMenuFragment extends Fragment {
IconsCache iconsCache = getMyApplication().getIconsCache();
boolean light = getMyApplication().getSettings().isLightContent();
int iconId = MapContextMenu.getInstance().getLeftIconId();
int iconId = getCtxMenu().getLeftIconId();
final View iconLayout = view.findViewById(R.id.context_menu_icon_layout);
final ImageView iconView = (ImageView)view.findViewById(R.id.context_menu_icon_view);
@ -254,11 +254,11 @@ public class MapContextMenuFragment extends Fragment {
// Text line 1
TextView line1 = (TextView) view.findViewById(R.id.context_menu_line1);
line1.setText(MapContextMenu.getInstance().getAddressStr());
line1.setText(getCtxMenu().getAddressStr());
// Text line 2
TextView line2 = (TextView) view.findViewById(R.id.context_menu_line2);
line2.setText(MapContextMenu.getInstance().getLocationStr());
line2.setText(getCtxMenu().getLocationStr(getMapActivity()));
// Close button
final ImageView closeButtonView = (ImageView)view.findViewById(R.id.context_menu_close_btn_view);
@ -279,7 +279,7 @@ public class MapContextMenuFragment extends Fragment {
buttonNavigate.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
MapContextMenu.getInstance().buttonNavigatePressed();
getCtxMenu().buttonNavigatePressed(getMapActivity());
}
});
@ -289,7 +289,7 @@ public class MapContextMenuFragment extends Fragment {
buttonFavorite.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
MapContextMenu.getInstance().buttonFavoritePressed();
getCtxMenu().buttonFavoritePressed(getMapActivity());
}
});
@ -299,7 +299,7 @@ public class MapContextMenuFragment extends Fragment {
buttonShare.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
MapContextMenu.getInstance().buttonSharePressed();
getCtxMenu().buttonSharePressed(getMapActivity());
}
});
@ -309,12 +309,12 @@ public class MapContextMenuFragment extends Fragment {
buttonMore.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
MapContextMenu.getInstance().buttonMorePressed();
getCtxMenu().buttonMorePressed(getMapActivity());
}
});
// Menu controller
menuController = MapContextMenu.getInstance().getMenuController();
menuController = getCtxMenu().getMenuController();
bottomView = view.findViewById(R.id.context_menu_bottom_view);
if (menuController != null) {
bottomView.setOnTouchListener(new View.OnTouchListener() {
@ -397,14 +397,22 @@ public class MapContextMenuFragment extends Fragment {
.addToBackStack(null).commit();
}
private MapContextMenu getCtxMenu() {
return ((MapActivity)getActivity()).getContextMenu();
}
private MapActivity getMapActivity() {
return (MapActivity)getActivity();
}
// Utils
public int getScreenHeight() {
private int getScreenHeight() {
DisplayMetrics dm = new DisplayMetrics();
getActivity().getWindowManager().getDefaultDisplay().getMetrics(dm);
return dm.heightPixels;
}
public int dpToPx(float dp) {
private int dpToPx(float dp) {
Resources r = getActivity().getResources();
return (int) TypedValue.applyDimension(
COMPLEX_UNIT_DIP,

View file

@ -23,7 +23,6 @@ import net.osmand.data.RotatedTileBox;
import net.osmand.plus.ContextMenuAdapter;
import net.osmand.plus.R;
import net.osmand.plus.activities.MapActivity;
import net.osmand.plus.mapcontextmenu.MapContextMenu;
import java.util.ArrayList;
import java.util.Iterator;
@ -511,7 +510,7 @@ public class ContextMenuLayer extends OsmandMapLayer {
this.latLon = new LatLon(pointDescription.getLat(), pointDescription.getLon());
showMapContextMenuMarker();
MapContextMenu.getInstance().show(pointDescription, selectedObj);
activity.getContextMenu().show(activity, pointDescription, selectedObj);
}