Merge pull request #10851 from osmandapp/dont_overwrite_unchanged_gpx
Don't overwrite GPX file if it's there were no changes
This commit is contained in:
commit
c7a4624faa
1 changed files with 29 additions and 17 deletions
|
@ -231,7 +231,7 @@ public class MeasurementToolFragment extends BaseOsmAndFragment implements Route
|
||||||
@Override
|
@Override
|
||||||
public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container,
|
public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container,
|
||||||
@Nullable Bundle savedInstanceState) {
|
@Nullable Bundle savedInstanceState) {
|
||||||
final MapActivity mapActivity = (MapActivity) getActivity();
|
MapActivity mapActivity = (MapActivity) getActivity();
|
||||||
if (mapActivity == null) {
|
if (mapActivity == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -375,13 +375,16 @@ public class MeasurementToolFragment extends BaseOsmAndFragment implements Route
|
||||||
mainView.findViewById(R.id.options_button).setOnClickListener(new OnClickListener() {
|
mainView.findViewById(R.id.options_button).setOnClickListener(new OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(View view) {
|
public void onClick(View view) {
|
||||||
boolean trackSnappedToRoad = !editingCtx.isApproximationNeeded();
|
MapActivity mapActivity = getMapActivity();
|
||||||
boolean addNewSegmentAllowed = editingCtx.isAddNewSegmentAllowed();
|
if (mapActivity != null) {
|
||||||
OptionsBottomSheetDialogFragment.showInstance(mapActivity.getSupportFragmentManager(),
|
boolean trackSnappedToRoad = !editingCtx.isApproximationNeeded();
|
||||||
MeasurementToolFragment.this,
|
boolean addNewSegmentAllowed = editingCtx.isAddNewSegmentAllowed();
|
||||||
trackSnappedToRoad, addNewSegmentAllowed,
|
OptionsBottomSheetDialogFragment.showInstance(mapActivity.getSupportFragmentManager(),
|
||||||
editingCtx.getAppMode().getStringKey()
|
MeasurementToolFragment.this,
|
||||||
);
|
trackSnappedToRoad, addNewSegmentAllowed,
|
||||||
|
editingCtx.getAppMode().getStringKey()
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -431,7 +434,8 @@ public class MeasurementToolFragment extends BaseOsmAndFragment implements Route
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onSelectPoint(int selectedPointPos) {
|
public void onSelectPoint(int selectedPointPos) {
|
||||||
if (selectedPointPos != -1) {
|
MapActivity mapActivity = getMapActivity();
|
||||||
|
if (mapActivity != null && selectedPointPos != -1) {
|
||||||
openSelectedPointMenu(mapActivity);
|
openSelectedPointMenu(mapActivity);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -440,7 +444,7 @@ public class MeasurementToolFragment extends BaseOsmAndFragment implements Route
|
||||||
measurementLayer.setOnMeasureDistanceToCenterListener(new MeasurementToolLayer.OnMeasureDistanceToCenter() {
|
measurementLayer.setOnMeasureDistanceToCenterListener(new MeasurementToolLayer.OnMeasureDistanceToCenter() {
|
||||||
@Override
|
@Override
|
||||||
public void onMeasure(float distance, float bearing) {
|
public void onMeasure(float distance, float bearing) {
|
||||||
String distStr = OsmAndFormatter.getFormattedDistance(distance, mapActivity.getMyApplication());
|
String distStr = OsmAndFormatter.getFormattedDistance(distance, app);
|
||||||
String azimuthStr = OsmAndFormatter.getFormattedAzimuth(bearing, app);
|
String azimuthStr = OsmAndFormatter.getFormattedAzimuth(bearing, app);
|
||||||
distanceToCenterTv.setText(String.format("%1$s • %2$s", distStr, azimuthStr));
|
distanceToCenterTv.setText(String.format("%1$s • %2$s", distStr, azimuthStr));
|
||||||
TextViewCompat.setAutoSizeTextTypeUniformWithConfiguration(
|
TextViewCompat.setAutoSizeTextTypeUniformWithConfiguration(
|
||||||
|
@ -496,8 +500,13 @@ public class MeasurementToolFragment extends BaseOsmAndFragment implements Route
|
||||||
public void onClick(View v) {
|
public void onClick(View v) {
|
||||||
if (isFollowTrackMode()) {
|
if (isFollowTrackMode()) {
|
||||||
startTrackNavigation();
|
startTrackNavigation();
|
||||||
} else {
|
} else if (editingCtx.isNewData() || editingCtx.hasChanges()) {
|
||||||
saveChanges(FinalSaveAction.SHOW_SNACK_BAR_AND_CLOSE, false);
|
saveChanges(FinalSaveAction.SHOW_SNACK_BAR_AND_CLOSE, false);
|
||||||
|
} else {
|
||||||
|
MapActivity mapActivity = getMapActivity();
|
||||||
|
if (mapActivity != null) {
|
||||||
|
dismiss(mapActivity, false);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -535,9 +544,12 @@ public class MeasurementToolFragment extends BaseOsmAndFragment implements Route
|
||||||
configBtn.setOnClickListener(new OnClickListener() {
|
configBtn.setOnClickListener(new OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(View v) {
|
public void onClick(View v) {
|
||||||
RouteOptionsBottomSheet.showInstance(
|
MapActivity mapActivity = getMapActivity();
|
||||||
mapActivity, MeasurementToolFragment.this, DialogMode.PLAN_ROUTE,
|
if (mapActivity != null) {
|
||||||
editingCtx.getAppMode().getStringKey());
|
RouteOptionsBottomSheet.showInstance(
|
||||||
|
mapActivity, MeasurementToolFragment.this, DialogMode.PLAN_ROUTE,
|
||||||
|
editingCtx.getAppMode().getStringKey());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -931,7 +943,7 @@ public class MeasurementToolFragment extends BaseOsmAndFragment implements Route
|
||||||
app.getTargetPointsHelper().updateRouteAndRefresh(true);
|
app.getTargetPointsHelper().updateRouteAndRefresh(true);
|
||||||
app.getRoutingHelper().onSettingsChanged(true);
|
app.getRoutingHelper().onSettingsChanged(true);
|
||||||
} else {
|
} else {
|
||||||
mapActivity.getMapActions().stopNavigationActionConfirm(null , new Runnable() {
|
mapActivity.getMapActions().stopNavigationActionConfirm(null, new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
MapActivity mapActivity = getMapActivity();
|
MapActivity mapActivity = getMapActivity();
|
||||||
|
@ -1145,7 +1157,7 @@ public class MeasurementToolFragment extends BaseOsmAndFragment implements Route
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onChangeApplicationMode(ApplicationMode mode, RouteBetweenPointsDialogType dialogType,
|
public void onChangeApplicationMode(ApplicationMode mode, RouteBetweenPointsDialogType dialogType,
|
||||||
RouteBetweenPointsDialogMode dialogMode) {
|
RouteBetweenPointsDialogMode dialogMode) {
|
||||||
MeasurementToolLayer measurementLayer = getMeasurementLayer();
|
MeasurementToolLayer measurementLayer = getMeasurementLayer();
|
||||||
if (measurementLayer != null) {
|
if (measurementLayer != null) {
|
||||||
ChangeRouteType changeRouteType = ChangeRouteType.NEXT_SEGMENT;
|
ChangeRouteType changeRouteType = ChangeRouteType.NEXT_SEGMENT;
|
||||||
|
@ -1947,7 +1959,7 @@ public class MeasurementToolFragment extends BaseOsmAndFragment implements Route
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean showInstance(FragmentManager fragmentManager, MeasurementEditingContext editingCtx,
|
public static boolean showInstance(FragmentManager fragmentManager, MeasurementEditingContext editingCtx,
|
||||||
boolean followTrackMode) {
|
boolean followTrackMode) {
|
||||||
MeasurementToolFragment fragment = new MeasurementToolFragment();
|
MeasurementToolFragment fragment = new MeasurementToolFragment();
|
||||||
fragment.setEditingCtx(editingCtx);
|
fragment.setEditingCtx(editingCtx);
|
||||||
fragment.setMode(FOLLOW_TRACK_MODE, followTrackMode);
|
fragment.setMode(FOLLOW_TRACK_MODE, followTrackMode);
|
||||||
|
|
Loading…
Reference in a new issue