পেজিং 3 পেজিং লাইব্রেরির আগের সংস্করণ থেকে উল্লেখযোগ্যভাবে আলাদা। এই সংস্করণটি বর্ধিত কার্যকারিতা প্রদান করে এবং পেজিং 2 ব্যবহার করার সাথে সাধারণ অসুবিধাগুলিকে সমাধান করে৷ যদি আপনার অ্যাপ ইতিমধ্যেই পেজিং লাইব্রেরির একটি পূর্ববর্তী সংস্করণ ব্যবহার করে, তাহলে পেজিং 3-এ স্থানান্তরিত করার বিষয়ে আরও জানতে এই পৃষ্ঠাটি পড়ুন৷
যদি পেজিং 3 পেজিং লাইব্রেরির প্রথম সংস্করণ হয় যা আপনি আপনার অ্যাপে ব্যবহার করছেন, তাহলে মৌলিক ব্যবহারের তথ্যের জন্য পৃষ্ঠাযুক্ত ডেটা লোড এবং প্রদর্শন দেখুন।
পেজিং 3 এ স্থানান্তরিত করার সুবিধা
পেজিং 3-এ নিম্নলিখিত বৈশিষ্ট্যগুলি রয়েছে যা লাইব্রেরির পূর্ববর্তী সংস্করণগুলিতে উপস্থিত ছিল না:
- Kotlin coroutines এবং Flow এর জন্য প্রথম-শ্রেণীর সমর্থন।
- RxJava
Singleবা GuavaListenableFutureprimitives ব্যবহার করে async লোডিংয়ের জন্য সমর্থন। - বিল্ট-ইন লোড অবস্থা এবং প্রতিক্রিয়াশীল UI ডিজাইনের জন্য ত্রুটি সংকেত, পুনঃপ্রচেষ্টা এবং রিফ্রেশ কার্যকারিতা সহ।
- বাতিলকরণ সমর্থন এবং একটি সরলীকৃত ডেটা উৎস ইন্টারফেস সহ সংগ্রহস্থল স্তরের উন্নতি।
- উপস্থাপনা স্তরের উন্নতি, তালিকা বিভাজক, কাস্টম পৃষ্ঠা রূপান্তর, এবং স্টেট হেডার এবং ফুটার লোড করা।
আপনার অ্যাপটিকে পেজিং 3-এ স্থানান্তর করুন
সম্পূর্ণরূপে পেজিং 3-এ স্থানান্তরিত করতে, আপনাকে অবশ্যই পেজিং 2 থেকে তিনটি প্রধান উপাদান স্থানান্তর করতে হবে:
-
DataSourceক্লাস -
PagedList -
PagedListAdapter
যাইহোক, কিছু পেজিং 3 উপাদান পেজিং এর পূর্ববর্তী সংস্করণগুলির সাথে পিছনের দিকে সামঞ্জস্যপূর্ণ। বিশেষ করে, পেজিং 3 থেকে PagingSource API পুরানো সংস্করণ থেকে LivePagedListBuilder এবং RxPagedListBuilder এর জন্য একটি ডেটা উৎস হতে পারে। একইভাবে, Pager এপিআই asPagingSourceFactory() পদ্ধতির সাথে পুরানো DataSource অবজেক্ট ব্যবহার করতে পারে। এর মানে হল যে আপনার কাছে নিম্নলিখিত মাইগ্রেশন বিকল্প রয়েছে:
- আপনি আপনার
DataSourcePagingSourceস্থানান্তর করতে পারেন তবে আপনার পেজিং বাস্তবায়নের বাকি অংশ অপরিবর্তিত রেখে দিন। - আপনি আপনার
PagedListএবংPagedListAdapterস্থানান্তর করতে পারেন তবে এখনও পুরানোDataSourceAPI ব্যবহার করতে পারেন৷ - আপনার অ্যাপটিকে সম্পূর্ণরূপে পেজিং 3-এ স্থানান্তর করতে আপনি সম্পূর্ণ পেজিং বাস্তবায়ন স্থানান্তর করতে পারেন।
এই পৃষ্ঠার বিভাগগুলি ব্যাখ্যা করে যে কীভাবে আপনার অ্যাপের প্রতিটি স্তরে পেজিং উপাদান স্থানান্তর করতে হয়।
ডেটা সোর্স ক্লাস
এই বিভাগটি PagingSource ব্যবহার করার জন্য একটি পুরানো পেজিং বাস্তবায়ন স্থানান্তর করার জন্য প্রয়োজনীয় সমস্ত পরিবর্তন বর্ণনা করে।
পেজিং 2 থেকে PageKeyedDataSource , PositionalDataSource , এবং ItemKeyedDataSource সবই পেজিং 3-এর PagingSource API-এ একত্রিত হয়৷ সমস্ত পুরানো API ক্লাসের লোডিং পদ্ধতিগুলিকে PagingSource একটি একক load() পদ্ধতিতে একত্রিত করা হয়৷ এটি কোড ডুপ্লিকেশন হ্রাস করে কারণ পুরানো API ক্লাসগুলির বাস্তবায়নে লোডিং পদ্ধতি জুড়ে বেশিরভাগ যুক্তি প্রায়ই অভিন্ন।
সমস্ত লোডিং পদ্ধতির পরামিতি পেজিং 3-এ একটি LoadParams সিল করা ক্লাসের সাথে প্রতিস্থাপিত হয়, যার মধ্যে প্রতিটি লোডের প্রকারের জন্য উপশ্রেণী অন্তর্ভুক্ত থাকে। আপনার load() পদ্ধতিতে লোডের ধরনগুলির মধ্যে পার্থক্য করার প্রয়োজন হলে, LoadParams এর কোন সাবক্লাসে পাস করা হয়েছে তা পরীক্ষা করুন: LoadParams.Refresh , LoadParams.Prepend , অথবা LoadParams.Append ।
PagingSource বাস্তবায়ন সম্পর্কে আরও জানতে, একটি ডেটা উৎস সংজ্ঞায়িত করুন দেখুন।
রিফ্রেশ কী
PagingSource -এর বাস্তবায়ন অবশ্যই লোড করা পেজড ডেটার মাঝখান থেকে কীভাবে রিফ্রেশ পুনরায় শুরু হবে তা নির্ধারণ করতে হবে। সবচেয়ে সাম্প্রতিক অ্যাক্সেস করা সূচক হিসাবে state.anchorPosition ব্যবহার করে সঠিক প্রাথমিক কী ম্যাপ করতে getRefreshKey() প্রয়োগ করে এটি করুন।
কোটলিন
// Replaces ItemKeyedDataSource. override fun getRefreshKey(state: PagingState<String, User>): String? { return state.anchorPosition?.let { anchorPosition -> state.getClosestItemToPosition(anchorPosition)?.id } } // Replacing PositionalDataSource. override fun getRefreshKey(state: PagingState<Int, User>): Int? { return state.anchorPosition }
জাভা
// Replaces ItemKeyedDataSource. @Nullable @Override String getRefreshKey(state: PagingState<String, User>) { Integer anchorPosition = state.anchorPosition; if (anchorPosition == null) { return null; } return state.getClosestItemToPosition(anchorPosition); } // Replaces PositionalDataSource. @Nullable @Override Integer getRefreshKey(state: PagingState<Integer, User>) { return state.anchorPosition; }
জাভা
// Replacing ItemKeyedDataSource. @Nullable @Override String getRefreshKey(state: PagingState<String, User>) { Integer anchorPosition = state.anchorPosition; if (anchorPosition == null) { return null; } return state.getClosestItemToPosition(anchorPosition); } // Replacing PositionalDataSource. @Nullable @Override Integer getRefreshKey(state: PagingState<Integer, User>) { return state.anchorPosition; }
তালিকা রূপান্তর
পেজিং লাইব্রেরির পুরোনো সংস্করণে, পেজড ডেটার রূপান্তর নিম্নলিখিত পদ্ধতির উপর নির্ভর করে:
-
DataSource.map() -
DataSource.mapByPage() -
DataSource.Factory.map() -
DataSource.Factory.mapByPage()
পেজিং 3-এ, সমস্ত রূপান্তরগুলি PagingData অপারেটর হিসাবে প্রয়োগ করা হয়। আপনি যদি আপনার পৃষ্ঠাযুক্ত তালিকাকে রূপান্তর করতে পূর্ববর্তী তালিকার যেকোন পদ্ধতি ব্যবহার করেন, আপনার নতুন PagingSource ব্যবহার করে Pager তৈরি করার সময় আপনাকে অবশ্যই DataSource থেকে PagingData আপনার রূপান্তর যুক্তিকে স্থানান্তর করতে হবে।
পেজিং 3 ব্যবহার করে পৃষ্ঠাযুক্ত ডেটাতে রূপান্তর প্রয়োগ করার বিষয়ে আরও জানতে, ট্রান্সফর্ম ডেটা স্ট্রীম দেখুন।
পেজডলিস্ট
এই বিভাগটি পেজিং 3 এ Pager এবং PagingData ব্যবহার করার জন্য একটি পুরানো পেজিং বাস্তবায়ন স্থানান্তর করার জন্য প্রয়োজনীয় সমস্ত পরিবর্তনগুলি বর্ণনা করে৷
PagedListBuilder ক্লাস
PagingData পেজিং 2 থেকে বিদ্যমান PagedList প্রতিস্থাপন করে। PagingData এ স্থানান্তর করতে, আপনাকে অবশ্যই নিম্নলিখিতগুলি আপডেট করতে হবে:
- পেজিং কনফিগারেশন
PagedList.ConfigথেকেPagingConfigএ সরানো হয়েছে। -
LivePagedListBuilderএবংRxPagedListBuilderএকটি এককPagerক্লাসে একত্রিত হয়েছে। -
Pagerতার.flowবৈশিষ্ট্য সহ একটি পর্যবেক্ষণযোগ্যFlow<PagingData>প্রকাশ করে। RxJava এবং LiveData ভেরিয়েন্টগুলিও এক্সটেনশন বৈশিষ্ট্য হিসাবে উপলব্ধ, যা জাভা থেকে স্ট্যাটিক পদ্ধতির মাধ্যমে কল করা যায় এবং যথাক্রমেpaging-rxjava*এবংpaging-runtimeমডিউল থেকে সরবরাহ করা হয়।
কোটলিন
val flow = Pager( // Configure how data is loaded by passing additional properties to // PagingConfig, such as prefetchDistance. PagingConfig(pageSize = 20) ) { ExamplePagingSource(backend, query) }.flow .cachedIn(viewModelScope)
জাভা
// CoroutineScope helper provided by the lifecycle-viewmodel-ktx artifact. CoroutineScope viewModelScope = ViewModelKt.getViewModelScope(viewModel); Pager<Integer, User> pager = Pager<>( new PagingConfig(/* pageSize = */ 20), () -> ExamplePagingSource(backend, query)); Flowable<PagingData<User>> flowable = PagingRx.getFlowable(pager); PagingRx.cachedIn(flowable, viewModelScope);
জাভা
// CoroutineScope helper provided by the lifecycle-viewmodel-ktx artifact. CoroutineScope viewModelScope = ViewModelKt.getViewModelScope(viewModel); Pager<Integer, User> pager = Pager<>( new PagingConfig(/* pageSize = */ 20), () -> ExamplePagingSource(backend, query)); PagingLiveData.cachedIn(PagingLiveData.getLiveData(pager), viewModelScope);
পেজিং 3 ব্যবহার করে PagingData অবজেক্টের একটি প্রতিক্রিয়াশীল স্ট্রিম সেট আপ করার বিষয়ে আরও জানতে, পেজিং ডেটার একটি স্ট্রিম সেট আপ করুন দেখুন।
স্তরযুক্ত উত্সগুলির জন্য সীমানা কলব্যাক৷
পেজিং 3-এ, RemoteMediator নেটওয়ার্ক এবং ডাটাবেস থেকে পেজিং করার জন্য একটি হ্যান্ডলার হিসাবে PagedList.BoundaryCallback প্রতিস্থাপন করে।
পেজিং 3-এ নেটওয়ার্ক এবং ডাটাবেস থেকে পৃষ্ঠায় RemoteMediator ব্যবহার সম্পর্কে আরও জানতে, Android পেজিং কোডল্যাব দেখুন।
PagedListAdapter
এই বিভাগটি পেজিং 3 থেকে PagingDataAdapter বা AsyncPagingDataDiffer ক্লাসগুলি ব্যবহার করার জন্য একটি পুরানো পেজিং বাস্তবায়ন স্থানান্তর করার জন্য প্রয়োজনীয় সমস্ত পরিবর্তনগুলি বর্ণনা করে৷
পেজিং 3 নতুন PagingData প্রতিক্রিয়াশীল স্ট্রীমগুলি পরিচালনা করতে PagingDataAdapter প্রদান করে। অন্যথায়, PagedListAdapter এবং PagingDataAdapter একই ইন্টারফেস আছে। PagedListAdapter থেকে PagingDataAdapter এ স্থানান্তর করতে, পরিবর্তে PagingDataAdapter প্রসারিত করতে আপনার PagedListAdapter এর বাস্তবায়ন পরিবর্তন করুন।
PagingDataAdapter সম্পর্কে আরও জানতে, একটি RecyclerView অ্যাডাপ্টার সংজ্ঞায়িত করুন দেখুন।
AsyncPagedListDiffer
আপনি যদি বর্তমানে AsyncPagedListDiffer সাথে একটি কাস্টম RecyclerView.Adapter বাস্তবায়ন ব্যবহার করেন, তাহলে পরিবর্তে পেজিং 3 এ দেওয়া AsyncPagingDataDiffer ব্যবহার করতে আপনার বাস্তবায়ন স্থানান্তর করুন:
কোটলিন
AsyncPagingDataDiffer(diffCallback, listUpdateCallback)
জাভা
new AsyncPagingDataDiffer(diffCallback, listUpdateCallback);
জাভা
new AsyncPagingDataDiffer(diffCallback, listUpdateCallback);
অতিরিক্ত সম্পদ
পেজিং লাইব্রেরি সম্পর্কে আরও জানতে, নিম্নলিখিত অতিরিক্ত সংস্থানগুলি দেখুন:
কোডল্যাব
নমুনা
- অ্যান্ড্রয়েড আর্কিটেকচার উপাদান পেজিং নমুনা
- ডেটাবেস এবং নেটওয়ার্ক নমুনা সহ অ্যান্ড্রয়েড আর্কিটেকচার উপাদান পেজিং
আপনার জন্য প্রস্তাবিত
- দ্রষ্টব্য: জাভাস্ক্রিপ্ট বন্ধ থাকলে লিঙ্ক টেক্সট প্রদর্শিত হয়
- পৃষ্ঠাযুক্ত ডেটা লোড এবং প্রদর্শন করুন
- পৃষ্ঠাযুক্ত ডেটা সংগ্রহ করুন
- নেটওয়ার্ক এবং ডাটাবেস থেকে পৃষ্ঠা