I have some location coordinates stored in my SQLite database table. I want to retrieve the locations within 1 km range from the use\'s current location. Right
Here is some code which should give you an idea how to get it working:
public static double[] getNeighbourhoodArea(
final double lat, final double lng, final int distInMtrs) {
double[] area = new double[4];
final double latRadian = Math.toRadians(lat);
final double degLatKm = 110.574235;
final double degLngKm = 110.572833 * Math.cos(latRadian);
final double deltaLat = distInMtrs / 1000.0 / degLatKm;
final double deltaLong = distInMtrs / 1000.0 / degLngKm;
final double minLat = lat - deltaLat;
final double minLng = lng - deltaLong;
final double maxLat = lat + deltaLat;
final double maxLng = lng + deltaLong;
area[0] = minLat;
area[1] = minLng;
area[2] = maxLat;
area[3] = maxLng;
return area;
}
/**
* search POIs in the neighbourhood
*/
private PntInrtst collectPOIs(double lat, double lng) {
if (mDb == null) return Const.NULL_POI;
Cursor cursorStat = mDb.getPoisInArea(lat, lng, Const.SIDE_LENGTH_GEO_OFFSET);
double area[] = Logic.getProtectionArea(lat, lng, Const.SIDE_LENGTH_GEO_OFFSET);
ArrayList poiArray = new ArrayList();
PntInrtst poi = Const.NULL_POI;
if (cursorStat.moveToFirst()) {
for (int i = 0; i < cursorStat.getCount(); i++) {
double potLat = cursorStat.getFloat(Const.COL_LA);
double potLng = cursorStat.getFloat(Const.COL_LO);
if ((potLat < area[Const.MAX_LAT] && potLat > area[Const.MIN_LAT])
&& (potLng < area[Const.MAX_LNG] && potLng > area[Const.MIN_LNG])) {
poi = Logic.getPoiByCursor(getApplicationContext(), cursorStat);
poiArray.add(poi);
}
cursorStat.moveToNext();
} // End "Cursor"
}
cursorStat.close();
// more than once, fire the nearest
if (poiArray.size() > 1) return closest(poiArray, lat, lng);
else return poi; // one or null
}
/**
* filter POIs which won't be useful (avoids flooding the cache)
*/
public Cursor getPoisInArea(double latitude, double longitude, int range) {
double area[] = getNeighbourhoodArea(latitude, longitude, range);
String where = "la" + "<" + area[MAX_LAT] +
" AND " + "la" + ">" + area[MIN_LAT] +
" AND " + "lo" + "<" + area[MAX_LNG] +
" AND " + "lo" + ">" + area[MIN_LNG];
SQLiteDatabase db = mDbHelper.getReadableDatabase();
return db.query(Const.POI_DB_TABLE, null, where, null, null, null, null);
}