谷歌地图上的路线绘图在android错误java.net.UnknownHostException:maps.googleapis.com

时间:2014-11-08 05:55:48

标签: java android

我正在开发一个Android项目,我想从当前位置绘制一条到特定商店的路线。以下是我的代码:

我调用异步类GetRouteTask调用另一个类。下面的代码如下所示:

public void placemarkersonmap()
    {
        googleMap.setMyLocationEnabled(true);
        googleMap.getUiSettings().setMyLocationButtonEnabled(true);
        googleMap.getUiSettings().setZoomControlsEnabled(true);
        googleMap.getUiSettings().setCompassEnabled(true);
        googleMap.getUiSettings().setAllGesturesEnabled(true);
        googleMap.setTrafficEnabled(true);


        new GetRouteTask().execute();

    }
 private class GetRouteTask extends AsyncTask<String, Void, String> {

         private ProgressDialog Dialog;
         String response = "";
         @Override
         protected void onPreExecute() {
               Dialog = new ProgressDialog(getActivity());
               Dialog.setMessage("Loading route...");
               Dialog.setCancelable(false);
               Dialog.show();
         }

         @Override
         protected String doInBackground(String... urls) {
               //Get All Route values
                     document = v2GetRouteDirection.getDocument(fromPosition, toPosition, GMapV2GetRouteDirection.MODE_DRIVING);
                     if(document!=null){
                      response = "Success";
                     }

                     return response;

         }

         @Override
         protected void onPostExecute(String result) {
               googleMap.clear();
               if(response.equalsIgnoreCase("Success")){
               ArrayList<LatLng> directionPoint = v2GetRouteDirection.getDirection(document);
               PolylineOptions rectLine = new PolylineOptions().width(10).color(
                           Color.RED);

               for (int i = 0; i < directionPoint.size(); i++) {
                     rectLine.add(directionPoint.get(i));
               }
               // Adding route on the map
               googleMap.addPolyline(rectLine);
               markerOptions.position(toPosition).title(job_object.job_shop_name);
               markerOptions.draggable(true);
               googleMap.addMarker(markerOptions);
              googleMap.moveCamera(CameraUpdateFactory.newLatLngZoom(fromPosition, 12f));
            googleMap.animateCamera(CameraUpdateFactory.newLatLngZoom(fromPosition, 12f));

               }

               Dialog.dismiss();
         }
   }

助手类:

package com.igloo.classes;

import java.io.InputStream;
import java.util.ArrayList;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;

import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.protocol.BasicHttpContext;
import org.apache.http.protocol.HttpContext;
import org.w3c.dom.Document;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

import com.google.android.gms.maps.model.LatLng;
import android.util.Log;

public class GMapV2GetRouteDirection {
   public final static String MODE_DRIVING = "driving";
   public final static String MODE_WALKING = "walking";

   public GMapV2GetRouteDirection() { }

   public Document getDocument(LatLng start, LatLng end, String mode) {
       String url = "http://maps.googleapis.com/maps/api/directions/xml?"
               + "origin=" + start.latitude + "," + start.longitude 
               + "&destination=" + end.latitude + "," + end.longitude
               + "&sensor=false&units=metric&mode=driving";

       try {
           HttpClient httpClient = new DefaultHttpClient();
           HttpContext localContext = new BasicHttpContext();
           HttpPost httpPost = new HttpPost(url);
           HttpResponse response = httpClient.execute(httpPost, localContext);
           InputStream in = response.getEntity().getContent();
           DocumentBuilder builder = DocumentBuilderFactory.newInstance().newDocumentBuilder();
           Document doc = builder.parse(in);
           return doc;
       } catch (Exception e) {
           e.printStackTrace();
       }
       return null;
   }

   public String getDurationText (Document doc) {
       NodeList nl1 = doc.getElementsByTagName("duration");
       Node node1 = nl1.item(0);
       NodeList nl2 = node1.getChildNodes();
       Node node2 = nl2.item(getNodeIndex(nl2, "text"));
       Log.i("DurationText", node2.getTextContent());
       return node2.getTextContent();
   }

   public int getDurationValue (Document doc) {
       NodeList nl1 = doc.getElementsByTagName("duration");
       Node node1 = nl1.item(0);
       NodeList nl2 = node1.getChildNodes();
       Node node2 = nl2.item(getNodeIndex(nl2, "value"));
       Log.i("DurationValue", node2.getTextContent());
       return Integer.parseInt(node2.getTextContent());
   }

   public String getDistanceText (Document doc) {
       NodeList nl1 = doc.getElementsByTagName("distance");
       Node node1 = nl1.item(0);
       NodeList nl2 = node1.getChildNodes();
       Node node2 = nl2.item(getNodeIndex(nl2, "text"));
       Log.i("DistanceText", node2.getTextContent());
       return node2.getTextContent();
   }

   public int getDistanceValue (Document doc) {
       NodeList nl1 = doc.getElementsByTagName("distance");
       Node node1 = nl1.item(0);
       NodeList nl2 = node1.getChildNodes();
       Node node2 = nl2.item(getNodeIndex(nl2, "value"));
       Log.i("DistanceValue", node2.getTextContent());
       return Integer.parseInt(node2.getTextContent());
   }

   public String getStartAddress (Document doc) {
       NodeList nl1 = doc.getElementsByTagName("start_address");
       Node node1 = nl1.item(0);
       Log.i("StartAddress", node1.getTextContent());
       return node1.getTextContent();
   }

   public String getEndAddress (Document doc) {
       NodeList nl1 = doc.getElementsByTagName("end_address");
       Node node1 = nl1.item(0);
       Log.i("StartAddress", node1.getTextContent());
       return node1.getTextContent();
   }

   public String getCopyRights (Document doc) {
       NodeList nl1 = doc.getElementsByTagName("copyrights");
       Node node1 = nl1.item(0);
       Log.i("CopyRights", node1.getTextContent());
       return node1.getTextContent();
   }

   public ArrayList<LatLng> getDirection (Document doc) {
       NodeList nl1, nl2, nl3;
       ArrayList<LatLng> listGeopoints = new ArrayList<LatLng>();
       nl1 = doc.getElementsByTagName("step");
       if (nl1.getLength() > 0) {
           for (int i = 0; i < nl1.getLength(); i++) {
               Node node1 = nl1.item(i);
               nl2 = node1.getChildNodes();

               Node locationNode = nl2.item(getNodeIndex(nl2, "start_location"));
               nl3 = locationNode.getChildNodes();
               Node latNode = nl3.item(getNodeIndex(nl3, "lat"));
               double lat = Double.parseDouble(latNode.getTextContent());
               Node lngNode = nl3.item(getNodeIndex(nl3, "lng"));
               double lng = Double.parseDouble(lngNode.getTextContent());
               listGeopoints.add(new LatLng(lat, lng));

               locationNode = nl2.item(getNodeIndex(nl2, "polyline"));
               nl3 = locationNode.getChildNodes();
               latNode = nl3.item(getNodeIndex(nl3, "points"));
               ArrayList<LatLng> arr = decodePoly(latNode.getTextContent());
               for(int j = 0 ; j < arr.size() ; j++) {
                   listGeopoints.add(new LatLng(arr.get(j).latitude, arr.get(j).longitude));
               }

               locationNode = nl2.item(getNodeIndex(nl2, "end_location"));
               nl3 = locationNode.getChildNodes();
               latNode = nl3.item(getNodeIndex(nl3, "lat"));
               lat = Double.parseDouble(latNode.getTextContent());
               lngNode = nl3.item(getNodeIndex(nl3, "lng"));
               lng = Double.parseDouble(lngNode.getTextContent());
               listGeopoints.add(new LatLng(lat, lng));
           }
       }

       return listGeopoints;
   }

   private int getNodeIndex(NodeList nl, String nodename) {
       for(int i = 0 ; i < nl.getLength() ; i++) {
           if(nl.item(i).getNodeName().equals(nodename))
               return i;
       }
       return -1;
   }

   private ArrayList<LatLng> decodePoly(String encoded) {
       ArrayList<LatLng> poly = new ArrayList<LatLng>();
       int index = 0, len = encoded.length();
       int lat = 0, lng = 0;
       while (index < len) {
           int b, shift = 0, result = 0;
           do {
               b = encoded.charAt(index++) - 63;
               result |= (b & 0x1f) << shift;
               shift += 5;
           } while (b >= 0x20);
           int dlat = ((result & 1) != 0 ? ~(result >> 1) : (result >> 1));
           lat += dlat;
           shift = 0;
           result = 0;
           do {
               b = encoded.charAt(index++) - 63;
               result |= (b & 0x1f) << shift;
               shift += 5;
           } while (b >= 0x20);
           int dlng = ((result & 1) != 0 ? ~(result >> 1) : (result >> 1));
           lng += dlng;

           LatLng position = new LatLng((double) lat / 1E5, (double) lng / 1E5);
           poly.add(position);
       }
       return poly;
   }
}

我在较新的设备上工作正常。但在较旧的设备(Android 2.6)上,我遇到以下异常:

11-08 11:14:24.709: W/System.err(4582): java.net.UnknownHostException: maps.googleapis.com
11-08 11:14:24.740: W/System.err(4582):     at java.net.InetAddress.lookupHostByName(InetAddress.java:506)
11-08 11:14:24.740: W/System.err(4582):     at java.net.InetAddress.getAllByNameImpl(InetAddress.java:294)
11-08 11:14:24.748: W/System.err(4582):     at java.net.InetAddress.getAllByName(InetAddress.java:256)
11-08 11:14:24.748: W/System.err(4582):     at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:136)
11-08 11:14:24.748: W/System.err(4582):     at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
11-08 11:14:24.748: W/System.err(4582):     at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
11-08 11:14:24.748: W/System.err(4582):     at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:359)
11-08 11:14:24.748: W/System.err(4582):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
11-08 11:14:24.748: W/System.err(4582):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
11-08 11:14:24.748: W/System.err(4582):     at com.igloo.classes.GMapV2GetRouteDirection.getDocument(GMapV2GetRouteDirection.java:37)
11-08 11:14:24.748: W/System.err(4582):     at com.igloo.fragments.RouteFragment$GetRouteTask.doInBackground(RouteFragment.java:282)
11-08 11:14:24.748: W/System.err(4582):     at com.igloo.fragments.RouteFragment$GetRouteTask.doInBackground(RouteFragment.java:1)
11-08 11:14:24.748: W/System.err(4582):     at android.os.AsyncTask$2.call(AsyncTask.java:185)
11-08 11:14:24.748: W/System.err(4582):     at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:306)
11-08 11:14:24.748: W/System.err(4582):     at java.util.concurrent.FutureTask.run(FutureTask.java:138)
11-08 11:14:24.748: W/System.err(4582):     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1088)
11-08 11:14:24.748: W/System.err(4582):     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:581)
11-08 11:14:24.748: W/System.err(4582):     at java.lang.Thread.run(Thread.java:1019)
11-08 11:15:33.982: W/System.err(4582): java.net.UnknownHostException: maps.googleapis.com
11-08 11:15:33.990: W/System.err(4582):     at java.net.InetAddress.lookupHostByName(InetAddress.java:506)
11-08 11:15:33.990: W/System.err(4582):     at java.net.InetAddress.getAllByNameImpl(InetAddress.java:294)
11-08 11:15:33.998: W/System.err(4582):     at java.net.InetAddress.getAllByName(InetAddress.java:256)
11-08 11:15:33.998: W/System.err(4582):     at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:136)
11-08 11:15:33.998: W/System.err(4582):     at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
11-08 11:15:33.998: W/System.err(4582):     at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
11-08 11:15:33.998: W/System.err(4582):     at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:359)
11-08 11:15:33.998: W/System.err(4582):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
11-08 11:15:33.998: W/System.err(4582):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
11-08 11:15:33.998: W/System.err(4582):     at com.igloo.classes.GMapV2GetRouteDirection.getDocument(GMapV2GetRouteDirection.java:37)
11-08 11:15:33.998: W/System.err(4582):     at com.igloo.fragments.RouteFragment$GetRouteTask.doInBackground(RouteFragment.java:282)
11-08 11:15:33.998: W/System.err(4582):     at com.igloo.fragments.RouteFragment$GetRouteTask.doInBackground(RouteFragment.java:1)
11-08 11:15:33.998: W/System.err(4582):     at android.os.AsyncTask$2.call(AsyncTask.java:185)
11-08 11:15:34.006: W/System.err(4582):     at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:306)
11-08 11:15:34.006: W/System.err(4582):     at java.util.concurrent.FutureTask.run(FutureTask.java:138)
11-08 11:15:34.006: W/System.err(4582):     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1088)
11-08 11:15:34.006: W/System.err(4582):     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:581)
11-08 11:15:34.006: W/System.err(4582):     at java.lang.Thread.run(Thread.java:1019)
11-08 11:15:47.576: W/KeyCharacterMap(4582): No keyboard for id 0
11-08 11:15:47.576: W/KeyCharacterMap(4582): Using default keymap

显示的错误行是这一行:

 HttpResponse response = httpClient.execute(httpPost, localContext);

在辅助类中。

问题是为什么这段代码在某些时候起作用而在其他时候不起作用? 我该如何解决这个问题?

0 个答案:

没有答案