ผสานรวมการป้อนข้อความอัตโนมัติด้วย IME และบริการป้อนข้อความอัตโนมัติ

ตั้งแต่ Android 11 เป็นต้นไป แป้นพิมพ์และตัวแก้ไขวิธีการป้อนข้อมูลอื่นๆ (IME) สามารถแสดงคำแนะนำการป้อนข้อความอัตโนมัติแทรกในบรรทัด ในแถบคำแนะนำ หรือสิ่งที่คล้ายกันแทนที่ระบบจะแสดงคำแนะนำในเมนู เนื่องจากคำแนะนำในการป้อนข้อความอัตโนมัติเหล่านี้อาจมีข้อมูลส่วนตัว เช่น รหัสผ่านหรือข้อมูลบัตรเครดิต ระบบจึงจะซ่อนคำแนะนำจาก IME จนกว่าผู้ใช้จะเลือกคำแนะนำนั้น อัปเดต IME และบริการป้อนข้อความอัตโนมัติ เช่น เครื่องมือจัดการรหัสผ่าน เพื่อใช้ประโยชน์จากฟีเจอร์นี้ หาก IME หรือบริการป้อนข้อความอัตโนมัติไม่รองรับการป้อนข้อความอัตโนมัติในบรรทัด คำแนะนำจะแสดงในเมนู เช่นเดียวกับในเวอร์ชันที่เก่ากว่า Android 11

ขั้นตอนการทำงาน

ในขั้นตอนนี้ IME หมายถึงแป้นพิมพ์ปัจจุบันหรือตัวแก้ไขอินพุตอื่นๆ และผู้ให้บริการคำแนะนำหมายถึงผู้ให้บริการคำแนะนำการป้อนข้อความอัตโนมัติที่เหมาะสม ผู้ให้บริการคำแนะนำอาจเป็นแพลตฟอร์มหรือบริการป้อนข้อความอัตโนมัติ ทั้งนี้ขึ้นอยู่กับช่องป้อนข้อมูลและการตั้งค่าของผู้ใช้

  1. ผู้ใช้จะโฟกัสที่ช่องป้อนข้อมูลที่จะเรียกใช้การป้อนข้อความอัตโนมัติ เช่น ช่องป้อนข้อมูลรหัสผ่านหรือบัตรเครดิต

  2. แพลตฟอร์มจะค้นหา IME ปัจจุบันและผู้ให้บริการคำแนะนำที่เหมาะสมเพื่อดูว่ารองรับการเติมข้อความอัตโนมัติในบรรทัดหรือไม่ หาก IME หรือผู้ให้บริการคำแนะนำไม่รองรับการเติมข้อความอัตโนมัติในบรรทัด คำแนะนำจะแสดงในเมนู เช่นเดียวกับใน Android 10 และต่ำกว่า

  3. แพลตฟอร์มจะขอให้ IME ส่งคำขอคำแนะนำ คำขอคำแนะนำนี้จะระบุจำนวนคำแนะนำสูงสุดที่จะแสดง และยังระบุข้อกำหนดของการนำเสนอสำหรับคำแนะนำแต่ละรายการด้วย ข้อกำหนดเฉพาะของการแสดงจะระบุข้อมูลต่างๆ เช่น ขนาดสูงสุด ขนาดข้อความ สี และข้อมูลแบบอักษร ซึ่งช่วยให้ผู้ให้บริการคำแนะนำจับคู่รูปลักษณ์ของ IME ได้

  4. แพลตฟอร์มจะขอให้ผู้ให้บริการคำแนะนำระบุจำนวนคำแนะนำตามคำขอ คำแนะนำแต่ละรายการมีการเรียกกลับเพื่อขยายViewที่มี UI ของคำแนะนำ

  5. แพลตฟอร์มจะแจ้งให้ IME ทราบว่าคำแนะนำพร้อมใช้งานแล้ว IME จะแสดงคำแนะนำโดยเรียกใช้เมธอดการเรียกกลับเพื่อขยายView ของคำแนะนำแต่ละรายการ IME จะไม่เห็นคำแนะนำในขั้นตอนนี้เพื่อปกป้องข้อมูลส่วนตัวของผู้ใช้

  6. หากผู้ใช้เลือกคำแนะนำอันใดอันหนึ่ง 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() เวอร์ชันต่างๆ ที่รองรับคำแนะนำในบทสนทนา