ปรับการตั้งค่าการแสดงผล

Android มี API ที่อนุญาตให้แอปปรับการตั้งค่าการแสดงผลในฮาร์ดแวร์ที่รองรับ บนระบบปฏิบัติการ Android TV แอปต่างๆ สามารถใช้ข้อมูลนี้เพื่อให้เนื้อหาแสดงในรูปแบบที่ดีที่สุดได้ โดยจับคู่อัตราเฟรมและโปรไฟล์สีเพื่อให้ได้ประสบการณ์การรับชมที่ดีที่สุด

จับคู่อัตราเฟรมของเนื้อหา

เมื่ออัตราเฟรมของวิดีโอไม่ตรงกับอัตราการรีเฟรชของจอแสดงผล ผู้ใช้อาจเห็นภาพเคลื่อนไหวที่กระตุกจากอัตราเฟรมที่แปลง โดยเฉพาะอย่างยิ่งในช็อตที่แพนช้าๆ ด้วยเหตุนี้ คุณจึงควรใช้ SurfaceControl.Transaction.setFrameRate() API เพื่อแจ้งเฟรมเวิร์กเกี่ยวกับอัตราเฟรมของเนื้อหา และเพื่อส่งสัญญาณว่าเนื้อหาวิดีโอมีสิทธิ์เปลี่ยนอัตราเฟรมแบบไม่ราบรื่นหรือไม่

อ่านข้อมูลเพิ่มเติมได้ที่คู่มืออัตราเฟรม

จับคู่โปรไฟล์รูปภาพที่ต้องการ

MediaQuality API ใน Android 16 ช่วยให้นักพัฒนาแอปควบคุมโปรไฟล์รูปภาพได้

ตัวอย่างสถานการณ์มีดังนี้

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

การเลือกโปรไฟล์รูปภาพของระบบ

ก่อนเลือกรูปแบบรูปภาพ คุณต้องตรวจสอบก่อนว่าอุปกรณ์รองรับรูปแบบนั้น

ข้อมูลโค้ดต่อไปนี้แสดงวิธีใช้ getAvailablePictureProfiles() เพื่อค้นหาโปรไฟล์รูปภาพที่รองรับทั้งหมดและใช้โปรไฟล์กีฬา

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.BAKLAVA) {
    val mediaQualityManager: MediaQualityManager =
        context.getSystemService(MediaQualityManager::class.java)
    val profiles = mediaQualityManager.getAvailablePictureProfiles(null)
    for (profile in profiles) {
        // If we have a system sports profile, apply it to our media codec
        if (profile.profileType == PictureProfile.TYPE_SYSTEM
            && profile.name == NAME_SPORTS
        ) {
            val bundle = Bundle().apply { 
                putParcelable(MediaFormat.KEY_PICTURE_PROFILE_INSTANCE, profile)
            }
            mediaCodec.setParameters(bundle)
        }
    }
}

หากต้องการดูโปรไฟล์ที่เฉพาะเจาะจงโดยใช้ชื่อ ให้ใช้ getPictureProfile()

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.BAKLAVA) {
    val profile = mediaQualityManager.getPictureProfile(
        PictureProfile.TYPE_SYSTEM, NAME_SPORTS, null)
}

หากไม่จําเป็นต้องค้นหาว่าโปรไฟล์พร้อมใช้งานหรือไม่ คุณสามารถระบุโปรไฟล์โดยใช้รหัสกับ MediaCodec ได้โดยตรงโดยใช้ MediaFormat.KEY_PICTURE_PROFILE_INSTANCE

แม้ว่าโปรไฟล์ที่รองรับอาจแตกต่างกันไปตามอุปกรณ์ แต่คุณอาจลองจับคู่กับรหัสโปรไฟล์ระบบที่ทราบต่อไปนี้

const val NAME_STANDARD: String = "standard"
const val NAME_VIVID: String = "vivid"
const val NAME_SPORTS: String = "sports"
const val NAME_GAME: String = "game"
const val NAME_MOVIE: String = "movie"
const val NAME_ENERGY_SAVING: String = "energy_saving"
const val NAME_USER: String = "user"