我想知道如何在当前位置创建一个半径,范围为 800 米。还有我如何检查我从数据库中获取的标记是否在我的圈子内。
我找到了这个关于如何在stackoverflow上添加半径的代码片段。
//radius in meters
Circle circle = mMap.addCircle(new CircleOptions().center(new LatLng(latitude, longitude)).radius(800).strokeColor(Color.RED));
circle.setVisible(true);
对于我关于如何检查从数据库中获取的标记是否在半径范围内的问题,我使用
位置.距离之间((谷歌地图 |计算 2 个位置之间的距离(安卓教程(
然后我添加了一个 if 语句
if (result[0] >= 450 && result[0] <= 800) {
Toast.makeText(this, "distance: "+ result[0] + "nBus is inside radius", Toast.LENGTH_SHORT).show();
}
对于这样的任务,我有一个静态辅助类。这是我用来创建圆的代码:
public static CircleOptions setMapCircleMeters(LatLng latLng, float meters){
CircleOptions options = null;
try {
options = new CircleOptions();
options.center(latLng);
options.radius(meters);
options.fillColor(Color.argb(70, 80, 80, 80));
options.strokeWidth(2.0f);
}
catch (Exception ex){
Log.e(TAG, " CircleOptions --- " + ex.getMessage());
}
return options;
}
您可以轻松更改fillColor
或strokeWidth
的属性以满足您的需求。
现在,要确定某个位置是否在您要检查的距离内,请执行以下操作:
public static boolean isInRangeMeters(LatLng pt1, LatLng pt2, double meters){
boolean inRange = false;
try{
double distance = getDistanceMeters(pt1, pt2);
inRange = (distance <= meters);
}
catch (Exception ex){
Log.e("ERROR", ex.getMessage());
}
return inRange;
}
public static double getDistanceMeters(LatLng pt1, LatLng pt2){
double distance = 0d;
try{
double theta = pt1.longitude - pt2.longitude;
double dist = Math.sin(Math.toRadians(pt1.latitude)) * Math.sin(Math.toRadians(pt2.latitude))
+ Math.cos(Math.toRadians(pt1.latitude)) * Math.cos(Math.toRadians(pt2.latitude))
* Math.cos(Math.toRadians(theta));
dist = Math.acos(dist);
dist = Math.toDegrees(dist);
distance = dist * 60 * 1853.1596;
}
catch (Exception ex){
Log.e("ERROR", ex.getMessage());
}
return distance;
}