Уже управляет GoogleApiClient с ошибкой id 0, несмотря на реализацию onPause () - PullRequest
0 голосов
/ 10 февраля 2019

При нажатии на Cardview мое приложение будет отображать начало действия, которое будет отображать близлежащие места в представлении Recycler.Но всякий раз, когда я щелкаю по карточке, у меня появляется ошибка, показанная ниже.Чудом, когда я комментирую nearByPlace("restaurant") в NearbyActivity.java, программа не падает.Так возможно, потому что nearByPlace ("restaurant") также использует тот же идентификатор и как я могу это исправить

java.lang.RuntimeException: Невозможно запустить действие ComponentInfo {com.example.android.sunshine / com.example.android.sunshine.MainActivity}: java.lang.IllegalStateException: уже управляющий клиентом GoogleApiClient с идентификатором 0

ошибка Logcat

ItemOneFragment.Java

private void init() {
        mGeoDataClient = Places.getGeoDataClient(getActivity(), null);
        // Construct a PlaceDetectionClient.
        mPlaceDetectionClient = Places.getPlaceDetectionClient(getActivity(), null);
        mGoogleApiClient = new GoogleApiClient
                .Builder(getActivity())
                .addApi(Places.GEO_DATA_API)
                .addApi(Places.PLACE_DETECTION_API)
                .enableAutoManage(getActivity(), 0, this)
                .build();
        SessionData.setSessionId("0");
        mSearchText.setOnItemClickListener(mAutocompleteClickListener);
        placeAutocompleteAdapter = new PlaceAutocompleteAdapter(getActivity(), mGeoDataClient, LAT_LNG_BOUNDS, null);
        mSearchText.setAdapter(placeAutocompleteAdapter);

    }

@Override
    public void onActivityCreated(@Nullable Bundle savedInstanceState) {
        super.onActivityCreated(savedInstanceState);
        cardShopMall = (CardView) getView().findViewById(R.id.textViewShopMall);
        cardShopMall.setOnClickListener(cardShopMallOnClickListener);


        if (isServicesOK()) {
            getLocationPermission();
        }
        if (mLocationPermissionsGranted) {
            getDeviceLocation();
            init();
        }


    }

CardView.OnClickListener cardShopMallOnClickListener = new CardView.OnClickListener(){
        @Override
        public void onClick(View view) {
            String type = "shopping_mall";
            Intent i = new Intent(getContext(),NearbyActivity.class);
            i.putExtra("type",type);
            i.putExtra("latitude",latitude);
            i.putExtra("longitude",longitude);
            startActivity(i);
        }
    };

NearbyActivity.Java

IGoogleAPIService mServiceNear;
    private GoogleApiClient mGoogleApiClient;

    public NearbyActivity() {
        Retrofit retrofit1 = RetrofitClient2.getClient("https://maps.googleapis.com/");
        mServiceNear = retrofit1.create(IGoogleAPIService.class);
    }

    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

               mGoogleApiClient = new GoogleApiClient
                        .Builder(this)
                        .addApi(Places.GEO_DATA_API)
                        .addApi(Places.PLACE_DETECTION_API)
                        .enableAutoManage(this, 2 ,this)
                        .build();

        Intent intent = getIntent();
        String type = intent.getExtras().getString("type");
        latitude = intent.getExtras().getDouble("latitude");
        longitude = intent.getExtras().getDouble("longitude");

        try {
            nearByPlace("restaurant");
        } catch (Exception e) {
            e.printStackTrace();
        }

    }


    private void nearByPlace(final String type) {
        String url = getUrl(latitude,longitude,type);
        Log.d(TAG,"underURL@ nearByPlace : " + url);

        mServiceNear.getNearByPlaces(url)
                .enqueue(new Callback<MyPlaces>() {
                    @Override
                    public void onResponse(Call<MyPlaces> call, retrofit2.Response<MyPlaces> response) {

                        try {
                            if (response.isSuccessful()){
                                Log.d(TAG,"responnse : ok");

                                try {
                                    if (response.body() != null){
                                        for (int i=0;i<response.body().getResults().length;i++){

                                            Results googlePlace = response.body().getResults()[i];
                                            String placeName = googlePlace.getName();
                                            String vicinity = googlePlace.getVicinity();
                                            Log.d(TAG,"nearByPlaces: " + placeName);
                                            ListItem item = new ListItem(
                                                    googlePlace.getName(),
                                                    googlePlace.getVicinity()
                                            );
                                            listItems.add(item);
                                        }
                                    }else {
                                        Toast.makeText(getApplicationContext(),"No Nearby " + type,Toast.LENGTH_LONG).show();
                                    }
                                } catch (Exception e) {
                                    e.printStackTrace();
                                }
                                adapter = new MyAdapter(listItems,NearbyActivity.this);
                                recyclerView.setAdapter(adapter);
                            }
                        }catch (Exception e){
                            e.getMessage();
                        }

                    }

                    @Override
                    public void onFailure(Call<MyPlaces> call, Throwable t) {

                    }
                });

    }

    private String getUrl(double latitude, double longitude, String restaurant) {
        StringBuilder googlePlacesUrl = new StringBuilder("https://maps.googleapis.com/maps/api/place/nearbysearch/json?");
        googlePlacesUrl.append("location="+latitude+","+longitude);
        googlePlacesUrl.append("&radius="+5000);
        googlePlacesUrl.append("&type="+restaurant);
        googlePlacesUrl.append("&sensor=true");
        googlePlacesUrl.append("&key="+getResources().getString(R.string.GoogleAPiKey));

        Log.d(TAG,"getURL : " + googlePlacesUrl.toString());
        return googlePlacesUrl.toString();
    }

    @Override
    protected void onPause() {
        super.onPause();
        if (mGoogleApiClient != null && mGoogleApiClient.isConnected()) {
            mGoogleApiClient.stopAutoManage(this);
            mGoogleApiClient.disconnect();
        }
    }

1 Ответ

0 голосов
/ 10 февраля 2019

Да, вы правильно внедрили onPause для своей Деятельности, но не для своего Fragment.

В своем методе init внутри своего Фрагмента вы создаете новый GoogleApiClient.Это отличается от вашего Activity, в котором - как уже упоминалось ранее - вы правильно реализовали onPause.

Поэтому решение вашей проблемы должно заключаться в реализации onPause для вашего фрагмента.

Я надеюсь, что это решит вашу проблему

...