如何计算地图中不同标记的距离,然后选择至少一个

Aks*_*hat 10 gps android location google-maps

我必须从地图上的不同标记到设备的当前位置,并获得最短的标记.我有lat和long标记,当前位置lat和long可以动态获取.

假设我在地图上有5个标记,Bangalore(Lat:12.971599,Long:77.594563),Delhi(Lat:28.635308,Long:77.224960),Mumbai(Lat:19.075984,Long:72.877656),Chennai(Lat:13.052414,Long: 80.250825),Kolkata(Lat:22.572646,Long:88.363895).

现在假设用户站在海德拉巴附近(Lat:17.385044,Long:78.486671).当用户点击按钮时,应用程序应该计算每个标记的距离并选择并返回最短的标记,这将是班加罗尔.

有一种方法可以在本地数据库的帮助下完成.请有人帮忙吗?

任何人都可以建议我这样做的好方法,或者如果你愿意,可以提出一个好的代码.Thanx提前.

Aks*_*hat 1

在这里,我找到了一种使用数据库来做到这一点的方法。这是一个计算距离函数:

public void calculateDistance() {

  if (latitude != 0.0 && longitude != 0.0) {
    for(int i=0;i<97;i++) { 
      Location myTargetLocation=new Location("");
      myTargetLocation.setLatitude(targetLatitude[i]);
      myTargetLocation.setLongitude(targetLongitude[i]);
      distance[i]=myCurrentLocation.distanceTo(myTargetLocation);
      distance[i]=distance[i]/1000;
      mdb.insertDetails(name[i],targetLatitude[i], targetLongitude[i], distance[i]);
    }

    Cursor c1= mdb.getallDetail();
    while (c1.moveToNext()) {
      String station_name=c1.getString(1);
      double latitude=c1.getDouble(2);
      double longitude=c1.getDouble(3);
      double dis=c1.getDouble(4);
      //Toast.makeText(getApplicationContext(),station_name+" & "+latitude+" &  "+longitude+" &  "+dis,1).show();
    }
    Arrays.sort(distance);
    double nearest_distance=distance[0];
    Cursor c2=mdb.getNearestStationName();
    {
        while (c2.moveToNext()) {

            double min_dis=c2.getDouble(4);
            if(min_dis==nearest_distance)
            {
                String nearest_stationName=c2.getString(1);
                if(btn_clicked.equals("source"))
                {
                source.setText(nearest_stationName);
                break;
                }
                else if(btn_clicked.equals("dest"))
                {
                    destination.setText(nearest_stationName);
                    break;
                }
                else
                {

                }
            }
        }
    }
     }
     else
     {
         Toast.makeText(this, "GPS is Not Working Properly,, please check Gps and  Wait for few second", 1).show(); 
     }
}
Run Code Online (Sandbox Code Playgroud)

我们所要做的就是创建一个名为 targetLatitude[i] 和 targetLongitude[i] 的数组,其中包含要计算距离的所有地点的纬度和经度。然后创建数据库如下图:

public class MyDataBase {
    SQLiteDatabase sdb;
    MyHelper mh;
    MyDataBase(Context con)
    {
    mh = new MyHelper(con, "Metro",null, 1);
    }

public void open() {
try
{
sdb=mh.getWritableDatabase();
}
catch(Exception e)
{

}


}

public void insertDetails(String name,double latitude,double longitude,double distance) {

ContentValues cv=new ContentValues();
cv.put("name", name);
cv.put("latitude", latitude);
cv.put("longitude",longitude);
cv.put("distance", distance);
sdb.insert("stations", null, cv);
}

public void insertStops(String stop,double latitude,double logitude)
{
    ContentValues cv=new ContentValues();
    cv.put("stop", stop);
    cv.put("latitude", latitude);
    cv.put("logitude", logitude);
    sdb.insert("stops", null, cv);

}



public Cursor getallDetail()
{   
    Cursor c=sdb.query("stations",null,null,null,null,null,null);
    return c;
}
public Cursor getNearestStationName() {
    Cursor c=sdb.query("stations",null,null,null,null,null,null);
    return c;
}


public Cursor getStops(String stop)
{
    Cursor c;
    c=sdb.query("stops",null,"stop=?",new String[]{stop},null, null, null);
    return c;
}

class MyHelper extends SQLiteOpenHelper
{

    public MyHelper(Context context, String name, CursorFactory factory,
            int version) {
        super(context, name, factory, version);
        // TODO Auto-generated constructor stub
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        // TODO Auto-generated method stub
        db.execSQL("Create table stations(_id integer primary key,name text," +
                " latitude double, longitude double, distance double );");
        db.execSQL("Create table stops(_id integer primary key,stop text," +
                "latitude double,logitude double);");

    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        // TODO Auto-generated method stub

    }

}
public void deleteDetail() {
    sdb.delete("stations",null,null);
    sdb.delete("stops",null,null);

}

public void close() {
    sdb.close();

}

}
Run Code Online (Sandbox Code Playgroud)

然后在任何你想要的地方执行CalculateDistance函数,你就可以获得最近的车站名称。