ตั้งแต่ Android 11 เป็นต้นไป แป้นพิมพ์และตัวแก้ไขวิธีการป้อนข้อมูลอื่นๆ (IME) สามารถแสดงคำแนะนำการป้อนข้อความอัตโนมัติแทรกในบรรทัด ในแถบคำแนะนำ หรือสิ่งที่คล้ายกันแทนที่ระบบจะแสดงคำแนะนำในเมนู เนื่องจากคำแนะนำในการป้อนข้อความอัตโนมัติเหล่านี้อาจมีข้อมูลส่วนตัว เช่น รหัสผ่านหรือข้อมูลบัตรเครดิต ระบบจึงจะซ่อนคำแนะนำจาก IME จนกว่าผู้ใช้จะเลือกคำแนะนำนั้น อัปเดต IME และบริการป้อนข้อความอัตโนมัติ เช่น เครื่องมือจัดการรหัสผ่าน เพื่อใช้ประโยชน์จากฟีเจอร์นี้ หาก IME หรือบริการป้อนข้อความอัตโนมัติไม่รองรับการป้อนข้อความอัตโนมัติในบรรทัด คำแนะนำจะแสดงในเมนู เช่นเดียวกับในเวอร์ชันที่เก่ากว่า Android 11
ขั้นตอนการทำงาน
ในขั้นตอนนี้ IME หมายถึงแป้นพิมพ์ปัจจุบันหรือตัวแก้ไขอินพุตอื่นๆ และผู้ให้บริการคำแนะนำหมายถึงผู้ให้บริการคำแนะนำการป้อนข้อความอัตโนมัติที่เหมาะสม ผู้ให้บริการคำแนะนำอาจเป็นแพลตฟอร์มหรือบริการป้อนข้อความอัตโนมัติ ทั้งนี้ขึ้นอยู่กับช่องป้อนข้อมูลและการตั้งค่าของผู้ใช้
ผู้ใช้จะโฟกัสที่ช่องป้อนข้อมูลที่จะเรียกใช้การป้อนข้อความอัตโนมัติ เช่น ช่องป้อนข้อมูลรหัสผ่านหรือบัตรเครดิต
แพลตฟอร์มจะค้นหา IME ปัจจุบันและผู้ให้บริการคำแนะนำที่เหมาะสมเพื่อดูว่ารองรับการเติมข้อความอัตโนมัติในบรรทัดหรือไม่ หาก IME หรือผู้ให้บริการคำแนะนำไม่รองรับการเติมข้อความอัตโนมัติในบรรทัด คำแนะนำจะแสดงในเมนู เช่นเดียวกับใน Android 10 และต่ำกว่า
แพลตฟอร์มจะขอให้ IME ส่งคำขอคำแนะนำ คำขอคำแนะนำนี้จะระบุจำนวนคำแนะนำสูงสุดที่จะแสดง และยังระบุข้อกำหนดของการนำเสนอสำหรับคำแนะนำแต่ละรายการด้วย ข้อกำหนดเฉพาะของการแสดงจะระบุข้อมูลต่างๆ เช่น ขนาดสูงสุด ขนาดข้อความ สี และข้อมูลแบบอักษร ซึ่งช่วยให้ผู้ให้บริการคำแนะนำจับคู่รูปลักษณ์ของ IME ได้
แพลตฟอร์มจะขอให้ผู้ให้บริการคำแนะนำระบุจำนวนคำแนะนำตามคำขอ คำแนะนำแต่ละรายการมีการเรียกกลับเพื่อขยาย
View
ที่มี UI ของคำแนะนำแพลตฟอร์มจะแจ้งให้ IME ทราบว่าคำแนะนำพร้อมใช้งานแล้ว IME จะแสดงคำแนะนำโดยเรียกใช้เมธอดการเรียกกลับเพื่อขยาย
View
ของคำแนะนำแต่ละรายการ IME จะไม่เห็นคำแนะนำในขั้นตอนนี้เพื่อปกป้องข้อมูลส่วนตัวของผู้ใช้หากผู้ใช้เลือกคำแนะนำอันใดอันหนึ่ง IME จะได้รับแจ้งในลักษณะเดียวกับเมื่อผู้ใช้เลือกคำแนะนำจากเมนูระบบ
ส่วนต่อไปนี้อธิบายวิธีกำหนดค่า IME หรือบริการป้อนข้อความอัตโนมัติเพื่อรองรับการป้อนข้อความอัตโนมัติในบรรทัด
กำหนดค่า IME ให้รองรับการป้อนข้อความอัตโนมัติในบรรทัด
หัวข้อนี้จะอธิบายวิธีการกำหนดค่า IME เพื่อรองรับการป้อนข้อความอัตโนมัติแบบอินไลน์ หาก IME ไม่รองรับการป้อนข้อความอัตโนมัติในบรรทัด แพลตฟอร์มจะแสดงคำแนะนำการป้อนข้อความอัตโนมัติในเมนูโดยค่าเริ่มต้น
IME ต้องตั้งค่าแอตทริบิวต์ supportsInlinedSuggestions
เป็น true
<input-method
xmlns:android="http://schemas.android.com/apk/res/android"
android:supportsInlineSuggestions="true"/>
เมื่อแพลตฟอร์มต้องการคำแนะนำการป้อนข้อความอัตโนมัติ ระบบจะเรียกใช้เมธอด InputMethodService.onCreateInlineSuggestionsRequest()
ของ IME คุณต้องติดตั้งใช้งานวิธีการนี้ แสดงผล
InlineSuggestionsRequest
โดยระบุข้อมูลต่อไปนี้
- จำนวนคำแนะนำที่ IME ต้องการ
InlinePresentationSpec
สำหรับคำแนะนำแต่ละรายการ ซึ่งจะกำหนดวิธีนำเสนอคำแนะนำ
เมื่อแพลตฟอร์มมีคำแนะนำ ระบบจะเรียกใช้เมธอด onInlineSuggestionsResponse()
ของ IME โดยส่ง InlineSuggestionsResponse
ที่มีคำแนะนำ คุณต้องใช้วิธีนี้ ในการนำไปใช้งาน ให้เรียกใช้ InlineSuggestionsResponse.getInlineSuggestions()
เพื่อดูรายการคำแนะนำ จากนั้นขยายคำแนะนำแต่ละรายการโดยเรียกใช้เมธอด InlineSuggestion.inflate()
กำหนดค่าบริการป้อนข้อความอัตโนมัติเพื่อรองรับการป้อนข้อความอัตโนมัติในบรรทัด
หัวข้อนี้จะอธิบายวิธีกำหนดค่าบริการป้อนข้อความอัตโนมัติเพื่อรองรับการป้อนข้อความอัตโนมัติในบรรทัด หากแอปไม่รองรับการป้อนข้อความอัตโนมัติในบรรทัด แพลตฟอร์มจะแสดงคำแนะนำการป้อนข้อความอัตโนมัติในเมนูโดยค่าเริ่มต้น
บริการป้อนข้อความอัตโนมัติต้องตั้งค่าแอตทริบิวต์ supportsInlinedSuggestions
เป็น true
ดังนี้
<autofill-service
xmlns:android="http://schemas.android.com/apk/res/android"
android:supportsInlineSuggestions="true"/>
เมื่อ IME ต้องการคำแนะนำในการป้อนข้อความอัตโนมัติ แพลตฟอร์มจะเรียกใช้เมธอดonFillRequest()
ของบริการป้อนข้อความอัตโนมัติ เช่นเดียวกับในเวอร์ชันที่ต่ำกว่า Android 11 อย่างไรก็ตาม บริการของคุณต้องเรียกใช้เมธอด getInlineSuggestionsRequest()
ของออบเจ็กต์ FillRequest
ที่ส่งมาเพื่อรับ InlineSuggestionsRequest
ที่ IME สร้างขึ้น InlineSuggestionsRequest
จะระบุจํานวนคําแนะนําในบรรทัดและคําแนะนําแต่ละรายการต้องแสดงอย่างไร หาก IME ไม่รองรับคำแนะนำในบรรทัด เมธอดจะแสดง null
บริการป้อนข้อความอัตโนมัติจะสร้างออบเจ็กต์ InlinePresentation
สูงสุดตามจำนวนที่ขอใน InlineSuggestionsRequest
งานนำเสนอต้องเป็นไปตามข้อจำกัดด้านขนาดที่ระบุโดย InlineSuggestionsRequest
หากต้องการให้คำแนะนำกลับไปยัง IME ให้เรียกใช้ Dataset.Builder.setValue()
หนึ่งครั้งสำหรับคำแนะนำแต่ละรายการ Android 11 มี Dataset.Builder.setValue()
เวอร์ชันต่างๆ ที่รองรับคำแนะนำในบทสนทนา