android - доукомплектация возвращает ноль на некоторых телефонах - PullRequest
0 голосов
/ 06 февраля 2019

Это очень странно, мой код работает нормально на Android ниже 8, он отлично работает на некоторых телефонах с Android 8, но на некоторых Samsung с Android 8, возвращает нуль /

Это мой код:

getHomePage = ApiConnection.client.create(GetHomePage::class.java)
    getHomePage.getHomePage(Func.getUid(this))
        .subscribeOn(Schedulers.io())
        .observeOn(AndroidSchedulers.mainThread())
        .subscribe({ result ->

            val Gallery = result.gallery;
            val Category = result.category
            val Product = result.products

            if (Gallery != null)
                GalleryMaker(this@MainActivity, Gallery)

            if(Category!=null){
                val catAdapter = CategoryAdapter(this@MainActivity, Category);
                rcCats?.adapter = catAdapter
                catAdapter.setOnItemClickListener(object : CategoryAdapter.ClickListener {
                    override fun onClick(pos: Int, aView: View) {
                        val item = Category.get(pos)
                        val intent: Intent = Intent(this@MainActivity, Products::class.java)
                        intent.putExtra("title", item.name)
                        intent.putExtra("id", item.id)
                        startActivity(intent)
                    }
                })
            }

            if(Product!=null){
                val productsAdapter = ProductAdapter(this@MainActivity, Product);
                rcProducts?.adapter = productsAdapter
            }


            customProgressDialog?.dismiss("")
        }, { error ->
            Log.v("this", error.printStackTrace().toString())
        })

результат для категории, продукта и категории равен нулю.еще раз, то же самое приложение прекрасно работает на android pre 8, оно отлично работает с android 8 в другом телефоне, но с samsung android version 8, оно не работает и возвращает null

Это мое соединение API:

    object ApiConnection {
    val BaseUrl = Const.BaseUrl
    val client: Retrofit
        get() {
            val gson = GsonBuilder()
                .setLenient()
                .create()

            ///for Logging
            val interceptor = HttpLoggingInterceptor()
            interceptor.level = HttpLoggingInterceptor.Level.BODY
            val client = OkHttpClient.Builder().addInterceptor(interceptor).build()


            var retrofit = Retrofit.Builder()
                .baseUrl(BaseUrl)
                .addCallAdapterFactory(RxJava2CallAdapterFactory.create())
                .addConverterFactory(GsonConverterFactory.create(gson))
                .client(client)
                .build()
            return retrofit
        }
}

это кошка журнала, прежде чем я помещу! = Null для слушателей

Fatal Exception: java.lang.IllegalArgumentException: Parameter specified as non-null is null: method b.a.a.a.b, parameter list
   at ir.s.cardiomeds.Adapters.CategoryAdapter.(Unknown Source:7)
   at ir.s.cardiomeds.MainActivity$getData$1.accept(Unknown Source:29)
   at ir.s.cardiomeds.MainActivity$getData$1.accept(Unknown Source:2)
   at io.reactivex.internal.observers.ConsumerSingleObserver.onError(Unknown Source:7)
   at io.reactivex.internal.operators.single.SingleObserveOn$ObserveOnSingleObserver.run(Unknown Source:14)
   at io.reactivex.android.schedulers.HandlerScheduler$ScheduledRunnable.run(Unknown Source:2)
   at android.os.Handler.handleCallback(Handler.java:789)
   at android.os.Handler.dispatchMessage(Handler.java:98)
   at android.os.Looper.loop(Looper.java:164)
   at android.app.ActivityThread.main(ActivityThread.java:6944)
   at java.lang.reflect.Method.invoke(Method.java)
   at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:327)
   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1374)
...