Android 11 นำเสนอแนวคิดเกี่ยวกับประเภทผู้ใช้ที่กำหนดมาอย่างดี โดยแสดงผู้ใช้ประเภทต่างๆ ทั้งหมดที่ฟีเจอร์ผู้ใช้หลายคนของ Android อนุญาต ฟีเจอร์นี้ช่วยให้ OEM ปรับแต่งประเภทผู้ใช้ AOSP ที่กำหนดไว้ล่วงหน้าและระบุประเภทโปรไฟล์ใหม่ได้ ดูข้อมูลเพิ่มเติมได้ที่ส่วนประเภทผู้ใช้
หน้านี้แสดงรายละเอียดของหลักเกณฑ์การใช้งานเพื่อปรับแต่งประเภทผู้ใช้
การปรับแต่ง
OEM ต้องวางซ้อน config_user_types.xml
ด้วยการปรับแต่งที่ต้องการเพื่อปรับแต่งประเภทผู้ใช้ AOSP และเพื่อกำหนดประเภทโปรไฟล์ใหม่ ไฟล์ config_user_types.xml
ประกอบด้วยการใช้งานข้อมูลอ้างอิงและรายการแอตทริบิวต์ที่กำหนดค่าได้ทั้งหมด
แอตทริบิวต์ใดก็ตาม เช่น default-restrictions
ที่ระบุไว้ในไฟล์ config_user_types.xml
จะเขียนทับค่าเริ่มต้น AOSP แอตทริบิวต์ที่ไม่ได้ระบุ
จะเป็นไปตามค่าเริ่มต้นของ AOSP การเปลี่ยนแอตทริบิวต์ส่วนใหญ่ เช่น แอตทริบิวต์ป้ายของประเภทโปรไฟล์ จะส่งผลต่อผู้ใช้ที่มีอยู่แล้วในประเภทผู้ใช้นั้นๆ
อย่างไรก็ตาม เนื่องจากจะมีการใช้ default-restrictions
ในเวลาที่สร้างผู้ใช้เท่านั้น การแก้ไขแอตทริบิวต์นี้ในกรณีที่ OTA เปลี่ยนแปลงไฟล์ config_user_types.xml
จะไม่ส่งผลต่อผู้ใช้ที่มีอยู่ก่อน ในทำนองเดียวกัน การระบุจำนวนผู้ใช้สูงสุดจะมีผลเมื่อสร้างผู้ใช้ใหม่เท่านั้น โดยจะไม่มีการนำผู้ใช้เดิมออก
ข้อจำกัดการปรับแต่งในปัจจุบันสำหรับผู้ใช้แต่ละประเภทมีดังนี้
- คุณสามารถกำหนดค่าและกำหนดโปรไฟล์ได้อย่างเต็มรูปแบบ ในกรณีนี้ OEM จะมีหน้าที่ทำการแก้ไขแพลตฟอร์มตามที่จำเป็นเพื่อให้โปรไฟล์ที่กำหนดเองรองรับใน Android เนื่องจาก AOSP รองรับเฉพาะประเภทผู้ใช้ AOSP ที่กำหนดไว้ล่วงหน้าเท่านั้น
- คุณจะกำหนดผู้ใช้เต็มรูปแบบไม่ได้ รวมถึงปรับแต่งได้เฉพาะแอตทริบิวต์
default-restrictions
เท่านั้น - ไม่สามารถกำหนดค่าผู้ใช้ระบบโดยใช้กลไกนี้ ในกรณีนี้ คุณจะตั้งค่า
default-restrictions
ได้โดยใช้com.android.internal.R.array.config_defaultFirstUserRestrictions
ดูconfig.xml
สำหรับข้อมูลเพิ่มเติม
แก้ไขประเภทผู้ใช้ที่มีอยู่
คุณปรับแต่งประเภทผู้ใช้ที่มีอยู่ได้โดยการลบล้างแอตทริบิวต์ดังที่แสดงในตัวอย่างโค้ดต่อไปนี้
<user-types version="0">
<full-type name="android.os.usertype.full.SECONDARY" >
<default-restrictions no_sms="true" />
</full-type>
<profile-type
name='android.os.usertype.profile.MANAGED'
max-allowed-per-parent='2'
icon-badge='@android:drawable/ic_corp_icon_badge_case'
badge-plain='@android:drawable/ic_corp_badge_case'
badge-no-background='@android:drawable/ic_corp_badge_no_background' >
<badge-labels>
<item res='@android:string/managed_profile_label_badge' />
<item res='@android:string/managed_profile_label_badge_2' />
</badge-labels>
<badge-colors>
<item res='@android:color/profile_badge_1' />
<item res='@android:color/profile_badge_2' />
</badge-colors>
<default-restrictions no_sms="true" no_outgoing_calls="true" />
</profile-type>
</user-types>
ในตัวอย่างโค้ดนี้ ประเภทผู้ใช้ AOSP ต่อไปนี้ปรับแต่งโดยการแก้ไขพร็อพเพอร์ตี้ที่รองรับ
ผู้ใช้เต็มรูปแบบ
android.os.usertype.full.SECONDARY
:- ข้อจำกัดเริ่มต้นของ
no_sms
จะตั้งค่าเป็น "จริง" โดยระบุdefault-restrictions no_sms="true"
- ข้อจำกัดเริ่มต้นของ
ผู้ใช้โปรไฟล์
android.os.usertype.profile.MANAGED
:- ผู้ใช้หลักแต่ละคนจะมีโปรไฟล์ได้ 2 โปรไฟล์โดยการตั้งค่า
max-allowed-per-parent='2'
- ตั้งค่าแอตทริบิวต์ของป้ายเป็นค่าที่ต้องการโดยใช้
icon-badge
,badge-plain
,badge-no-background
,badge-labels
,badge-colors
- ข้อจำกัดเริ่มต้นของ
no_sms
และno_outgoing_calls
ได้รับการตั้งค่าเป็น "จริง" โดยระบุdefault-restrictions no_sms="true" no_outgoing_calls="true"
- ผู้ใช้หลักแต่ละคนจะมีโปรไฟล์ได้ 2 โปรไฟล์โดยการตั้งค่า
โปรดดูความหมายและค่าเริ่มต้นของพร็อพเพอร์ตี้เหล่านี้ใน UserTypeFactory.java
และ UserTypeDetails.java
กำหนดประเภทโปรไฟล์ที่กำหนดเอง
ตัวอย่างโค้ดต่อไปนี้แสดงวิธีกำหนดประเภทโปรไฟล์ที่กำหนดเองแบบใหม่
<user-types version="1">
<profile-type
name="com.example.profilename"
max-allowed-per-parent="2" />
<change-user-type
from="android.os.usertype.profile.MANAGED"
to="com.example.profilename"
whenVersionLeq="1" />
</user-types>
ในตัวอย่างโค้ดนี้ ประเภทโปรไฟล์ com.example.profilename
ได้รับการกำหนดดังนี้
มีการตั้งค่า
max-allowed-per-parents
เป็น2
สำหรับ 2 โปรไฟล์ต่อผู้ใช้หลักต่อผู้ใช้ 1 รายchange-user-type
: แปลงโปรไฟล์ที่มีการจัดการที่มีอยู่ทั้งหมดของประเภทandroid.os.usertype.profile.MANAGED
เป็นcom.example.profilename
ประเภทใหม่ เมื่ออัปเกรดอุปกรณ์จาก<= 1
เวอร์ชันuser-type
ผ่าน OTA