Day 27 - AdapterKit
สวัสดีครับ บทความนี้เป็นบทความที่ 27 แล้วนะครับ ที่ผมจะมาเขียน ในซีรีย์ Learn 30 Android Libraries in 30 days
สำหรับบทความทั้งหมด อ่านได้จากด้านล่างครับ
- Day 1 : AndroidStaggered Grid
- Day 2 : Paralloid
- Day 3 : Retrofit
- Day 4 : SwipeRefreshLayout
- Day 5 : Android GraphView
- Day 6 : Holo Color Picker
- Day 7 : Android Async Http
- Day 8 : Crashlytics
- Day 9 : Butter Knife
- Day 10 : Android Annotations
- Day 11 : DateTimePicker
- Day 12 : Circular Progress Button
- Day 13 : ViewPager
- Day 14 : ViewPagerIndicator
- Day 15 : FadingActionBar
- Day 16 : AutofitTextView
- Day 17 : SwipeListView
- Day 18 : ShowcaseView
- Day 19 : GreenDAO
- Day 20 : AndroidViewAnimation
- Day 21 : ActiveAndroid
- Day 22 : Twitter4J
- Day 23 : ListViewAnimations
- Day 24 : AndEngine
- Day 25 : EazeGraph
- Day 26 : Cardslib
- Day 27 : AdapterKit
- Day 28 : WeatherLib
- Day 29 : FlatUI
- Day 30 : Android Firebase
สำหรับวันนี้ขอนำเสนอเรื่อง Adapter-Kit
เป็น Library ที่เอาไว้ช่วยให้เราทำ Custom ListView ได้ง่ายขึ้น เพราะตัว Adapter-Kit จะมี คลาส Adapter มาให้แล้ว อย่างเช่น เมื่อเรา ต้องการที่จะทำ Custom Adapter 4-5 แบบ แทนที่จะต้องมาสร้าง Adapter ทุกๆแบบ ก็ใช้แค่ Adapter-Kit ตัวเดียวเท่านั้นครับ หากยังไม่เห็นภาพ มาดูตัวอย่างกันดีกว่า
Installation
ขั้นตอนการติดตั้ง เปิดไฟล์ build.gradle
ขึ้นมา แล้วเพิ่ม dependencies ลงไปดังนี้
กด Sync Gradle เป็นอันเรียบร้อย
Usage
การใช้งาน Adapter-Kit มีคลาสที่จำเป็นอยู่นั่นก็คือ
InstantAdapter
: เป็นเหมือน Custom Adapter ของเรา ตัวเดียว ใช้ได้ตลอดงานListView
: อันนี้แน่นอนอยู่แล้ว เป็น ListView ธรรมดาModel.class
: อันนี้เป็นคลาส โมเดล เช่น คลาสPlayer
คลาสBook
คลาสStudent
เป็นต้นList<Model>
: เป็น List ของคลาสโมเดล ปกติเวลาเรา ใส่ค่าให้ Adapter จะเป็นพวก Array หรือว่า List อยู่แล้ว ซึ่งคล้ายๆกัน
การสร้างออปเจ็ค InstantAdapter
ใช้คำสั่งนี้
โดย parameter มีดังนี้
this
คือContext
R.layout.list_item
: คือ resourceId (ชื่อ Layout)Model.class
: คลาสโมเดลของเราmodel
: List ของคลาสโมเดล
จากนั้นก็สั่ง setAdapter()
ปกติครับ
สร้างโปรเจ็ค
มาลองสร้างโปรเจ็คดูกัน เริ่มแรก ทำการสร้างเลเอาท์ ภายในก็มีแค่ ListView
ต่อมา เลเอาท์ของ list_item แต่ละ row ใน ListView ตั้งชื่อว่า list_item.xml
ต่อมาสร้างคลาส Java ชื่อว่า AdapterKitActivity
แล้วทำการเซตเลเอาท์ และ binding ListView ดังนี้
ตัว InstantAdapter มันใช้ คลาสโมเดล ด้วย ฉะนั้นผมสร้างคลาสโมเดลชื่อ Player
ขึ้นมา มีแค่ name และ club ครับ
กลับมาที่ Activity อีกครั้ง คราวนี้ก็สร้างออปเจ็ค ของ InstantAdapter
ที่เมธอด onCreate()
ดังนี้
ด้านบนเป็นการสร้างข้อมูลจำลองขึ้นมาเพื่อเก็บใส่ List<Player>
เพื่อเอาไว้ตอนสร้าง InstantAdapter
ทดสอบ รันโปรแกรม
อ้าวเห้ย! ทำไมไม่มีข้อมูลแสดง หว่า…????
ลืมไปหนึ่งอย่าง ไม่สงสัยหรอ ว่าทำไม แค่เราส่ง model กลับ layout ไปให้ InstantAdapter มันรู้ได้ไง ว่าตรงไหนจะต้องเป็น TextView ของ name อันไหนเป็น TextView ของ club จริงๆแล้ว ต้องไปแก้ที่คลาส Model ครับ เปิดไฟล์ Player.java
ขึ้นมา แล้วเพิ่ม @InstantText(viewId = id)
ที่เมธอด getName()
และ getClub()
ดังนี้
จากโค๊ดด้านบน เราสั่งให้มันหา id ที่ชื่อ name จากนั้น ก็เซตค่า name ให้ ซึ่งก็คือ เซตค่า ์Player.name ให้กับ TextView นั่นเอง เช่นเดียวกัน อีกเมธอด คือการเซต Player.club ให้กับ TextView ที่มีไอดีชื่อ club ครับ ทดสอบรันใหม่อีกครั้ง คราวนี้ได้ผลลัพธ์แบบนี้
CircularAdapter
ัตัว Adapter-Kit ยังมี CircularAdapter
ซึ่งช่วยให้เราแสดง ListView แบบ inifity เลย การสร้างก็ง่ายมาก แบบนี้
การสร้างออปเจ็ค CircularListAdapter
จาก InstantAdapter
ของเรา จากนั้นก็ให้ ListView setAdapter()
จาก adapter เดิมเป็น CircularListAdapter
ทีนี้ลองรันดูใหม่ เมื่อ scroll ลงมาเรื่อยๆ ก็จะเป็น Endless ListView เลย
สรุป
จริงๆยังมีส่วน Section อีกนะครับ แต่ขี้เกียจทำละครับ ไม่ไหว หากใครสนใจ ลองไปศึกษาเพิ่มเติม จาก Sample ของ Adapter-Kit ดูนะครับ จากการลองใช้แล้ว ก็พบว่ามันยังมีข้อจำกัดอยู่พอสมควร ผมลองใช้กับ ImageView แล้วพบว่ามันไม่สามารถทำได้ เพราะว่าเห็น annotation ที่ใช้ได้ มีแค่ @InstantText()
สำหรับ TextView อย่างเดียว เดี่ยวถ้ายังไง ลองเล่นเพิ่มเติม แล้วพบว่ามันสามารถทำพวก View อื่นๆ นอกเหนือจาก TextView ได้จะมาอัพเดทละกันครับ
- Authors
-
Chai Phonbopit
เป็น Web Dev ในบริษัทแห่งหนึ่ง ทำงานมา 10 ปีกว่าๆ ด้วยภาษาและเทคโนโลยี เช่น JavaScript, Node.js, React, Vue และปัจจุบันกำลังสนใจในเรื่องของ Blockchain และ Crypto กำลังหัดเรียนภาษา Rust