add asyncTask and fix add/update methods
This commit is contained in:
parent
1fe42339ee
commit
2f5d3c0ef8
1 changed files with 57 additions and 6 deletions
|
@ -1,5 +1,6 @@
|
||||||
package net.osmand.plus.mapmarkers;
|
package net.osmand.plus.mapmarkers;
|
||||||
|
|
||||||
|
import android.app.Activity;
|
||||||
import android.app.Dialog;
|
import android.app.Dialog;
|
||||||
import android.content.ClipData;
|
import android.content.ClipData;
|
||||||
import android.content.ClipboardManager;
|
import android.content.ClipboardManager;
|
||||||
|
@ -54,11 +55,9 @@ import android.widget.Toast;
|
||||||
import net.osmand.AndroidUtils;
|
import net.osmand.AndroidUtils;
|
||||||
import net.osmand.IndexConstants;
|
import net.osmand.IndexConstants;
|
||||||
import net.osmand.Location;
|
import net.osmand.Location;
|
||||||
import net.osmand.data.LatLon;
|
|
||||||
import net.osmand.plus.GPXUtilities;
|
import net.osmand.plus.GPXUtilities;
|
||||||
import net.osmand.plus.GpxSelectionHelper;
|
import net.osmand.plus.GpxSelectionHelper;
|
||||||
import net.osmand.plus.MapMarkersHelper;
|
import net.osmand.plus.MapMarkersHelper;
|
||||||
import net.osmand.plus.MapMarkersHelper.MapMarker;
|
|
||||||
import net.osmand.plus.OsmAndLocationProvider.OsmAndCompassListener;
|
import net.osmand.plus.OsmAndLocationProvider.OsmAndCompassListener;
|
||||||
import net.osmand.plus.OsmAndLocationProvider.OsmAndLocationListener;
|
import net.osmand.plus.OsmAndLocationProvider.OsmAndLocationListener;
|
||||||
import net.osmand.plus.OsmandApplication;
|
import net.osmand.plus.OsmandApplication;
|
||||||
|
@ -149,7 +148,12 @@ public class CoordinateInputDialogFragment extends DialogFragment implements Osm
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
public TrackActivity getTrackActivity() {
|
public TrackActivity getTrackActivity() {
|
||||||
|
Activity activity = getActivity();
|
||||||
|
if (activity instanceof TrackActivity) {
|
||||||
return (TrackActivity) getActivity();
|
return (TrackActivity) getActivity();
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void syncGpx(GPXUtilities.GPXFile gpxFile) {
|
private void syncGpx(GPXUtilities.GPXFile gpxFile) {
|
||||||
|
@ -161,11 +165,55 @@ public class CoordinateInputDialogFragment extends DialogFragment implements Osm
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void addWpt(GPXUtilities.GPXFile gpx, String description, String name, String category, int color, double lat, double lon) {
|
protected void addWpt(GPXUtilities.GPXFile gpx, String description, String name, String category, int color, double lat, double lon) {
|
||||||
|
if (gpx != null) {
|
||||||
|
if (gpx.showCurrentTrack) {
|
||||||
|
savingTrackHelper.insertPointData(lat, lon, System.currentTimeMillis(), description, name, category, color);
|
||||||
|
selectedGpxHelper.setGpxFileToDisplay(gpx);
|
||||||
|
} else {
|
||||||
gpx.addWptPt(lat, lon, System.currentTimeMillis(), description, name, category, color);
|
gpx.addWptPt(lat, lon, System.currentTimeMillis(), description, name, category, color);
|
||||||
|
new SaveGpxAsyncTask(getMyApplication(), gpx, false).executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR);
|
||||||
|
}
|
||||||
|
syncGpx(gpx);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static class SaveGpxAsyncTask extends AsyncTask<Void, Void, Void> {
|
||||||
|
private final OsmandApplication app;
|
||||||
|
private final GPXUtilities.GPXFile gpx;
|
||||||
|
private final boolean gpxSelected;
|
||||||
|
|
||||||
|
SaveGpxAsyncTask(OsmandApplication app, GPXUtilities.GPXFile gpx, boolean gpxSelected) {
|
||||||
|
this.app = app;
|
||||||
|
this.gpx = gpx;
|
||||||
|
this.gpxSelected = gpxSelected;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected Void doInBackground(Void... params) {
|
||||||
|
GPXUtilities.writeGpxFile(new File(gpx.path), gpx, app);
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onPostExecute(Void aVoid) {
|
||||||
|
if (!gpxSelected) {
|
||||||
|
app.getSelectedGpxHelper().setGpxFileToDisplay(gpx);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void updateWpt(GPXUtilities.GPXFile gpx, String description, String name, String category, int color, double lat, double lon) {
|
protected void updateWpt(GPXUtilities.GPXFile gpx, String description, String name, String category, int color, double lat, double lon) {
|
||||||
|
|
||||||
|
if (gpx != null) {
|
||||||
|
if (gpx.showCurrentTrack) {
|
||||||
|
savingTrackHelper.updatePointData(selectedWpt, lat, lon, System.currentTimeMillis(), description, name, category, color);
|
||||||
|
selectedGpxHelper.setGpxFileToDisplay(gpx);
|
||||||
|
} else {
|
||||||
gpx.updateWptPt(selectedWpt, lat, lon, System.currentTimeMillis(), description, name, category, color);
|
gpx.updateWptPt(selectedWpt, lat, lon, System.currentTimeMillis(), description, name, category, color);
|
||||||
|
new SaveGpxAsyncTask(getMyApplication(), gpx, false).executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR);
|
||||||
|
}
|
||||||
|
syncGpx(gpx);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void quit() {
|
private void quit() {
|
||||||
|
@ -176,6 +224,9 @@ public class CoordinateInputDialogFragment extends DialogFragment implements Osm
|
||||||
GPXUtilities.GPXFile gpx = getGpx();
|
GPXUtilities.GPXFile gpx = getGpx();
|
||||||
GPXUtilities.writeGpxFile(new File(gpx.path), gpx, getMyApplication());
|
GPXUtilities.writeGpxFile(new File(gpx.path), gpx, getMyApplication());
|
||||||
syncGpx(gpx);
|
syncGpx(gpx);
|
||||||
|
if (listener != null) {
|
||||||
|
listener.onMapMarkersSaved();
|
||||||
|
}
|
||||||
dismiss();
|
dismiss();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in a new issue