ข้อจำกัดเกี่ยวกับประสบการณ์ของผู้ใช้รถยนต์

โปรดอ่านหลักเกณฑ์สิ่งรบกวนการขับขี่ก่อนดำเนินการต่อ

หน้านี้อธิบายกฎข้อจำกัดด้านประสบการณ์ของผู้ใช้ (UX) ของรถยนต์ที่คุณสามารถใช้เพื่อสร้างการกำหนดค่ากฎข้อจำกัดด้าน UX หลายรายการ (เช่น สหภาพยุโรปกับญี่ปุ่น) จากนั้นจึงกำหนดชุดกฎที่จะใช้ในขณะรันไทม์ ดูข้อมูลเพิ่มเติมได้ที่ CarUxRestrictions

บริการข้อจำกัด UX ของรถยนต์ช่วยให้นักพัฒนาแอปกำหนดการกำหนดค่าข้อจำกัด UX ของรถยนต์ใหม่ได้ หากนักพัฒนาแอปต้องการแก้ไขกฎข้อจำกัด (เช่น เพื่อให้เป็นไปตามมาตรฐานความปลอดภัยในพื้นที่) นักพัฒนาแอปสามารถใช้ API เพื่อกำหนดการกำหนดค่าใหม่ได้

API สำหรับตั้งค่าการกําหนดค่าจะยังคงอยู่ในการกําหนดค่าใหม่เท่านั้น กล่าวคือ การกำหนดค่าจะไม่มีผลทันที แต่ระบบจะโหลดการกําหนดค่าใหม่เมื่อบริการข้อจํากัด UX เริ่มทํางานอีกครั้งและรถอยู่ในโหมดเข้าเกียร์จอด บริการซ่อมรถจะตรวจสอบว่ารถอยู่ในตำแหน่งเข้าเกียร์ P ก่อนที่จะโหลดการกำหนดค่าใหม่

นอกจากเมธอดบริการข้อจํากัด UX ใหม่แล้ว เรายังมี API ในการสร้างการกําหนดค่าด้วย ระบบจะแปลงสถานะการเลือกเกียร์และความเร็วเป็นสถานะการขับขี่อย่างใดอย่างหนึ่งต่อไปนี้

  • หยุดทำงาน เกียร์อยู่ในโหมด P
  • ไม่มีการใช้งาน เกียร์ไม่ได้อยู่ในตำแหน่ง "P" และความเร็วเป็น 0
  • ย้าย เกียร์ไม่ได้อยู่ในตำแหน่ง P และความเร็วไม่ใช่ 0

หากต้องการดูวิธีที่แอปใช้สถานะการขับขี่ของรถยนต์และข้อจำกัด UX ที่เกี่ยวข้อง โปรดดูการใช้สถานะการขับขี่ของรถยนต์และข้อจำกัด UX

การกําหนดค่าข้อจํากัดตามสถานะไดรฟ์

Android จะจับคู่สถานะการขับรถกับชุดข้อจำกัด UX เพื่อไม่ให้ผู้ขับขี่เสียสมาธิ /packages/services/Car/+/main/car-lib/src/android/car/drivingstate/CarDrivingStateManager.java

  • หยุดทำงาน ไม่จำกัด
  • ไม่มีการใช้งาน ไม่มีวิดีโอและไม่มีหน้าจอการกําหนดค่า
  • ย้าย ถูกจํากัดโดยสมบูรณ์ (ต้องระบุข้อจํากัดทั้งหมด)

การแมปที่แสดงด้านบนได้รับการกำหนดไว้ล่วงหน้าและกำหนดค่าเป็นทรัพยากร XML จากนั้น /packages/services/Car/+/main/car-lib/src/android/car/drivingstate/CarDrivingStateManager.java จะบันทึกกฎไว้ในหน่วยความจำ จากนั้นบริการจะแมปสถานะการขับขี่ปัจจุบันกับการจํากัด UX และประกาศข้อจํากัดปัจจุบันไปยังทั้งระบบ

<!-- No restrictions when car is parked -->
<DrivingState car:state="parked">
    <Restrictions car:requiresDistractionOptimization="false"
                  car:uxr="baseline"/>
</DrivingState>

<!-- Restrictions when car is idling -->
<DrivingState car:state="idling">
    <Restrictions car:requiresDistractionOptimization="true"
                  car:uxr="no_video|no_config"/>
</DrivingState>

<!-- Restrictions for speed >= 0 m/s -->
<DrivingState car:state="moving" car:minSpeed="0.0">
    <Restrictions car:requiresDistractionOptimization="true"
                  car:uxr="fully_restricted"/>
</DrivingState>

การกําหนดค่าสําหรับจอภาพหลายจอ

โดยค่าเริ่มต้น จะไม่มีการกำหนดข้อจำกัดสำหรับจอแสดงผลเพิ่มเติม หากต้องการสร้างการกำหนดค่าข้อจำกัดสำหรับจอแสดงผลหลายจอ ให้ใส่แท็ก RestrictionMapping กับ พอร์ตทางกายภาพ สำหรับจอแสดงผลนั้น ระบบจะนำข้อจำกัดที่เหมาะสมไปใช้กับจอแสดงผลแต่ละจอโดยอัตโนมัติ ในตัวอย่างต่อไปนี้ จอแสดงผลที่มีรหัสพอร์ตจริง 1 และ 2 มีการกำหนดค่าต่างกัน

<RestrictionMapping car:physicalPort="1">
       <DrivingState car:state="moving">
           <Restrictions car:requiresDistractionOptimization="true" car:uxr="no_keyboard|no_video"/>
       </DrivingState>
   </RestrictionMapping>

   <RestrictionMapping car:physicalPort="2">
       <DrivingState car:state="moving">
           <Restrictions car:requiresDistractionOptimization="true" car:uxr="no_video"/>
       </DrivingState>
  </RestrictionMapping>

การกําหนดค่าสําหรับโหมดการจํากัด

คุณเลือกชื่อโหมดได้ เช่น วัยรุ่น ในตัวอย่างต่อไปนี้ ระบบกําหนดค่าข้อจํากัดที่แตกต่างกันสําหรับโหมดเริ่มต้นและผู้โดยสาร (ก่อนหน้านี้รองรับเฉพาะโหมดผู้โดยสารเท่านั้น)

<DrivingState car:state="idling">
    <Restrictions car:mode="passenger" car:requiresDistractionOptimization="false" car:uxr="baseline"/>
    <Restrictions car:requiresDistractionOptimization="true" car:uxr="no_video"/>
</DrivingState>
</Restrictions>
คุณใช้ API เพื่อตั้งชื่อสตริงสำหรับโหมดใดก็ได้ เช่น เมธอด setRestrictionMode(@NonNull String mode) ใน CarUxRestrictionsManager (ก่อนหน้านี้ คุณจะใช้เมธอด setRestrictionMode(@CarUxRestrictionsManager.UxRestrictionMode int mode) ใน CarUxRestrictionsManager)

CarUxRestrictionsConfiguration API

ข้อจำกัดที่มี CarUxRestrictionsConfiguration

ระบบจะแมปคลาส CarUxRestrictionsConfiguration ใหม่ 1:1 กับสคีมาการกําหนดค่า XML ปัจจุบัน CarUxRestrictionsConfiguration สร้างได้ด้วย CarUxRestrictions.Builder ซึ่งจะตรวจสอบการกำหนดค่าเมื่อ build()

new CarUxRestrictionsConfiguration.Builder()
        // Explicitly set restrictions for each driving state.
        .setUxRestrictions(CarDrivingStateEvent.DRIVING_STATE_PARKED,
                /* requiresOptimization= */ false,
                /* restrictions= */ UX_RESTRICTIONS_BASELINE)
        .setUxRestrictions(CarDrivingStateEvent.DRIVING_STATE_IDLING,
                true,
                UX_RESTRICTIONS_NO_VIDEO|UX_RESTRICTIONS_NO_SETUP)
        .setUxRestrictions(CarDrivingStateEvent.DRIVING_STATE_MOVING,
                true,
                UX_RESTRICTIONS_FULLY_RESTRICTED)
        // Set restriction parameters.
        .setMaxStringLength(int max)
        .setMaxCumulativeContentItems(int max)
        .setMaxContentDepth(int max)
        // Build a new CarUxRestrictionsConfiguration.
        .build();

CarUxRestrictionsManager API

ตั้งค่า CarUxRestrictionsConfiguration สำหรับไดรฟ์ถัดไปด้วย CarUxRestrictionsManager เมธอดนี้ต้องใช้สิทธิ์ Car.PERMISSION_CAR_UX_RESTRICTIONS_CONFIGURATION

public synchronized boolean saveUxRestrictionsConfigurationForNextBoot(
        CarUxRestrictionsConfiguration config);

เก็บการกำหนดค่าข้อจำกัด UX ใหม่ไว้

เมื่อส่งการกําหนดค่าใหม่ บริการข้อจํากัด UX จะแสดงผลบูลีนเพื่อระบุว่าบันทึกการกําหนดค่าใหม่สําเร็จหรือไม่ ระบบจะใช้การกำหนดค่าใหม่นี้เฉพาะเมื่อ Integrated Head Unit (IHU) รีสตาร์ทและรถจอดอยู่เท่านั้น บริการข้อจำกัด UX มีการกำหนดค่า 2 ชุดภายในดังนี้

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

การกำหนดค่าเวอร์ชันที่ใช้งานจริง

รูปที่ 1 การกำหนดค่าเวอร์ชันที่ใช้งานจริง

ที่อยู่ไม่สำเร็จ

ระบบจะไม่บังคับใช้ข้อจำกัด UX จนกว่าจะได้รับข้อมูลจาก CarPropertyManager (เช่น ระหว่างการบูต) ระบบจะทำงานเหมือนกับว่าสถานะการขับขี่คือ "จอดอยู่"

หากการอ่านการกําหนดค่าที่บันทึกไว้ไม่สําเร็จ (เช่น ผลลัพธ์ SettingNotFoundException) บริการข้อจํากัด UX จะกลับไปใช้โหมดที่จํากัดอย่างเต็มรูปแบบซึ่งมีการเขียนโค้ดไว้ล่วงหน้า ดังนี้

// Idling/moving state is fully restricted.
private static CarUxRestrictionsConfiguration generateDefaultConfig() {}

สถานะการขับขี่และข้อจํากัดของผู้ใช้

เนื้อหาต่อไปนี้อธิบายการโต้ตอบที่แสดงในแผนภาพการออกแบบต่อไปนี้

การโต้ตอบกับสถานะการขับรถ

รูปที่ 2 การโต้ตอบกับสถานะการขับรถ

พร็อพเพอร์ตี้ที่ใช้หาสถานะการขับรถ

ใช้ VehiclePropertyIds 3 รายการต่อไปนี้เพื่อหาสถานะการขับขี่

API ที่พร้อมให้บริการแก่แอป

โค้ดจะอยู่ในตำแหน่งต่อไปนี้

โค้ด ตำแหน่ง
CarUxRestrictionsManager
API สาธารณะเพื่อลงทะเบียนการเปลี่ยนแปลงข้อจํากัด UX
/packages/services/Car/+/main/car-lib/src/android/car/drivingstate/CarDrivingStateManager.java
CarUxRestrictions
คำจำกัดความของข้อจำกัด UX
/packages/services/Car/+/main/car-lib/src/android/car/drivingstate/CarDrivingStateManager.java
CarDrivingStateManager
API ของระบบเพื่อลงทะเบียนการเปลี่ยนแปลงสถานะการขับรถ
/packages/services/Car/+/main/car-lib/src/android/car/drivingstate/CarDrivingStateManager.java

หากต้องการจำลองสถานะการขับขี่ โปรดดูหัวข้อการทดสอบ