Я выполнил все решения, которые я могу выполнить. Я включил API, связанные с моим проектом, и сделал ключи API (браузер, андроид) медленно, и, конечно, но никто не работает. Согласно this, мой ключ API неверен или отсутствует. Есть ли способ проверить, изменяется ли значение в моем манифесте или получает значение null при запуске моего проекта?INVALID API KEY android Google Адреса
ответ
Я решил проблему, используя код, который я нашел из учебников. надейтесь на эту помощь для людей, имеющих такую же проблему.
Я сделал PlaceAPI класс
public class PlaceAPI{
private static final String TAG = PlaceAPI.class.getSimpleName();
private static final String PLACES_API_BASE = "https://maps.googleapis.com/maps/api/place";
private static final String TYPE_AUTOCOMPLETE = "/autocomplete";
private static final String OUT_JSON = "/json";
private static final String API_KEY = "key here";
public ArrayList<String> autocomplete (String input) {
ArrayList<String> resultList = null;
ArrayList<String> resultListid = null;
HttpURLConnection conn = null;
StringBuilder jsonResults = new StringBuilder();
try {
StringBuilder sb = new StringBuilder(PLACES_API_BASE + TYPE_AUTOCOMPLETE + OUT_JSON);
sb.append("?key=" + API_KEY.trim());
sb.append("&input=" + URLEncoder.encode(input, "utf8"));
URL url = new URL(sb.toString());
conn = (HttpURLConnection) url.openConnection();
InputStreamReader in = new InputStreamReader(conn.getInputStream());
// Load the results into a StringBuilder
int read;
char[] buff = new char[1024];
while ((read = in.read(buff)) != -1) {
jsonResults.append(buff, 0, read);
}
} catch (MalformedURLException e) {
Log.e(TAG, "Error processing Places API URL", e);
return resultList;
} catch (IOException e) {
Log.e(TAG, "Error connecting to Places API", e);
return resultList;
} finally {
if (conn != null) {
conn.disconnect();
}
}
try {
// Log.d(TAG, jsonResults.toString());
// Create a JSON object hierarchy from the results
JSONObject jsonObj = new JSONObject(jsonResults.toString());
JSONArray predsJsonArray = jsonObj.getJSONArray("predictions");//result
// Extract the Place descriptions from the results
resultList = new ArrayList<String>(predsJsonArray.length());
for (int i = 0; i < predsJsonArray.length(); i++) {
resultList.add(predsJsonArray.getJSONObject(i).getString("description"));//geometry
}
} catch (JSONException e) {
Log.e(TAG, "Cannot process JSON results", e);
}
//GET PLACEID
try {
// Create a JSON object hierarchy from the results
JSONObject jsonObjid = new JSONObject(jsonResults.toString());
JSONArray predsJsonArrayid = jsonObjid.getJSONArray("predictions");
// Extract the Place descriptions from the results
resultListid = new ArrayList<String>(predsJsonArrayid.length());
for (int i = 0; i < predsJsonArrayid.length(); i++) {
resultListid.add(predsJsonArrayid.getJSONObject(i).getString("id"));
}
} catch (JSONException e) {
Log.e(TAG, "Cannot process JSON results", e);
}
return resultList;
}
}
и сделал адаптер PlacesAutoCompleteAdapter
class PlacesAutoCompleteAdapter extends ArrayAdapter<String> implements Filterable {
ArrayList<String> resultList;
Context mContext;
int mResource;
PlaceAPI mPlaceAPI = new PlaceAPI();
public PlacesAutoCompleteAdapter(Context context, int resource) {
super(context, resource);
mContext = context;
mResource = resource;
}
@Override
public int getCount() {
// Last item will be the footer
return resultList.size();
}
@Override
public String getItem(int position) {
return resultList.get(position);
}
@Override
public Filter getFilter() {
Filter filter = new Filter() {
@Override
protected FilterResults performFiltering(CharSequence constraint) {
FilterResults filterResults = new FilterResults();
if (constraint != null) {
resultList = mPlaceAPI.autocomplete(constraint.toString());
filterResults.values = resultList;
filterResults.count = resultList.size();
}
return filterResults;
}
@Override
protected void publishResults(CharSequence constraint, FilterResults results) {
if (results != null && results.count > 0) {
notifyDataSetChanged();
}
else {
notifyDataSetInvalidated();
}
}
};
return filter;
}
}
затем с помощью адаптера автозаполнения:
autocomplete = (AutoCompleteTextView) findViewById(R.id.autocomplete);
autocomplete.setAdapter(new PlacesAutoCompleteAdapter(this, R.layout.autocomplete_list_item));
autocomplete.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
// Get data associated with the specified position
// in the list (AdapterView)
place = (String) parent.getItemAtPosition(position);
//Toast.makeText(this, description, Toast.LENGTH_SHORT).show();
}
});
Если вы сделали с программой установки Google, то просто попробуйте этот адрес, он всегда работает для меня ...
private String getPlacesApiUrl() {
String url = "";
String location = String.valueOf(currentLocation.latitude)+","+String.valueOf(currentLocation.longitude);
String radius = "5000";
String type = "hospital";
String sensor = "false";
String key = "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX";
try {
url = "https://maps.googleapis.com/maps/api/place/search/json"
+ "?location=" + URLEncoder.encode(location, "UTF-8")
+ "&type=" + URLEncoder.encode(type, "UTF-8")
+ "&radius=" + URLEncoder.encode(radius, "UTF-8")
+ "&sensor=" + URLEncoder.encode(sensor, "UTF-8")
+ "&key=" + URLEncoder.encode(key, "UTF-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
Log.d("url",url);
return url;
}
Но убедитесь, что вы используете Browser Key
Успехов ,
привет спасибо за решение, теперь он отлично работает. Вы знаете, как получить длинный лот и лат? Еще раз спасибо, сэр, вы спасатель жизни. – ErlAl
Добро пожаловать. Пожалуйста, рассмотрите параметр «type: parameter» в этом методе. Здесь вы можете передать любой тип, указанный здесь https://developers.google.com/places/supported_types. И также ознакомьтесь с этим руководством https://developers.google.com/ места/веб-сервис/поиск? гектолитры = еп. – Khan
являются копировать и вставлять ключи API или набирать их на основе визуального? Я только спрашиваю, потому что, по моему опыту, я обнаружил, что копирование и вставка ключей api из панели инструментов dev работает каждый раз. –
Я пробовал копировать и печатать, но он все равно не работает. Спасибо за совет, я попробую еще раз. – ErlAl