X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=altosdroid%2Fsrc%2Forg%2Faltusmetrum%2FAltosDroid%2FPreloadMapActivity.java;h=498b208ef8e9f92e180fda89b3208d444d6d7cda;hb=51bf46248ca7ee3c817e62274b7366258c9f87cf;hp=2febaf29e5ccdc5c2b42e6cfd05f2fb3908261f5;hpb=85013045ca505096064aaf45c312b158d0263d2a;p=fw%2Faltos diff --git a/altosdroid/src/org/altusmetrum/AltosDroid/PreloadMapActivity.java b/altosdroid/src/org/altusmetrum/AltosDroid/PreloadMapActivity.java index 2febaf29..498b208e 100644 --- a/altosdroid/src/org/altusmetrum/AltosDroid/PreloadMapActivity.java +++ b/altosdroid/src/org/altusmetrum/AltosDroid/PreloadMapActivity.java @@ -36,6 +36,10 @@ import android.view.Window; import android.view.View.OnClickListener; import android.widget.*; import android.widget.AdapterView.*; +import android.location.Location; +import android.location.LocationManager; +import android.location.LocationListener; +import android.location.Criteria; import org.altusmetrum.altoslib_7.*; @@ -45,7 +49,7 @@ import org.altusmetrum.altoslib_7.*; * by the user, the MAC address of the device is sent back to the parent * Activity in the result Intent. */ -public class PreloadMapActivity extends Activity implements AltosLaunchSiteListener, AltosMapInterface, AltosMapLoaderListener { +public class PreloadMapActivity extends Activity implements AltosLaunchSiteListener, AltosMapInterface, AltosMapLoaderListener, LocationListener { private ArrayAdapter known_sites_adapter; @@ -54,9 +58,11 @@ public class PreloadMapActivity extends Activity implements AltosLaunchSiteListe private CheckBox roadmap; private CheckBox terrain; + private Spinner known_sites_spinner; private Spinner min_zoom; private Spinner max_zoom; - private Spinner tile_radius; + private TextView radius_label; + private Spinner radius; private EditText latitude; private EditText longitude; @@ -65,7 +71,6 @@ public class PreloadMapActivity extends Activity implements AltosLaunchSiteListe /* AltosMapLoaderListener interfaces */ public void loader_start(final int max) { - AltosDebug.debug("loader_start max %d\n", max); this.runOnUiThread(new Runnable() { public void run() { progress.setMax(max); @@ -75,7 +80,6 @@ public class PreloadMapActivity extends Activity implements AltosLaunchSiteListe } public void loader_notify(final int cur, final int max, final String name) { - AltosDebug.debug("loader_notify cur %4d max %4d %s\n", cur, max, name); this.runOnUiThread(new Runnable() { public void run() { progress.setProgress(cur); @@ -84,7 +88,6 @@ public class PreloadMapActivity extends Activity implements AltosLaunchSiteListe } public void loader_done(int max) { - AltosDebug.debug("loader_done max %d\n", max); this.runOnUiThread(new Runnable() { public void run() { progress.setProgress(0); @@ -111,7 +114,6 @@ public class PreloadMapActivity extends Activity implements AltosLaunchSiteListe } public PreloadMapImage(File file) { - AltosDebug.debug("preload file %s\n", file.toString()); } } @@ -160,7 +162,46 @@ public class PreloadMapActivity extends Activity implements AltosLaunchSiteListe } public void set_zoom_label(String label) { - AltosDebug.debug("zoom label %s\n", label); + } + + public void select_object(AltosLatLon latlon) { + } + + public void debug(String format, Object ... arguments) { + AltosDebug.debug(format, arguments); + } + + /* LocationProvider interface */ + + AltosLaunchSite current_location_site; + + public void onLocationChanged(Location location) { + AltosDebug.debug("location changed"); + if (current_location_site == null) { + AltosLaunchSite selected_item = (AltosLaunchSite) known_sites_spinner.getSelectedItem(); + + current_location_site = new AltosLaunchSite("Current Location", location.getLatitude(), location.getLongitude()); + known_sites_adapter.insert(current_location_site, 0); + + if (selected_item != null) + known_sites_spinner.setSelection(known_sites_adapter.getPosition(selected_item)); + else { + latitude.setText(new StringBuffer(String.format("%12.6f", current_location_site.latitude))); + longitude.setText(new StringBuffer(String.format("%12.6f", current_location_site.longitude))); + } + } else { + current_location_site.latitude = location.getLatitude(); + current_location_site.longitude = location.getLongitude(); + } + } + + public void onStatusChanged(String provider, int status, Bundle extras) { + } + + public void onProviderEnabled(String provider) { + } + + public void onProviderDisabled(String provider) { } private double text(EditText view) throws ParseException { @@ -187,8 +228,17 @@ public class PreloadMapActivity extends Activity implements AltosLaunchSiteListe return value(max_zoom); } - private int radius() { - return value(tile_radius); + private double value_distance(Spinner spinner) { + return (Double) spinner.getSelectedItem(); + } + + private double radius() { + double r = value_distance(radius); + if (AltosPreferences.imperial_units()) + r = AltosConvert.distance.inverse(r); + else + r = r * 1000; + return r; } private int bit(CheckBox box, int value) { @@ -210,13 +260,14 @@ public class PreloadMapActivity extends Activity implements AltosLaunchSiteListe double lon = longitude(); int min = min_z(); int max = max_z(); - int r = radius(); + double r = radius(); int t = types(); - AltosDebug.debug("load lat %12.6f lon %12.6f min %d max %d r %d types %x\n", + AltosDebug.debug("PreloadMap load %f %f %d %d %f %d\n", lat, lon, min, max, r, t); loader.load(lat, lon, min, max, r, t); } catch (ParseException e) { + AltosDebug.debug("PreloadMap load raised exception %s", e.toString()); } } @@ -238,11 +289,40 @@ public class PreloadMapActivity extends Activity implements AltosLaunchSiteListe spinner.setSelection(spinner_def); } + + private void add_distance(Spinner spinner, double[] distances_km, double def_km, double[] distances_mi, double def_mi) { + + ArrayAdapter adapter = new ArrayAdapter(this, android.R.layout.simple_spinner_item); + + int spinner_def = 0; + int pos = 0; + + double[] distances; + double def; + if (AltosPreferences.imperial_units()) { + distances = distances_mi; + def = def_mi; + } else { + distances = distances_km; + def = def_km; + } + + for (int i = 0; i < distances.length; i++) { + adapter.add(distances[i]); + if (distances[i] == def) + spinner_def = pos; + pos++; + } + + spinner.setAdapter(adapter); + spinner.setSelection(spinner_def); + } + + + class SiteListListener implements OnItemSelectedListener { public void onItemSelected(AdapterView parent, View view, int pos, long id) { AltosLaunchSite site = (AltosLaunchSite) parent.getItemAtPosition(pos); - AltosDebug.debug("Site selected: %s\n", site.toString()); - latitude.setText(new StringBuffer(String.format("%12.6f", site.latitude))); longitude.setText(new StringBuffer(String.format("%12.6f", site.longitude))); } @@ -253,12 +333,15 @@ public class PreloadMapActivity extends Activity implements AltosLaunchSiteListe } } + double[] radius_mi = { 1, 2, 5, 10, 20 }; + double radius_def_mi = 2; + double[] radius_km = { 1, 2, 5, 10, 20, 30 }; + double radius_def_km = 2; + @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); - AltosDebug.debug("preload map onCreate"); - // Setup the window requestWindowFeature(Window.FEATURE_INDETERMINATE_PROGRESS); setContentView(R.layout.map_preload); @@ -292,14 +375,19 @@ public class PreloadMapActivity extends Activity implements AltosLaunchSiteListe add_numbers(max_zoom, AltosMap.min_zoom - AltosMap.default_zoom, AltosMap.max_zoom - AltosMap.default_zoom, 2); - tile_radius = (Spinner) findViewById(R.id.preload_tile_radius); - add_numbers(tile_radius, 1, 5, 3); + radius_label = (TextView) findViewById(R.id.preload_radius_label); + radius = (Spinner) findViewById(R.id.preload_radius); + if (AltosPreferences.imperial_units()) + radius_label.setText("Radius (miles)"); + else + radius_label.setText("Radius (km)"); + add_distance(radius, radius_km, radius_def_km, radius_mi, radius_def_mi); progress = (ProgressBar) findViewById(R.id.preload_progress); // Initialize array adapters. One for already paired devices and // one for newly discovered devices - Spinner known_sites_spinner = (Spinner) findViewById(R.id.preload_site_list); + known_sites_spinner = (Spinner) findViewById(R.id.preload_site_list); known_sites_adapter = new ArrayAdapter(this, android.R.layout.simple_spinner_item); @@ -312,11 +400,19 @@ public class PreloadMapActivity extends Activity implements AltosLaunchSiteListe loader = new AltosMapLoader(map, this); + // Listen for GPS and Network position updates + LocationManager locationManager = (LocationManager) this.getSystemService(Context.LOCATION_SERVICE); + + locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 1000, 1, this); + new AltosLaunchSites(this); } @Override protected void onDestroy() { super.onDestroy(); + + // Stop listening for location updates + ((LocationManager) getSystemService(Context.LOCATION_SERVICE)).removeUpdates(this); } }