สมมติว่าคุณต้องการใช้แท็บแถบการดำเนินการเป็นรูปแบบหลักในการนําทางระดับบนสุดในแอปพลิเคชัน ขออภัย ActionBar
API พร้อมใช้งานใน Android 3.0 ขึ้นไป (API ระดับ 11 ขึ้นไป) เท่านั้น ดังนั้นหากต้องการเผยแพร่แอปพลิเคชันไปยังอุปกรณ์ที่ใช้แพลตฟอร์มเวอร์ชันเก่า คุณจะต้องจัดเตรียมการติดตั้งใช้งานที่รองรับ API เวอร์ชันใหม่ พร้อมกับระบุกลไกสำรองที่ใช้ API เวอร์ชันเก่า
ในคลาสนี้ คุณจะได้สร้างคอมโพเนนต์อินเทอร์เฟซผู้ใช้ (UI) แบบแท็บที่ใช้คลาสนามธรรมที่มีการติดตั้งใช้งานเฉพาะเวอร์ชันเพื่อให้ใช้งานย้อนหลังได้ บทเรียนนี้จะอธิบายวิธีสร้างเลเยอร์แอบสแตรกชันสำหรับ API แท็บใหม่ซึ่งเป็นขั้นตอนแรกในการสร้างคอมโพเนนต์แท็บ
เตรียมพร้อมสำหรับการทำนามธรรม
การแยกความคิดในภาษาโปรแกรม Java เกี่ยวข้องกับการสร้างอินเทอร์เฟซหรือคลาสนามธรรมอย่างน้อย 1 รายการเพื่อซ่อนรายละเอียดการใช้งาน ในกรณีของ API ของ Android รุ่นใหม่ คุณสามารถใช้ Abstraction เพื่อสร้างคอมโพเนนต์แบบรับรู้เวอร์ชันที่ใช้ API ปัจจุบันในอุปกรณ์รุ่นใหม่ และเปลี่ยนไปใช้ API เก่าที่เข้ากันได้มากกว่าในอุปกรณ์รุ่นเก่าได้
เมื่อใช้วิธีการนี้ คุณต้องพิจารณาก่อนว่าชั้นเรียนใดจะใช้คลาสใหม่แบบย้อนหลังได้ จากนั้นจึงสร้างคลาสนามธรรมโดยอิงตามอินเทอร์เฟซสาธารณะของชั้นเรียนใหม่ ในการกำหนดอินเทอร์เฟซ Abstraction คุณควรมิเรอร์ API ที่ใหม่กว่าให้ได้มากที่สุด วิธีนี้จะช่วยเพิ่มความเข้ากันได้ในอนาคตให้มากที่สุด และทำให้การนำเลเยอร์การแยกความคิดออกในอนาคตง่ายขึ้นเมื่อไม่จำเป็นแล้ว
หลังจากสร้างคลาสนามธรรมสำหรับ API ใหม่เหล่านี้แล้ว คุณจะสร้างและเลือกการใช้งานจำนวนเท่าใดก็ได้ในระหว่างรันไทม์ การใช้งานเหล่านี้อาจแตกต่างกันไปตามระดับ API ที่จำเป็นเพื่อวัตถุประสงค์ในการรองรับการทำงานร่วมกันย้อนหลัง ดังนั้น การใช้งานหนึ่งๆ อาจใช้ API ที่เพิ่งเปิดตัว ขณะที่การใช้งานอื่นๆ อาจใช้ API เก่าได้
สร้างอินเทอร์เฟซแท็บนามธรรม
หากต้องการสร้างแท็บเวอร์ชันที่เข้ากันได้แบบย้อนหลัง คุณควรพิจารณาก่อนว่าแอปพลิเคชันของคุณต้องใช้ฟีเจอร์และ API ใดบ้าง ในกรณีของแท็บส่วนระดับบนสุด สมมติว่าคุณมีข้อกำหนดการทำงานดังต่อไปนี้
- ตัวบ่งชี้แท็บควรแสดงข้อความและไอคอน
- แท็บสามารถเชื่อมโยงกับอินสแตนซ์ Fragment ได้
- กิจกรรมควรฟังการเปลี่ยนแปลงแท็บได้
การเตรียมข้อกำหนดเหล่านี้ไว้ล่วงหน้าจะช่วยให้คุณควบคุมขอบเขตของเลเยอร์แอบสแตรกได้ ซึ่งหมายความว่าคุณจะใช้เวลาน้อยลงในการสร้างการติดตั้งใช้งานเลเยอร์ Abstraction หลายๆ แบบ และเริ่มใช้การติดตั้งใช้งานใหม่ที่เข้ากันได้แบบย้อนหลังได้เร็วขึ้น
API หลักสําหรับแท็บอยู่ใน ActionBar
และ ActionBar.Tab
ต่อไปนี้คือ API ที่จะแยกออกมาเพื่อให้แท็บรับรู้เวอร์ชัน ข้อกำหนดสำหรับโปรเจ็กต์ตัวอย่างนี้กำหนดให้ต้องเข้ากันได้กับ Eclair (API ระดับ 5) ในขณะที่ใช้ประโยชน์จากฟีเจอร์แท็บใหม่ใน Honeycomb (API ระดับ 11) แผนภาพของโครงสร้างคลาสที่จะสนับสนุนการติดตั้งใช้งานทั้ง 2 รายการนี้ และคลาสพื้นฐาน (หรืออินเทอร์เฟซ) เชิงนามธรรมแสดงไว้ที่ด้านล่าง
ActionBar.Tab ที่เป็นนามธรรม
เริ่มต้นสร้างเลเยอร์การแยกแยะแท็บโดยสร้างคลาสนามธรรมที่แสดงถึงแท็บ ซึ่งจะแสดงอินเทอร์เฟซ ActionBar.Tab
ดังนี้
Kotlin
sealed class CompatTab(val tag: String) { ... abstract fun getText(): CharSequence abstract fun getIcon(): Drawable abstract fun getCallback(): CompatTabListener abstract fun getFragment(): Fragment abstract fun setText(text: String): CompatTab abstract fun setIcon(icon: Drawable): CompatTab abstract fun setCallback(callback: CompatTabListener): CompatTab abstract fun setFragment(fragment: Fragment): CompatTab ... }
Java
public abstract class CompatTab { ... public abstract CompatTab setText(int resId); public abstract CompatTab setIcon(int resId); public abstract CompatTab setTabListener( CompatTabListener callback); public abstract CompatTab setFragment(Fragment fragment); public abstract CharSequence getText(); public abstract Drawable getIcon(); public abstract CompatTabListener getCallback(); public abstract Fragment getFragment(); ... }
คุณสามารถใช้คลาสนามธรรมแทนอินเทอร์เฟซได้ที่นี่เพื่อลดความซับซ้อนในการใช้งานฟีเจอร์ทั่วไป เช่น การเชื่อมโยงออบเจ็กต์แท็บกับกิจกรรม (ไม่ได้แสดงในข้อมูลโค้ด)
วิธีการแท็บ ActionBar แบบนามธรรม
ถัดไป ให้กําหนดคลาสนามธรรมที่ช่วยให้คุณสร้างและเพิ่มแท็บลงในกิจกรรมได้ เช่น ActionBar.newTab()
และ ActionBar.addTab()
Kotlin
sealed class TabHelper(protected val activity: FragmentActivity) { ... abstract fun setUp() fun newTab(tag: String): CompatTab { // This method is implemented in a later lesson. } abstract fun addTab(tab: CompatTab) ... }
Java
public abstract class TabHelper { ... public CompatTab newTab(String tag) { // This method is implemented in a later lesson. } public abstract void addTab(CompatTab tab); ... }
ในบทเรียนถัดไป คุณสร้างการติดตั้งใช้งานสำหรับ TabHelper
และ CompatTab
ที่ใช้ได้กับแพลตฟอร์มทั้งเวอร์ชันเก่าและเวอร์ชันใหม่