Я следую этому уроку https://www.codexpedia.com/android/android-tablayout-with-many-tabs-kotlin/
Я изменил метод для добавления фрагмента, но мне нужно перейти на конкретную вкладку в tablayout. этот урок неправильно возвращает позицию вкладки (страницы) и каждый переход (скажем, вкладка 5), всегда загружайте каждую вкладку (0,1,2,3,4,5) не прямо на вкладку 5, каждая вкладка должна принимать данные с сервера, поэтому для извлечения данных во всех вкладках требуется много времени.
Класс объявления
class Listing : AppCompatActivity() {
// From server
var latitude = ""
var longitude = ""
var category:Int = 0
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_listing)
getCategory()
}
fun getCategory(){
val builder = AlertDialog.Builder(this)
val dialogView=layoutInflater.inflate(R.layout.progress_dialog,null)
builder.setView(dialogView)
builder.setCancelable(false)
val dialog = builder.create()
dialog.show()
var rq: RequestQueue = Volley.newRequestQueue(this)
var sr = object : StringRequest(Request.Method.POST, user_info.get_category, Response.Listener { response ->
//========================================================================================= data from server
Handler().postDelayed({dialog.dismiss()},0)
Log.i("AIM", response.toString())
val pageAdapter = MyPagerAdapter(supportFragmentManager)
var jsonObject = JSONObject(response)
var data:JSONObject = jsonObject["data"] as JSONObject
var jsonArray = data.getJSONArray("vendor_type")
for (i in 0 until jsonArray.length()) {
var jo = jsonArray.getJSONObject(i)
var id = jo["id"].toString()
var nama = jo["nama"].toString()
pageAdapter.add(FirstFragment.newInstance(i), nama)
user_info.nama_category.add(i,nama)
Log.d("aim","Fragment created")
}
viewpager_main.adapter = pageAdapter
tabs_main.setupWithViewPager(viewpager_main)
if (category != 0){
var fix = category - 1
viewpager_main.setCurrentItem(fix, false)
}
}, Response.ErrorListener { response ->
//========================================================================================= error handling
Handler().postDelayed({dialog.dismiss()},0)
var networkResponse = response.networkResponse
if (networkResponse == null){
Toast.makeText(this, "Tidak terhubung dengan server", Toast.LENGTH_LONG).show()
}
}) { }
sr.retryPolicy = DefaultRetryPolicy(
10000,
DefaultRetryPolicy.DEFAULT_MAX_RETRIES,
DefaultRetryPolicy.DEFAULT_BACKOFF_MULT
)
rq.add(sr)
}
}
Фрагмент
class FirstFragment : Fragment() {
private val vendorData = mutableListOf<vendor_model>()
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
val view = inflater.inflate(R.layout.fragment_first, container, false)
val page = getArguments()!!.getInt(PAGE_NUM)
Log.d("aim", "page : $page")
getVendor(page)
return view
}
companion object {
val PAGE_NUM = "PAGE_NUM"
fun newInstance(page: Int): FirstFragment {
val fragment = FirstFragment()
val args = Bundle()
args.putInt(PAGE_NUM, page)
fragment.setArguments(args)
return fragment
}
}
fun getVendor(page: Int) {
val builder = activity?.let { AlertDialog.Builder(it) }
val dialogView = layoutInflater.inflate(R.layout.progress_dialog,null)
builder?.setView(dialogView)
builder?.setCancelable(false)
val dialog = builder?.create()
dialog?.show()
var category = page + 1
Log.d("aim", "category : $category")
var rq: RequestQueue = Volley.newRequestQueue(activity)
var sr = object : StringRequest(Request.Method.POST, url, Response.Listener { response ->
Handler().postDelayed({dialog?.dismiss()},0)
Log.i("AIM", response.toString())
var jsonObject = JSONObject(response)
var jsonArray = jsonObject.getJSONArray("list")
for (i in 0 until jsonArray.length()) {
var jo = jsonArray.getJSONObject(i)
var jarak: String
if (jo.isNull("distance")) {
jarak = "Unknown"
}else jarak = jo["distance"].toString() + " Km"
var id = jo["id_vendor"].toString()
var nama = jo["nama"].toString()
//var jarak = jo["distance"].toString()
var rating = jo["rating"].toString()
var status = jo["is_open"].toString()
var img = jo["file_logo"].toString()
var category = jo["vendor_type"].toString()
val mItem = vendor_model(id, nama, "$jarak", rating, status, img, category)
vendorData.add(mItem)
}
// ============ recycler_nearme ============
recyclerView.layoutManager = LinearLayoutManager(activity, OrientationHelper.VERTICAL,false)
val vendorAdapter = vendor_adapter()
recyclerView.adapter = vendorAdapter
vendorAdapter.setList(vendorData)
vendorData.clear()
}, Response.ErrorListener { response ->
Handler().postDelayed({dialog?.dismiss()},0)
//========================================================================================= error handling
Toast.makeText(activity, response.toString(), Toast.LENGTH_LONG).show()
var networkResponse = response.networkResponse
if (networkResponse == null){
Toast.makeText(activity, "Tidak terhubung dengan server", Toast.LENGTH_LONG).show()
}
else {
var code = networkResponse.statusCode
var err = networkResponse.data
Toast.makeText(activity, "Error : $code", Toast.LENGTH_LONG).show()
Log.i("AIM", err.toString())
}
}) {
override fun getParams(): MutableMap<String,String> {
var map = HashMap<String, String>()
map.put("text" , "")
map.put("tags" , "")
map.put("take" , "10")
map.put("skip" , "0")
map.put("sort_by" , "asc")
map.put("language" , "[]")
map.put("type" , "")
map.put("category" , "[$category]")
map.put("grade" , "[]")
map.put("nearme" , "0")
map.put("distance" , "")
map.put("location" , "")
map.put("latitude" , "")
map.put("longitude" , "")
map.put("open_now" , "")
map.put("price_min" , "")
map.put("price_max" , "")
map.put("rating" , "")
map.put("rating_max" , "")
map.put("rating_min" , "")
map.put("ratings" , "[]")
map.put("subject" , "")
return map
}
}
sr.retryPolicy = DefaultRetryPolicy(
3000,
DefaultRetryPolicy.DEFAULT_MAX_RETRIES,
DefaultRetryPolicy.DEFAULT_BACKOFF_MULT
)
rq.add(sr)
Log.i("aim", sr.body.toString(Charset.defaultCharset()))
}
}
Адаптер
class MyPagerAdapter(fm: FragmentManager): FragmentPagerAdapter(fm){
private val tabNames: ArrayList<String>
private val fragments: ArrayList<Fragment>
init {
tabNames = ArrayList()
fragments = ArrayList()
}
fun add(fragment: Fragment, title: String) {
tabNames.add(title)
fragments.add(fragment)
}
override fun getCount(): Int {
return fragments.size
}
override fun getItem(position: Int): Fragment {
return fragments[position]
}
override fun getPageTitle(position: Int): CharSequence {
return tabNames[position]
}
}
спасибо за ваш ответ, очень признателен