เมื่อสร้างภาพเคลื่อนไหวขององค์ประกอบที่แชร์ จะมีกรณีการใช้งานบางอย่างที่มีคำแนะนำเฉพาะ
รูปภาพแบบอะซิงโครนัส
โดยทั่วไปแล้ว เรามักจะใช้ไลบรารีเพื่อโหลดรูปภาพแบบอะซิงโครนัส เช่น เมื่อ
ใช้ คอมโพสได้ AsyncImage ของ Coil
เพื่อให้ทำงานได้อย่างราบรื่นระหว่างคอมโพสได้ 2 รายการ เราขอแนะนำให้ตั้งค่า placeholderMemoryCacheKey() และ memoryCacheKey() เป็นคีย์เดียวกันกับสตริงที่ได้จากคีย์ขององค์ประกอบที่แชร์ เพื่อให้คีย์แคชเหมือนกันสำหรับองค์ประกอบที่แชร์ที่ตรงกัน องค์ประกอบที่แชร์ใหม่จะใช้แคชขององค์ประกอบที่ตรงกันเป็นตัวยึดตำแหน่งจนกว่าจะโหลดรูปภาพใหม่
การใช้งาน AsyncImage โดยทั่วไปมีดังนี้
AsyncImage( model = ImageRequest.Builder(LocalContext.current) .data("your-image-url") .crossfade(true) .placeholderMemoryCacheKey("image-key") // same key as shared element key .memoryCacheKey("image-key") // same key as shared element key .build(), placeholder = null, contentDescription = null, modifier = Modifier .size(120.dp) .sharedBounds( rememberSharedContentState( key = "image-key" ), animatedVisibilityScope = this ) )
ข้อความ
หากต้องการสร้างภาพเคลื่อนไหวของการเปลี่ยนแปลง fontSize ให้ใช้ Modifier.sharedBounds(), resizeMode =
ScaleToBounds() การเปลี่ยนภาพนี้จะทำให้การเปลี่ยนแปลงขนาดดูราบรื่น คุณปรับพารามิเตอร์ contentScale เพื่อสร้างภาพเคลื่อนไหวของน้ำหนักหรือรูปแบบฟอนต์ที่เฉพาะเจาะจงได้
Text( text = "This is an example of how to share text", modifier = Modifier .wrapContentWidth() .sharedBounds( rememberSharedContentState( key = "shared Text" ), animatedVisibilityScope = this, enter = fadeIn(), exit = fadeOut(), resizeMode = SharedTransitionScope.ResizeMode.scaleToBounds() ) )
ระบบจะไม่ สร้างภาพเคลื่อนไหวของการเปลี่ยนแปลง TextAlign โดยค่าเริ่มต้น แต่ให้ใช้ Modifier.wrapContentSize() หรือ Modifier.wrapContentWidth() แทนการใช้ TextAlign ที่แตกต่างกันสำหรับการเปลี่ยนภาพที่แชร์