W / IInputConnectionWrapper: reportFullscreenMode для несуществующего InputConnection - PullRequest
0 голосов
/ 07 мая 2019

Я пытаюсь использовать Placepicker в моем приложении. Я создал ключ API для того же и добавил в мои строки. но когда я открываю метку выбора, она просто падает с логом

Timeline: Activity_launch_request time:126708460 intent:Intent { 
act=com.google.android.gms.location.places.ui.PICK_PLACE 
pkg=com.google.android.gms (has extras) }

W/IInputConnectionWrapper: reportFullscreenMode on inexistent InputConnection

Я включил мой API в консоли и дважды проверил ключ API, который там существует. Я запутался, что здесь не так.

Это то, что я делаю, я использую библиотеку, указанную в документации Google, чтобы использовать метку выбора, поскольку она устарела.

implementation 'com.google.android.libraries.places:places-compat:1.1.0'

во-вторых, я импортирую нижеуказанные классы, как указано в документе

import com.google.android.libraries.places.compat.Place;
import com.google.android.libraries.places.compat.ui.PlacePicker;

наконец, я вызываю метку при событии нажатия кнопки

button.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            showPlacePicker();
        }
    });

в моем шоуPlacePicker

int PLACE_PICKER_REQUEST = 1;
private void showPlacePicker() {
    PlacePicker.IntentBuilder builder = new PlacePicker.IntentBuilder();
    try {
        startActivityForResult(builder.build(this), PLACE_PICKER_REQUEST);
    } catch (Exception e) {
        Log.e("error", e.getStackTrace().toString());
    }
}


public void onActivityResult(int requestCode, int resultCode, Intent data) {

    if (requestCode == PLACE_PICKER_REQUEST) {
        if (resultCode == RESULT_OK) {
            Place place = PlacePicker.getPlace(data, this);
            LatLng latLng = place.getLatLng();
            lat = latLng.latitude;
            lng = latLng.longitude;
            setAddress();
        }
    }
}

public void setAddress(){
    Geocoder geocoder = new Geocoder(this, Locale.getDefault());
    try {
        List<Address> addressList = geocoder.getFromLocation(
                lat, lng, 1);
        if (addressList != null && addressList.size() > 0) {
            Address address = addressList.get(0);
            StringBuilder sb = new StringBuilder();
            for (int i = 0; i < address.getMaxAddressLineIndex(); i++) {
                sb.append(address.getAddressLine(i)).append("\n");
            }
            sb.append(address.getFeatureName()).append(", ");
            sb.append(address.getSubLocality()).append(", ");
            sb.append(address.getAdminArea()) ;
            Toast.makeText(this, "admin area"+address.getAdminArea(), Toast.LENGTH_SHORT).show();
            locationText.setText(result);
        }
    } catch (IOException e) {
        Log.e("Address is ", "Unable connect to Geocoder", e);
    }
}

Может кто-нибудь сказать мне, что здесь не так? Я немного запутался, я не получаю много информации здесь. Я следовал инструкциям на Google для получения ключа и также видел учебники. Но я все еще не могу решить эту проблему.

...