إنشاء قوائم ديناميكية باستخدام RecyclerView جزء من Android Jetpack.
تُسهِّل ميزة RecyclerView عرض مجموعات كبيرة من البيانات بكفاءة. أنت توفر البيانات وتحديد كيف يبدو كل عنصر، ومكتبة RecyclerView يقوم بإنشاء العناصر ديناميكيًا عند الحاجة إليها.
كما يوحي الاسم، تعمل RecyclerView على إعادة تدوير هذه العناصر الفردية. عندما يتم تمرير العنصر خارج الشاشة، لا تتلف RecyclerView طريقة العرض. بدلاً من ذلك، تعيد RecyclerView استخدام العرض للعناصر الجديدة التي تم تمريرها على الشاشة. تعمل RecyclerView على تحسين الأداء واستجابة التطبيق، وتقليل استهلاك الطاقة.
الفئات الرئيسية
تعمل عدة فئات معًا لإنشاء قائمتك الديناميكية.
RecyclerView
هوViewGroup
الذي يحتوي على المشاهدات بشكل يتوافق مع بياناتك. هذه طريقة العرض نفسها، لذا يمكنك إضافةRecyclerView
إلى التخطيط بالطريقة التي تضيف بها أي عنصر آخر في واجهة المستخدم.يتم تحديد كل عنصر منفرد في القائمة بواسطة كائن view hold. فعندما إنشاء مالك الملف الشخصي، فلا توجد أي بيانات مرتبطة به. بعد يتم إنشاء صاحب الملف الشخصي، فإن
RecyclerView
يربطه ببياناته. إِنْتَ وتحديد عنصر العرض من خلال تمديدRecyclerView.ViewHolder
تطلب
RecyclerView
المشاهدات وتربط المشاهدات ببياناتها، من خلال استدعاء طرق في المحوِّل. يمكنك تعريف المحول من خلال تمديدRecyclerView.Adapter
يرتب مدير التنسيق العناصر الفردية في قائمتك. يمكنك استخدام أحد مديري التخطيطات المتوفرة في مكتبة RecyclerView، أو يمكنك وتعريفها بنفسك. تعتمد جميع مديري التخطيطات على تصميم
LayoutManager
حصة تجريدية.
يمكنك رؤية كيفية توافق جميع القطع معًا في نموذج تطبيق RecyclerView. (Kotlin) أو نموذج تطبيق RecyclerView (Java):
خطوات تنفيذ RecyclerView
إذا كنت ستستخدم RecyclerView، فهناك بعض الأمور التي يتعين عليك القيام بها. للاطلاع على شرح مفصّل في الأقسام التالية.
حدِّد شكل القائمة أو الشبكة. عادةً، يمكنك استخدام أحد مديري التخطيطات القياسية لمكتبة RecyclerView.
تصميم كيف يبدو وسلوك كل عنصر في القائمة. مقرها في هذا التصميم، نمد فئة
ViewHolder
. إصدارViewHolder
الذي تستخدمه جميع الوظائف لعناصر القائمة. صاحب الملف الشخصي هو برنامج تضمين حولView
، وتتم إدارة هذا العرض بواسطةRecyclerView
.حدِّد
Adapter
الذي يربط بياناتك بملفاتViewHolder
الشخصية.
هناك أيضًا تخصيص متقدم الخيارات التي تتيح لك تخصيص استمتِع بأداة RecyclerView وفقًا لاحتياجاتك المحددة.
تخطيط التصميم
يتم ترتيب العناصر في RecyclerView بواسطة
LayoutManager
الصف. توفر مكتبة RecyclerView ثلاثة مديري تخطيط تتعامل مع
مواقف التخطيط الأكثر شيوعًا:
LinearLayoutManager
ترتب العناصر في قائمة أحادية الأبعاد.GridLayoutManager
وترتب العناصر في شبكة ثنائية الأبعاد:- إذا تم ترتيب الشبكة عموديًا، تحاول
GridLayoutManager
جعل كل العناصر في كل صف لها نفس العرض والارتفاع، ولكن صفوف مختلفة يمكن أن يكون لها ارتفاعات مختلفة. - إذا تم ترتيب الشبكة أفقيًا، تحاول
GridLayoutManager
جعل كل العناصر في كل عمود لها نفس العرض والارتفاع، ولكن تختلف يمكن أن يكون للأعمدة عرض مختلف.
- إذا تم ترتيب الشبكة عموديًا، تحاول
StaggeredGridLayoutManager
تشبه السمةGridLayoutManager
، لكنها لا تتطلب أن تكون العناصر في صف لها نفس الارتفاع (للشبكات العمودية) أو العناصر الموجودة في نفس العمود لها نفس العرض (للشبكات الأفقية). والنتيجة هي أن العناصر في صف أو عمود إلى إزاحة من بعضها البعض.
تحتاج أيضًا إلى تصميم تخطيط العناصر الفردية. أنت بحاجة إلى هذا عند تصميم حامل العرض، كما هو موضح في القسم التالي.
تركيب المحوّل وحامل العرض
بعد تحديد التنسيق، يجب تنفيذ Adapter
ViewHolder
تعمل هاتان الفئتان معًا لتحديد كيفية تخزين بياناتك
المعروضة. ViewHolder
هو برنامج التفاف حول View
يحتوي على
التخطيط لعنصر فردي في القائمة. ينشئ Adapter
ViewHolder
حسب الحاجة وكذلك تعيين البيانات لهذه طرق العرض. عملية
يُعرف ربط طرق العرض ببياناتها باسم الربط.
عند تعريف المحوّل، يتم إلغاء ثلاث طرق رئيسية:
onCreateViewHolder()
: تستدعي "RecyclerView
" هذه الطريقة متى يحتاج إلى إنشاءViewHolder
جديد. تنشئ الطريقة المتغير وتهيئهViewHolder
وView
المرتبط به، ولكن لا يملأ بيانات الملف الشخصي المحتوى: لم يتم ربطViewHolder
ببيانات محدَّدة بعد.onBindViewHolder()
: تستدعي "RecyclerView
" هذه الطريقة لربطViewHolder
بالبيانات. تشير رسالة الأشكال البيانية لجلب البيانات المناسبة واستخدام البيانات لملء طريقة العرض تخطيط صاحبه. على سبيل المثال، إذا عرضت السمةRecyclerView
قائمة بالأسماء، قد تعثر الطريقة على الاسم المناسب في القائمة وتملأ طريقة العرض التطبيق المصغَّرTextView
للمالك.getItemCount()
: تستدعيRecyclerView
هذه الطريقة للحصول على حجم مجموعة البيانات. على سبيل المثال: في تطبيق دفتر العناوين، فقد يكون هذا هو العدد الإجمالي للعناوين. وتستخدم RecyclerView هذا العنصر لتحديد متى لا يكون هناك المزيد من العناصر التي يمكن المعروضة.
في ما يلي مثال نموذجي لمحوّل بسيط مزوّد بـ ViewHolder
مدمج
وتعرض قائمة بالبيانات. في هذه الحالة، تعرض RecyclerView قائمة بسيطة
من عناصر النص. يتم تمرير المحوّل مصفوفة من السلاسل التي تحتوي على النص.
لعناصر ViewHolder
.
Kotlin
class CustomAdapter(private val dataSet: Array<String>) : RecyclerView.Adapter<CustomAdapter.ViewHolder>() { /** * Provide a reference to the type of views that you are using * (custom ViewHolder) */ class ViewHolder(view: View) : RecyclerView.ViewHolder(view) { val textView: TextView init { // Define click listener for the ViewHolder's View textView = view.findViewById(R.id.textView) } } // Create new views (invoked by the layout manager) override fun onCreateViewHolder(viewGroup: ViewGroup, viewType: Int): ViewHolder { // Create a new view, which defines the UI of the list item val view = LayoutInflater.from(viewGroup.context) .inflate(R.layout.text_row_item, viewGroup, false) return ViewHolder(view) } // Replace the contents of a view (invoked by the layout manager) override fun onBindViewHolder(viewHolder: ViewHolder, position: Int) { // Get element from your dataset at this position and replace the // contents of the view with that element viewHolder.textView.text = dataSet[position] } // Return the size of your dataset (invoked by the layout manager) override fun getItemCount() = dataSet.size }
Java
public class CustomAdapter extends RecyclerView.Adapter<CustomAdapter.ViewHolder> { private String[] localDataSet; /** * Provide a reference to the type of views that you are using * (custom ViewHolder) */ public static class ViewHolder extends RecyclerView.ViewHolder { private final TextView textView; public ViewHolder(View view) { super(view); // Define click listener for the ViewHolder's View textView = (TextView) view.findViewById(R.id.textView); } public TextView getTextView() { return textView; } } /** * Initialize the dataset of the Adapter * * @param dataSet String[] containing the data to populate views to be used * by RecyclerView */ public CustomAdapter(String[] dataSet) { localDataSet = dataSet; } // Create new views (invoked by the layout manager) @Override public ViewHolder onCreateViewHolder(ViewGroup viewGroup, int viewType) { // Create a new view, which defines the UI of the list item View view = LayoutInflater.from(viewGroup.getContext()) .inflate(R.layout.text_row_item, viewGroup, false); return new ViewHolder(view); } // Replace the contents of a view (invoked by the layout manager) @Override public void onBindViewHolder(ViewHolder viewHolder, final int position) { // Get element from your dataset at this position and replace the // contents of the view with that element viewHolder.getTextView().setText(localDataSet[position]); } // Return the size of your dataset (invoked by the layout manager) @Override public int getItemCount() { return localDataSet.length; } }
ويتم تحديد التنسيق لكل عنصر عرض في ملف تنسيق XML، كالمعتاد.
في هذه الحالة، يحتوي التطبيق على ملف text_row_item.xml
على النحو التالي:
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="@dimen/list_item_height"
android:layout_marginLeft="@dimen/margin_medium"
android:layout_marginRight="@dimen/margin_medium"
android:gravity="center_vertical">
<TextView
android:id="@+id/textView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/element_text"/>
</FrameLayout>
الخطوات التالية
يوضح مقتطف الرمز التالي كيفية استخدام RecyclerView
.
Kotlin
class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) val dataset = arrayOf("January", "February", "March") val customAdapter = CustomAdapter(dataset) val recyclerView: RecyclerView = findViewById(R.id.recycler_view) recyclerView.layoutManager = LinearLayoutManager(this) recyclerView.adapter = customAdapter } }
Java
RecyclerView recyclerView = findViewById(R.id.recycler_view); recyclerView.layoutManager = new LinearLayoutManager(this) recyclerView.setAdapter(customAdapter);
توفّر المكتبة أيضًا عدة طرق لتخصيص عملية التنفيذ. لمزيد من المعلومات، للحصول على معلومات، يُرجى الاطّلاع على Advanced RecyclerView المتقدمة التخصيص.
مصادر إضافية
لمزيد من المعلومات عن إجراء الاختبارات على Android، يُرجى الرجوع إلى المراجع التالية.