Это очень странно, мой код работает нормально на 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)