java - 尝试使用 Maps API 查找附近地点时出现 FileNotFoundException

标签 java android google-maps google-places-api

我一直在学习教程,以便使用 Google Maps 和 Places API 创建一个显示附近地点的应用程序。具体来说,我正在尝试查看附近的餐馆或外卖店。事实上,应用程序显示 map fragment ,但没有地方显示为标记。

我尝试增加半径值,并将类型更改为此处列出的一些类型:https://developers.google.com/places/documentation/supported_types ,但我得到了相同的 FileNotFoundException 错误。谁能看出哪里出了问题?

这是我的 LogCat。

03-13 17:21:51.076: E/GooglePlayServicesUtil(13109): The Google Play services resources were not found. Check your project configuration to ensure that the resources are included.
03-13 17:21:51.436: D/dalvikvm(13109): GC_FOR_ALLOC freed 2262K, 24% free 8393K/10920K, paused 65ms, total 83ms
03-13 17:21:51.536: D/dalvikvm(13109): GC_FOR_ALLOC freed 1339K, 23% free 8409K/10920K, paused 21ms, total 23ms
03-13 17:21:51.586: W/ActivityThread(13109): ClassLoader.loadClass: The class loader returned by Thread.getContextClassLoader() may fail for processes that host multiple applications. You should explicitly specify a context class loader. For example: Thread.setContextClassLoader(getClass().getClassLoader());
03-13 17:21:52.137: D/dalvikvm(13109): GC_FOR_ALLOC freed 739K, 19% free 8928K/10920K, paused 31ms, total 32ms
03-13 17:21:52.387: D/dalvikvm(13109): GC_FOR_ALLOC freed 775K, 18% free 9233K/11192K, paused 18ms, total 19ms
03-13 17:21:52.457: W/SystemClock(13109): time going backwards: prev 232776411235435(ioctl) vs now 232776411021793(ioctl), tid=13531
03-13 17:21:53.308: D/dalvikvm(13109): GC_FOR_ALLOC freed 1516K, 19% free 9496K/11604K, paused 21ms, total 21ms
03-13 17:21:53.619: D/Exception while downloading url(13109): java.io.FileNotFoundException: https://maps.googleapis.com/maps/api/place/nearbysearch/json??types=meal_takeawaylocation=55.94395494, -3.12815476&radius=10000&sensor=true&key=[My API Key]
03-13 17:21:53.629: D/Background Task(13109): java.lang.NullPointerException
03-13 17:21:53.659: D/Exception(13109): java.lang.NullPointerException

这是我的代码:

public class GPSActivity extends FragmentActivity implements LocationListener{

GoogleMap mGoogleMap;
String[] mPlaceType=null;
String[] mPlaceTypeName=null;

double mLatitude=0;
double mLongitude=0;

protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_gps);

    mPlaceType = getResources().getStringArray(R.array.place_type);
    mPlaceTypeName = getResources().getStringArray(R.array.place_type_name);

    int status = GooglePlayServicesUtil.isGooglePlayServicesAvailable(getBaseContext());
    if(status!=ConnectionResult.SUCCESS) {
        int requestCode = 10;
        Dialog dialog = GooglePlayServicesUtil.getErrorDialog(status, this, requestCode);
        dialog.show();
    } else {
        SupportMapFragment fragment = (SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map);
        mGoogleMap = fragment.getMap();
        mGoogleMap.setMyLocationEnabled(true);
        LocationManager locationManager = (LocationManager) getSystemService(LOCATION_SERVICE);
        Criteria criteria = new Criteria();
        String provider = locationManager.getBestProvider(criteria, true);
        Location location = locationManager.getLastKnownLocation(provider);

        if (location!=null) {
            onLocationChanged(location);
        }

        locationManager.requestLocationUpdates(provider, 20000, 0, this);

        String type = mPlaceType[0];

        StringBuilder sb = new StringBuilder("https://maps.googleapis.com/maps/api/place/nearbysearch/json?");
        sb.append("?types=meal_takeaway");
        sb.append("location="+mLatitude+", "+mLongitude);
        sb.append("&radius=10000");
        sb.append("&sensor=true");
        sb.append("&key=[My API Key]");

        PlacesTask placesTask = new PlacesTask();
        placesTask.execute(sb.toString());
    }
}

public void onLocationChanged(Location location) {
    mLatitude = location.getLatitude();
    mLongitude = location.getLongitude();
    LatLng latLng = new LatLng(mLatitude, mLongitude);
    mGoogleMap.moveCamera(CameraUpdateFactory.newLatLng(latLng));
    mGoogleMap.animateCamera(CameraUpdateFactory.zoomTo(12));
}

protected void onPostExecute(List<HashMap<String,String>> list) {
    mGoogleMap.clear();
    for (int i=0; i<list.size(); i++) {
        MarkerOptions markerOptions = new MarkerOptions();
        HashMap<String,String> hmPlace = list.get(i);
        double lat = Double.parseDouble(hmPlace.get("lat"));
        double lng = Double.parseDouble(hmPlace.get("lng"));
        String name = hmPlace.get("meal_takeaway");
        String vicinity = hmPlace.get("vicinity");
        LatLng latLng = new LatLng(lat, lng);
        markerOptions.title(name+" : "+vicinity);
        mGoogleMap.addMarker(markerOptions);
    }
}

@Override
public void onProviderDisabled(String provider) {
    // TODO Auto-generated method stub

}

@Override
public void onProviderEnabled(String provider) {
    // TODO Auto-generated method stub

}

@Override
public void onStatusChanged(String provider, int status, Bundle extras) {
    // TODO Auto-generated method stub

}
}


class PlacesTask extends AsyncTask<String,Integer,String> {
String data = null;

private String downloadUrl(String strUrl) throws IOException {
    String data = "";
    InputStream iStream = null;
    HttpURLConnection urlConnection = null;
    try {
        URL url = new URL(strUrl);
        urlConnection = (HttpURLConnection) url.openConnection();
        urlConnection.connect();
        iStream = urlConnection.getInputStream();
        BufferedReader br = new BufferedReader(new InputStreamReader(iStream));
        StringBuffer sb = new StringBuffer();
        String line = "";
        while ( ( line = br.readLine()) !=null) {
            sb.append(line);
        }
        data = sb.toString();
        br.close();
    } catch (Exception e) {
        Log.d("Exception while downloading url", e.toString());
    } finally {
        iStream.close();
        urlConnection.disconnect();
    }
    return data;
}

protected String doInBackground(String... url) {
    try {
        data = downloadUrl(url[0]);
    } catch(Exception e) {
        Log.d("Background Task", e.toString());
    }
    return data;
}

protected void onPostExecute(String result) {
    ParserTask parserTask = new ParserTask();
    parserTask.execute(result);
}
}

谢谢,如果有任何帮助,我将不胜感激。

编辑:异常现在消失了,但标记仍然没有显示在 map 上。

最佳答案

看起来您的网址生成器已损坏。你有:

StringBuilder sb = new StringBuilder("https://maps.googleapis.com/maps/api/place/nearbysearch/json?");
        sb.append("?types=meal_takeaway");
        sb.append("location="+mLatitude+", "+mLongitude);
        sb.append("&radius=10000");
        sb.append("&sensor=true");
        sb.append("&key=[My API Key]");

这意味着您在 jsontypes 之间有两个 ?,而没有 &types=meal_takeawaylocation 之间。像这样修复它:

StringBuilder sb = new StringBuilder("https://maps.googleapis.com/maps/api/place/nearbysearch/json?");
        sb.append("types=meal_takeaway");
        sb.append("&location="+mLatitude+","+mLongitude);
        sb.append("&radius=10000");
        sb.append("&sensor=true");
        sb.append("&key=[My API Key]");

(注意:仅在前两个 sb.append() 调用中发生变化——还删除了空格)

FWIW,从长远来看,对于 JSON 请求使用 Volley 或类似的东西可能会更容易,而不是下载 url 并单独解析它。

关于java - 尝试使用 Maps API 查找附近地点时出现 FileNotFoundException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22386497/

相关文章:

java - Java 的 Vector 和 JTable 的问题

javascript - 从 google maps api json 获取 formatted_address

javascript - 如何在 Android 上为谷歌地图使用 RouteBoxer.js

java - 通过 url 点击在注销表单中调用 ${_csrf.parameterName} 和 ${_csrf.token}

java - 无法从 Eclipse 运行 Hadoop,说 Eclipse 中的 Hadoop 位置(错误 :NULL)

java - 为什么 Map 函数在嵌套流中不起作用

android - android paypal库需要的账号信息

android - Gallery 如何在 getView 中使用 AnimationDrawable

android - 如何在 flutter android 插件包中处理 android 生命周期

Python - 根据(谷歌) map 上的坐标获取度数和米数之间的比率