根据用户移动 android googleMaps v2 更新折线

Posted

技术标签:

【中文标题】根据用户移动 android googleMaps v2 更新折线【英文标题】:update polyline according to the user moving android googleMaps v2 【发布时间】:2013-06-06 22:58:44 【问题描述】:

我有带有折线的 googleMap (v2),它显示了用户当前位置和目的地点之间的路线。 现在,我想根据用户的移动来更新折线。 当位置改变但多段线闪烁时,我试图重绘整个多段线。 我在 PolylineOptions 类中没有找到任何合适的函数(函数 add() 只是添加一个顶点,而不是更新或删除) 你知道如何更新折线吗??? 感谢您抽出宝贵的时间。

【问题讨论】:

你好你能告诉我它是如何工作的,我仍然无法理解我想删除折线部分,因为我移动到目标点 【参考方案1】:

3.1.36 版本的唯一方法:

List<LatLng> points = polyline.getPoints();
points.add(newPoint);
polyline.setPoints(points);

希望 API 会在以后的版本中得到增强。

【讨论】:

但是如果我从数组中删除点然后调用 setPoints——折线视图会自动更新吗? 感谢您的精彩回答。 非常好。但我不会一直为polyline.getPoints(); 创建一个新的List。我认为拥有一个存储所有points 的列表,在需要时更新List 并在polyline.setPoints() 中使用它是一个好习惯。这是因为当您有一个庞大的列表时,垃圾收集器必须清理该 List 的新实例,因为应用程序不会使用它。 但它在我当前的位置和目的地之间画了一条直线......但我需要明智地更新折线......请帮我先生 它在新位置添加新线,我们如何删除旧线并使用新位置更新折线?【参考方案2】:

*我已经完成了更新折线路径而不删除折线的工作。我们可以通过改变该折线的点来做到这一点。检查下面的代码。

这是给折线设置新点的逻辑。

/*Here the routes contain the points(latitude and longitude)*/
for (int i = 0; i < routes.size(); i++) 
            Route route = routes.get(i);
            if(polyline_path != null)
                polyline_path.setPoints(route.points);
            
        

详细说明:

private GoogleMap map_object;
private Marker marker_driver;
private Marker marker_drop_off;
private Polyline polyline_path;
private PolylineOptions polylineOptions_path;

...
...
...

/*HelperDirectionFinder is a class that I create to call google API and I used this 
  class to get directions routes*/

/*I have created Service, and I'm calling this lines below after 5 sec. to get the 
  updated routes from google API.*/

HelperDirectionFinder directionFinder = new HelperDirectionFinder(
            JobEndScreen.this, source, destinations);
    try 
        directionFinder.showDirection();
     catch (UnsupportedEncodingException e) 
        HelperProgressDialog.closeDialog();
    

...
...
...

@Override
public void onDirectionFinderStart() 
    if(polylineOptions_path == null)
        HelperProgressDialog.showDialog(getActivity(), "", getString(R.string.text_loading));
    



/*This interface method is called after getting routes from google API.*/
/*Here the routes contains the list of path or routes returned by Google Api*/
@Override
public void onDirectionFinderSuccess(List<Route> routes) 
    HelperProgressDialog.closeDialog();


    /*When polylineOptions_path is null it means the polyline is not drawn.*/
    /*If the polylineOptions_path is not null it means the polyline is drawn on map*/
    if(polylineOptions_path == null)
        for (Route route : routes) 
            polylineOptions_path = new PolylineOptions().
                    geodesic(true).
                    color(ContextCompat.getColor(getActivity(), R.color.color_bg_gray_dark)).
                    width(10);

            for (int i = 0; i < route.points.size(); i++)
                polylineOptions_path.add(route.points.get(i));

            polyline_path = map_object.addPolyline(polylineOptions_path);
        
    
    else 
        for (int i = 0; i < routes.size(); i++) 
            Route route = routes.get(i);
            if(polyline_path != null)
                polyline_path.setPoints(route.points);
            
        
    

【讨论】:

【参考方案3】:
//Declare on global
PolylineOptions polyOptions, polyOptions2;
Polyline polyline2;
List<LatLng> ltln;
private Double lat_decimal = 0.0,lng_decimal=0.0;



//initialize
ltln = new ArrayList<>();

//如果你使用路由库

compile 'com.github.jd-alexander:library:1.0.7'

 @Override
    public void onRoutingSuccess(ArrayList<Route> arrayList, int i) 

    //Add this code snippet on onRoutingSuccess  to store latlan list
        ltln = new ArrayList<>();
        System.out.println("-----arrayList------" + arrayList.get(0).getPoints());
        ltln = arrayList.get(0).getPoints();



        //  NOTE here already we draw polyLine 1

       


 //below mentioned how to update polyline

   private void UpdatePoliline()
    System.out.println("-------runnablePolyline-------"+ltln.size());
    try 
        if (ltln.size() > 0) 
            for (int i = 0; i < ltln.size(); i++) 
                ltln.remove(i);
                if (CalculationByDistance(ltln.get(i), new LatLng(lat_decimal, lng_decimal)) >= 10) 
                    break;
                

            
            polyOptions2 = new PolylineOptions();
            polyOptions2.color(getResources().getColor(R.color.app_color));
            polyOptions2.width(7);
            polyOptions2.addAll(ltln);


            if (polyline2 == null) 
                polyline2 = googleMap.addPolyline(polyOptions2);
                if (polyLines.size() > 0) 
                    for (Polyline poly : polyLines) 
                        poly.remove();
                    
                
                polyLines.add(polyline2);
                if (polyline != null) 
                    polyline.remove();
                    polyline = null;
                
             else 
                polyline = googleMap.addPolyline(polyOptions2);
                if (polyLines.size() > 0) 
                    for (Polyline poly : polyLines) 
                        poly.remove();
                    
                
                polyLines.add(polyline);
                if (polyline2 != null) 
                    polyline2.remove();
                    polyline2 = null;
                
            
            System.out.println("=====waypoints new===" + ltln);
        
     catch (IndexOutOfBoundsException e) 
        e.printStackTrace();
    

// 计算两点之间的距离

 public float CalculationByDistance(LatLng StartP, LatLng EndP) 


    Location locationA = new Location("Source");
    locationA.setLatitude(StartP.latitude);
    locationA.setLongitude(StartP.longitude);

    Location locationB = new Location("Destination");
    locationB.setLatitude(EndP.latitude);
    locationB.setLongitude(EndP.longitude);



    float distance = locationA.distanceTo(locationB);


    return distance;

//重绘折线车辆不在当前折线的特定距离内

    if (ltln.size() > 0) 

        if (PolyUtil.isLocationOnPath(new LatLng(currentlat, currentLon), ltln, false, 60.0f) )
            System.out.println("===tolarance===" + true);
         else 
           //Redraw Polyline
        
    

   UpdatePoliline();

【讨论】:

以上是关于根据用户移动 android googleMaps v2 更新折线的主要内容,如果未能解决你的问题,请参考以下文章

Android使用GoogleMap实现定位及定位回正

如何使用 Android Studio 将信息窗口放置在 GoogleMaps 中标记的左侧或右侧

相机动画和用户相机移动的区别

Android在GoogleMap(百度地图)实现自定义指南针旋转与回正功能

Android在GoogleMap(百度地图)实现自定义指南针旋转与回正功能

Android在GoogleMap(百度地图)实现自定义指南针旋转与回正功能