จัดระเบียบการตั้งค่า เป็นส่วนหนึ่งของ Android Jetpack
หน้าจอการตั้งค่าขนาดใหญ่และซับซ้อนอาจทำให้ผู้ใช้ค้นหา การตั้งค่าเฉพาะที่ต้องการเปลี่ยนแปลง ไลบรารีค่ากำหนดมีฟังก์ชัน ต่อไปนี้เพื่อจัดระเบียบหน้าจอการตั้งค่าของคุณ
หมวดหมู่ค่ากำหนด
หากคุณมีผลิตภัณฑ์ที่เกี่ยวข้องหลายรายการ
Preference
วัตถุในหนึ่งไฟล์
คุณสามารถจัดกลุ่มได้โดยใช้
PreferenceCategory
ต
PreferenceCategory
จะแสดงชื่อหมวดหมู่และแยก
หมวดหมู่
หากต้องการกำหนด PreferenceCategory
ใน XML ให้ใส่แท็ก Preference
รวม
PreferenceCategory
ดังนี้
<PreferenceScreen
xmlns:app="http://schemas.android.com/apk/res-auto">
<PreferenceCategory
app:key="notifications_category"
app:title="Notifications">
<SwitchPreferenceCompat
app:key="notifications"
app:title="Enable message notifications"/>
</PreferenceCategory>
<PreferenceCategory
app:key="help_category"
app:title="Help">
<Preference
app:key="feedback"
app:summary="Report technical issues or suggest new features"
app:title="Send feedback"/>
</PreferenceCategory>
</PreferenceScreen>
ผลลัพธ์จะมีลักษณะดังต่อไปนี้

แบ่งลำดับชั้นออกเป็นหลายหน้าจอ
หากคุณมีออบเจ็กต์ Preference
จำนวนมากหรือหมวดหมู่ที่แตกต่างกัน คุณ
แสดงบนหน้าจอแยกกันได้ แต่ละหน้าจอ
PreferenceFragmentCompat
มีลําดับชั้นแยกต่างหาก ออบเจ็กต์ Preference
รายการ
ในหน้าจอเริ่มต้น จะสามารถลิงก์ไปยังหน้าจอย่อยที่มี
การตั้งค่าเริ่มต้น
รูปที่ 2 แสดงลำดับชั้นแบบง่ายที่ประกอบด้วย 2 หมวดหมู่ ได้แก่ ข้อความ และ ซิงค์

รูปที่ 3 แสดงค่ากำหนดชุดเดียวกันที่แบ่งออกเป็นหลายหน้าจอ

หากต้องการลิงก์หน้าจอกับ Preference
คุณสามารถประกาศ app:fragment
ใน XML หรือ
ที่คุณสามารถใช้ได้
Preference.setFragment()
เปิดชื่อแพ็กเกจแบบเต็มของ PreferenceFragmentCompat
เมื่อ
มีการแตะ Preference
ดังที่แสดงในตัวอย่างต่อไปนี้
<Preference
app:fragment="com.example.SyncFragment"
.../>
เมื่อผู้ใช้แตะ Preference
ที่มี Fragment
ที่เชื่อมโยง อินเทอร์เฟซ
วิธีการ
PreferenceFragmentCompat.OnPreferenceStartFragmentCallback.onPreferenceStartFragment()
จะถูกเรียก นี่เป็นที่ที่คุณใช้จัดการการแสดงหน้าจอใหม่และตำแหน่ง
ติดตั้งหน้าจอในบริเวณ Activity
โดยรอบ
การติดตั้งใช้งานโดยทั่วไปมีลักษณะคล้ายกับด้านล่างนี้
class MyActivity : AppCompatActivity(),
PreferenceFragmentCompat.OnPreferenceStartFragmentCallback {
...
override fun onPreferenceStartFragment(caller: PreferenceFragmentCompat, pref: Preference): Boolean {
// Instantiate the new Fragment.
val args = pref.extras
val fragment = supportFragmentManager.fragmentFactory.instantiate(
classLoader,
pref.fragment)
fragment.arguments = args
fragment.setTargetFragment(caller, 0)
// Replace the existing Fragment with the new Fragment.
supportFragmentManager.beginTransaction()
.replace(R.id.settings_container, fragment)
.addToBackStack(null)
.commit()
return true
}
}
public class MyActivity extends AppCompatActivity implements
PreferenceFragmentCompat.OnPreferenceStartFragmentCallback {
...
@Override
public boolean onPreferenceStartFragment(PreferenceFragmentCompat caller, Preference pref) {
// Instantiate the new Fragment.
final Bundle args = pref.getExtras();
final Fragment fragment = getSupportFragmentManager().getFragmentFactory().instantiate(
getClassLoader(),
pref.getFragment());
fragment.setArguments(args);
fragment.setTargetFragment(caller, 0);
// Replace the existing Fragment with the new Fragment.
getSupportFragmentManager().beginTransaction()
.replace(R.id.settings_container, fragment)
.addToBackStack(null)
.commit();
return true;
}
}
PreferenceScreen
การประกาศลำดับชั้นที่ซ้อนกันภายในทรัพยากร XML เดียวกันโดยใช้กลุ่มที่ซ้อนกัน
ไม่รองรับ <PreferenceScreen>
แล้ว ใช้ออบเจ็กต์ Fragment
ที่ฝังไว้
แทน
ใช้กิจกรรมแยกต่างหาก
หรือหากคุณต้องการกำหนดค่าแต่ละหน้าจออย่างละเอียด หรือหากต้องการ
Activity
การเปลี่ยนไปมาระหว่างหน้าจอ คุณสามารถใช้ Activity
แยกต่างหากสำหรับ
ทุกๆ PreferenceFragmentCompat
ด้วยวิธีนี้ คุณจะสามารถกำหนดค่า
Activity
และหน้าจอการตั้งค่าที่เกี่ยวข้อง สำหรับแอปส่วนใหญ่ เราจะไม่
แนะนำ ให้ใช้ Fragments
ตามที่อธิบายไว้ก่อนหน้านี้แทน
ดูข้อมูลเพิ่มเติมเกี่ยวกับการเปิดตัว Activity
จาก Preference
ได้ที่
การดำเนินการที่ต้องการ