如何防止Polyline在谷歌地图android重叠?

时间:2017-06-26 10:13:21

标签: android google-maps google-polyline

大家好,这可能是一个愚蠢的问题,但到目前为止,我正在努力寻找任何解决方案。现在让我怀疑我是否使用多条折线绘制多条路线,每条折线都有不同的颜色但是当两条点相交时,最后一条折线会被覆盖如何防止它。它必须看起来只有第一条路线应该得到一种颜色,所有其他路线必须有相同的颜色怎么做这个让我发布我到目前为止尝试的代码:

  public class GetDistance extends AsyncTask<Double, Void, String> {
            private ProgressDialog pd;
            private static final int READ_TIMEOUT = 6000;
            private static final int CONNECTION_TIMEOUT = 6000;
            private int flag;
            public GetDistance(int flag) {
                this.flag=flag;
            }

            @Override
            protected void onPreExecute() {
                super.onPreExecute();
                pd = new ProgressDialog(VisitTravel.this);
                pd.setMessage("Please wait");
                pd.show();
            }



            @Override
            protected String doInBackground(Double... strings) {
                URL url;
                try {
                    url = new URL("http://maps.googleapis.com/maps/api/directions/json?origin=" + strings[0] + "," + strings[1] + "&destination=" + strings[2] + "," + strings[3] + "&sensor=false&units=metric&mode=driving&alternatives=true");

                    HttpURLConnection conn;
                    conn = (HttpURLConnection) url.openConnection();
                    conn.setReadTimeout(READ_TIMEOUT);
                    conn.setConnectTimeout(CONNECTION_TIMEOUT);


                    conn.setRequestMethod("POST");

                    InputStream in;

                    in = new BufferedInputStream(conn.getInputStream());

                    StringBuilder buffer = new StringBuilder();
                    BufferedReader reader;
                    reader = new BufferedReader(new InputStreamReader(in));
                    String inputLine;
                    while ((inputLine = reader.readLine()) != null)
                        buffer.append(inputLine).append("\n");
                    if (buffer.length() == 0) {
                        // Stream was empty. No point in parsing.
                        Log.e("empty", "empty");
                    }
                    JsonResponse = buffer.toString();
                    Log.d("response", JsonResponse);


                } catch (IOException e1) {
                    e1.printStackTrace();
                }


                return JsonResponse;
            }
            @Override
            protected void onPostExecute(String result) {
                super.onPostExecute(result);
                pd.dismiss();
                if(flag==1) {
                    new ParserTask().execute(result);
                }}

        }
       private class ParserTask extends AsyncTask<String, Integer, List<List<HashMap<String, String>>>> {
            private ArrayList<LatLng> points;

            @Override
            protected List<List<HashMap<String, String>>> doInBackground(String... jsonData) {

                JSONObject jObject;
                List<List<HashMap<String, String>>> routes = null;

                try {
                    jObject = new JSONObject(jsonData[0]);
                    DirectionJSONParser parser = new DirectionJSONParser();

                    // Starts parsing data
                    routes = parser.parse(jObject);
                } catch (Exception e) {
                    e.printStackTrace();
                }
                return routes;
            }

            @Override
            protected void onPostExecute(List<List<HashMap<String, String>>> result) {
                PolylineOptions polylineOptionss=null;
                //      MarkerOptions markerOptions = new MarkerOptions();
                 // Traversing through all the routes
                for (int i = 0; i < result.size(); i++) {
                    points = new ArrayList<>();


                    // Fetching i-th route
                    List<HashMap<String, String>> path = result.get(i);

                    // Fetching all the points in i-th route
                    for (int j = 0; j < path.size(); j++) {
                        HashMap<String, String> point = path.get(j);

                    if (j == 0) {
                          duration = point.get("duration");
                           Log.d("duration", duration);
                           continue;
                      }
                        double lat = Double.parseDouble(point.get("lat"));
                        double lng = Double.parseDouble(point.get("lng"));
                        LatLng position = new LatLng(lat, lng);

                        points.add(position);

                    }
                     polylineOptionss=new PolylineOptions();
                    // Adding all the points in the route to LineOptions
                    polylineOptionss.addAll(points);
                  //  polylineOptions.width(7);
               //     Random rnd = new Random();
                 //   int color = Color.argb(255, rnd.nextInt(256), rnd.nextInt(256), rnd.nextInt(256));
                    if(i==0) {
                          polylineOptions0=new PolylineOptions();
                        polylineOptions0.addAll(points);
                     //   mGoogleMap.setTrafficEnabled(true);
                        polylineOptions0.width(15);
                           polylineOptions0.color(Color.parseColor("#9c27b0"));
                        polylineOptions0.geodesic(true);
                      Polyline polyline=  mGoogleMap.addPolyline(polylineOptions0);
                        polyline.setTag(duration);
                        polyline.setClickable(true);

                    }
//Here only differentiating each and every route.
                    else if(i==1){
                          polylineOptions1=new PolylineOptions();
                        polylineOptions1.addAll(points);
                        polylineOptions1.geodesic(true);
                        polylineOptions1.width(15);
                     //   mGoogleMap.setTrafficEnabled(true);
                        polylineOptions1.color(Color.parseColor("#9e9e9e"));
                        Polyline polyline=  mGoogleMap.addPolyline(polylineOptions1);
                        polyline.setTag(duration);
                        polyline.setClickable(true);

                    ///
                    }
                    else if(i==2){
                            polylineOptions2=new PolylineOptions();
                        polylineOptions2.addAll(points);
                        polylineOptions2.geodesic(true);
                        polylineOptions2.width(15);
                        polylineOptions2.color(Color.parseColor("#9c27b0"));
                        Polyline polyline=  mGoogleMap.addPolyline(polylineOptions2);
                        polyline.setTag(duration);
                        polyline.setClickable(true);
                        //     mGoogleMap.setTrafficEnabled(true);
                   //
                    }
                    else {
                          polylineOptions3=new PolylineOptions();
                        polylineOptions3.addAll(points);
                  //      mGoogleMap.setTrafficEnabled(true);
                        polylineOptions3.width(15);
                        polylineOptions3.geodesic(true);
                        polylineOptions3.color(Color.parseColor("#9e9e9e"));
                        Polyline polyline=  mGoogleMap.addPolyline(polylineOptions3);
                        polyline.setTag(duration);
                        polyline.setClickable(true);
                        ///     polylineOptions3.color(Color.parseColor("#ffffff"));
                    }

                }
                setBottomSheet(jsonresponse, edt.getText().toString(),1);
                CameraAnimation(polylineOptionss);
              //  mGoogleMap.addPolyline(polylineOptions);
                // Drawing polyline in the Google Map for the i-th route



            }
        }

如何从头到尾绘制一种颜色的第一条路线,然后使用其他颜色绘制其余路线。在此先感谢!!

2 个答案:

答案 0 :(得分:1)

使用Polyline的Z-Index变量并使用Polylineclick侦听器更改折线的z-index。意味着每当您单击任何行时,其z-index都会增加,而其他行z-index将减小,因此您单击的行将始终覆盖其他行。请参阅随附的代码以获取帮助。

Z索引 相对于其他叠加层(包括GroundOverlays,TileOverlays,Circles和Polygons但不包括Markers)绘制此tile叠加层的顺序。具有较大z索引的覆盖层会绘制在具有较小z索引的覆盖层上。具有相同z-index的叠加顺序是任意的。默认的zIndex为0。

            final List<Polyline> polylines = new ArrayList<>();

            for(int i= 0; i<paths.size(); i++ ){
                polylines.add(mMap.addPolyline(paths.get(i)));
            }

            mMap.setOnPolylineClickListener(new GoogleMap.OnPolylineClickListener() {
                @Override
                public void onPolylineClick(Polyline polyline) {



                    for(int i= 0; i<polylines.size(); i++ ){

                        polylines.get(i).setColor(Color.argb(255,187,189,191));
                        polylines.get(i).setZIndex(0);
                    }


                    polyline.setColor(Color.argb(255,102,157,246));
                    polyline.setZIndex(2);



                }
            });

答案 1 :(得分:0)

一种可能的解决方案可能是改变折线重叠部分的strokeWidth,使得绘制的第一个更宽,因此仍然可以在后续的情况下看到。只是一个想法,没有经过测试。