1

Full disclosure, I'm still learning RxJava, it's a bit hard to grasp the idea if many of the tutorials available are not newbie friendly.

This error happens on API 16, works fine on API 23 & above (have tested below).

As you will see, I'm trying to replace Async Task with RxJava.

This is my code:

private void getGps() {
    TrackGPS gps = new TrackGPS(this);
    Single.fromCallable(() -> {
        if (gps.canGetLocation()) {
            mMainVariables.setLongitude(gps.getLongitude());
            mMainVariables.setLatitude(gps.getLatitude());

            if (mMainVariables.getLongitude() != 0.0) {
                Geocoder geocoder;
                List<Address> addresses = null;

                geocoder = new Geocoder(this, Locale.getDefault());
                addresses = geocoder.getFromLocation(mMainVariables.getLatitude(), mMainVariables.getLongitude(), 1); // Here 1 represent max location result to returned, by documents it recommended 1 to 5
                Log.e("Address:", addresses.get(0).getAddressLine(0));
                mMainVariables.setAddress(addresses.get(0).getAddressLine(0));
                mMainVariables.setCity(addresses.get(0).getLocality());
                mMainVariables.setState(addresses.get(0).getAdminArea());
                mMainVariables.setCountry(addresses.get(0).getCountryName());
                mMainVariables.setPostalCode(addresses.get(0).getPostalCode());
                mMainVariables.setKnownName(addresses.get(0).getFeatureName());
                Log.d("Lat Long:", "Lat: " + Double.toString(mMainVariables.getLatitude()) + " Long: " + Double.toString(mMainVariables.getLongitude()));
                return addresses.get(0).getAddressLine(0);
            } else {
                gps.showSettingsAlert();
            }

        } else {
            Toasty.error(this, "Can't locate GPS", Toast.LENGTH_SHORT, true).show();
        }
        return "";
    }).subscribeOn(Schedulers.io())
            .observeOn(AndroidSchedulers.mainThread())
            .subscribe((result) -> {
                mTxtResult.setText(result);
            });
}

EDIT: Stack below:

05-23 20:26:58.936 3420-3420/com.example.ga.realm3 E/AndroidRuntime: FATAL EXCEPTION: main
                                                                 io.reactivex.exceptions.OnErrorNotImplementedException: Can't create handler inside thread that has not called Looper.prepare()
                                                                     at io.reactivex.internal.functions.Functions$OnErrorMissingConsumer.accept(Functions.java:704)
                                                                     at io.reactivex.internal.functions.Functions$OnErrorMissingConsumer.accept(Functions.java:701)
                                                                     at io.reactivex.internal.observers.ConsumerSingleObserver.onError(ConsumerSingleObserver.java:45)
                                                                     at io.reactivex.internal.operators.single.SingleObserveOn$ObserveOnSingleObserver.run(SingleObserveOn.java:79)
                                                                     at io.reactivex.android.schedulers.HandlerScheduler$ScheduledRunnable.run(HandlerScheduler.java:109)
                                                                     at android.os.Handler.handleCallback(Handler.java:730)
Rosenberg
  • 2,424
  • 5
  • 33
  • 56

1 Answers1

1

You cannot show UI related stuff in your Scheduler thread. You are trying to show a Toast and also I presume your showSettingsAlert() is also trying show a dialog.

This is against the threading policy. Very similar to

Can't create handler inside thread that has not called Looper.prepare() inside AsyncTask for ProgressDialog

Vasily Kabunov
  • 6,511
  • 13
  • 49
  • 53
Arun Shankar
  • 2,295
  • 16
  • 20