Update gpx

This commit is contained in:
Victor Shcherb 2015-04-21 01:22:30 +02:00
parent ac2f61ff22
commit b138522e4e
5 changed files with 78 additions and 64 deletions

View file

@ -2,17 +2,27 @@
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent" android:layout_width="fill_parent"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:descendantFocusability="blocksDescendants"
android:orientation="horizontal"
android:paddingLeft="@dimen/list_content_padding" android:paddingLeft="@dimen/list_content_padding"
android:paddingRight="@dimen/list_content_padding" android:paddingRight="@dimen/list_content_padding" >
android:orientation="horizontal" >
<ImageView
android:id="@+id/icon"
android:layout_width="@dimen/list_item_height"
android:layout_height="@dimen/list_item_height"
android:background="?attr/dashboard_button"
android:scaleType="center"
android:visibility="gone"
android:src="@drawable/ic_action_settings" />
<TextView <TextView
android:id="@+id/title" android:id="@+id/title"
android:layout_width="0dp" android:layout_width="0dp"
android:layout_height="fill_parent" android:layout_height="fill_parent"
android:layout_gravity="center_vertical" android:layout_gravity="center_vertical"
android:gravity="center_vertical"
android:layout_weight="1" android:layout_weight="1"
android:gravity="center_vertical"
android:text="@string/layer_poi" android:text="@string/layer_poi"
android:textSize="@dimen/default_list_text_size" /> android:textSize="@dimen/default_list_text_size" />

View file

@ -3,7 +3,8 @@
android:layout_width="fill_parent" android:layout_width="fill_parent"
android:layout_height="@dimen/list_item_height" android:layout_height="@dimen/list_item_height"
android:paddingLeft="@dimen/list_content_padding" android:paddingLeft="@dimen/list_content_padding"
android:orientation="horizontal" > android:orientation="horizontal"
>
<LinearLayout <LinearLayout
android:layout_width="0dp" android:layout_width="0dp"
@ -18,7 +19,6 @@
android:text="@string/gpx_navigation" android:text="@string/gpx_navigation"
android:textSize="@dimen/default_sub_text_size" > android:textSize="@dimen/default_sub_text_size" >
</TextView> </TextView>
<Spinner <Spinner
android:id="@+id/GPXRouteSpinner" android:id="@+id/GPXRouteSpinner"
android:layout_width="fill_parent" android:layout_width="fill_parent"
@ -28,12 +28,4 @@
</Spinner> </Spinner>
</LinearLayout> </LinearLayout>
<ImageView
android:id="@+id/settings"
android:layout_width="@dimen/list_item_height"
android:layout_height="@dimen/list_item_height"
android:scaleType="center"
android:background="?attr/dashboard_button"
android:src="@drawable/ic_action_settings" />
</LinearLayout> </LinearLayout>

View file

@ -171,6 +171,7 @@
android:id="@+id/Info" android:id="@+id/Info"
android:layout_width="fill_parent" android:layout_width="fill_parent"
android:layout_height="@dimen/list_item_height" android:layout_height="@dimen/list_item_height"
android:background="?attr/dashboard_button"
android:orientation="horizontal" > android:orientation="horizontal" >
<ImageView <ImageView

View file

@ -298,14 +298,14 @@ public class MapControlsLayer extends OsmandMapLayer {
protected void clickRouteParams() { protected void clickRouteParams() {
notifyClicked(); notifyClicked();
optionsRouteControlDialog.showAndHideDialog();
mapRouteInfoControlDialog.hideDialog(); mapRouteInfoControlDialog.hideDialog();
optionsRouteControlDialog.showAndHideDialog();
} }
protected void clickRouteWaypoints() { protected void clickRouteWaypoints() {
notifyClicked(); notifyClicked();
mapRouteInfoControlDialog.showHideDialog();
optionsRouteControlDialog.hideDialog(); optionsRouteControlDialog.hideDialog();
mapRouteInfoControlDialog.showHideDialog();
} }
protected void clickRouteCancel() { protected void clickRouteCancel() {

View file

@ -95,6 +95,10 @@ public class MapRoutePreferencesControl {
} }
private static class OtherSettingsRoutingParameter extends LocalRoutingParameter {
}
private static class OtherLocalRoutingParameter extends LocalRoutingParameter { private static class OtherLocalRoutingParameter extends LocalRoutingParameter {
public String text; public String text;
public boolean selected; public boolean selected;
@ -268,6 +272,7 @@ public class MapRoutePreferencesControl {
} }
} }
list.add(new GpxLocalRoutingParameter()); list.add(new GpxLocalRoutingParameter());
list.add(new OtherSettingsRoutingParameter());
return list; return list;
} }
@ -299,11 +304,17 @@ public class MapRoutePreferencesControl {
@Override @Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) { public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
if(listAdapter.getItem(position) instanceof OtherSettingsRoutingParameter) {
final Intent settings = new Intent(mapActivity, SettingsNavigationActivity.class);
settings.putExtra(SettingsNavigationActivity.INTENT_SKIP_DIALOG, true);
mapActivity.startActivity(settings);
} else {
CheckBox ch = (CheckBox) view.findViewById(R.id.check_item); CheckBox ch = (CheckBox) view.findViewById(R.id.check_item);
if (ch != null) { if (ch != null) {
ch.setChecked(!ch.isChecked()); ch.setChecked(!ch.isChecked());
} }
} }
}
}); });
listAdapter = new ArrayAdapter<LocalRoutingParameter>(ctx, R.layout.layers_list_activity_item, R.id.title, listAdapter = new ArrayAdapter<LocalRoutingParameter>(ctx, R.layout.layers_list_activity_item, R.id.title,
getRoutingParameters(settings.APPLICATION_MODE.get())) { getRoutingParameters(settings.APPLICATION_MODE.get())) {
@ -315,6 +326,15 @@ public class MapRoutePreferencesControl {
setupGPXSpinner(v); setupGPXSpinner(v);
return v; return v;
} }
if(parameter instanceof OtherSettingsRoutingParameter) {
View v = mapActivity.getLayoutInflater().inflate(R.layout.layers_list_activity_item, null);
final ImageView icon = (ImageView) v.findViewById(R.id.icon);
icon.setImageDrawable(mapActivity.getMyApplication().getIconsCache().getContentIcon(R.drawable.ic_action_gsettings_dark));
icon.setVisibility(View.VISIBLE);
((TextView)v.findViewById(R.id.title)).setText(R.string.routing_settings_2);
v.findViewById(R.id.check_item).setVisibility(View.GONE);
return v;
}
return inflateRoutingParameter(position); return inflateRoutingParameter(position);
} }
@ -420,6 +440,42 @@ public class MapRoutePreferencesControl {
private void setupGPXSpinner(View settingsDlg) { private void setupGPXSpinner(View settingsDlg) {
final Spinner gpxSpinner = (Spinner) settingsDlg.findViewById(R.id.GPXRouteSpinner); final Spinner gpxSpinner = (Spinner) settingsDlg.findViewById(R.id.GPXRouteSpinner);
updateSpinnerItems(gpxSpinner); updateSpinnerItems(gpxSpinner);
}
protected void openGPXFileSelection(final Spinner gpxSpinner) {
GpxUiHelper.selectGPXFile(mapActivity, false, false, new CallbackWithObject<GPXUtilities.GPXFile[]>() {
@Override
public boolean processResult(GPXFile[] result) {
mapActivity.getMapActions().setGPXRouteParams(result[0]);
mapActivity.getMyApplication().getTargetPointsHelper().updateRouteAndReferesh(true);
updateSpinnerItems(gpxSpinner);
updateParameters();
mapActivity.getRoutingHelper().recalculateRouteDueToSettingsChange();
return true;
}
});
}
private void updateSpinnerItems(final Spinner gpxSpinner) {
ArrayList<String> gpxActions = new ArrayList<String>();
gpxActions.add(mapActivity.getString(R.string.shared_string_none));
gpxActions.add(mapActivity.getString(R.string.select_gpx));
GPXRouteParamsBuilder rp = mapActivity.getRoutingHelper().getCurrentGPXRoute();
if (rp != null) {
gpxActions.add(new File(rp.getFile().path).getName());
}
ArrayAdapter<String> gpxAdapter = new ArrayAdapter<String>(mapActivity, android.R.layout.simple_spinner_item,
gpxActions);
gpxAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
gpxSpinner.setAdapter(gpxAdapter);
if (rp != null) {
gpxSpinner.setSelection(2);
} else {
gpxSpinner.setSelection(0);
}
gpxSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() { gpxSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
@Override @Override
@ -443,52 +499,6 @@ public class MapRoutePreferencesControl {
public void onNothingSelected(AdapterView<?> parent) { public void onNothingSelected(AdapterView<?> parent) {
} }
}); });
final ImageView settings = (ImageView) settingsDlg.findViewById(R.id.settings);
settings.setImageDrawable(mapActivity.getMyApplication().getIconsCache().getContentIcon(R.drawable.ic_action_gsettings_dark));
settings.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
final Intent settings = new Intent(mapActivity, SettingsNavigationActivity.class);
settings.putExtra(SettingsNavigationActivity.INTENT_SKIP_DIALOG, true);
mapActivity.startActivity(settings);
}
});
}
protected void openGPXFileSelection(final Spinner gpxSpinner) {
GpxUiHelper.selectGPXFile(mapActivity, false, false, new CallbackWithObject<GPXUtilities.GPXFile[]>() {
@Override
public boolean processResult(GPXFile[] result) {
mapActivity.getMapActions().setGPXRouteParams(result[0]);
mapActivity.getMyApplication().getTargetPointsHelper().updateRouteAndReferesh(true);
updateSpinnerItems(gpxSpinner);
updateParameters();
mapActivity.getRoutingHelper().recalculateRouteDueToSettingsChange();
return true;
}
});
}
private void updateSpinnerItems(Spinner gpxSpinner) {
ArrayList<String> gpxActions = new ArrayList<String>();
gpxActions.add(mapActivity.getString(R.string.shared_string_none));
gpxActions.add(mapActivity.getString(R.string.select_gpx));
GPXRouteParamsBuilder rp = mapActivity.getRoutingHelper().getCurrentGPXRoute();
if (rp != null) {
gpxActions.add(new File(rp.getFile().path).getName());
}
ArrayAdapter<String> gpxAdapter = new ArrayAdapter<String>(mapActivity, android.R.layout.simple_spinner_item,
gpxActions);
gpxAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
gpxSpinner.setAdapter(gpxAdapter);
if (rp != null) {
gpxSpinner.setSelection(2);
} else {
gpxSpinner.setSelection(0);
}
} }
public boolean isDialogVisible() { public boolean isDialogVisible() {
@ -498,6 +508,7 @@ public class MapRoutePreferencesControl {
public void hideDialog() { public void hideDialog() {
if(dialog != null) { if(dialog != null) {
dialog.hide(); dialog.hide();
dialog = null;
} }
} }