คุณปรับแต่งรูปภาพได้โดยใช้พร็อพเพอร์ตี้ในImage
คอมโพสิเบิล (contentScale
, colorFilter
) นอกจากนี้ คุณยังใช้ Modifiers
ที่มีอยู่เพื่อใช้เอฟเฟกต์ต่างๆ กับ Image
ได้ด้วย คุณสามารถใช้ตัวแก้ไขในคอมโพสิเบิลใดก็ได้ ไม่ใช่แค่คอมโพสิเบิล Image
ส่วน contentScale
และ colorFilter
นั้นเป็นพารามิเตอร์ที่ชัดเจนในคอมโพสิเบิล Image
ขนาดเนื้อหา
ระบุตัวเลือก contentScale
เพื่อครอบตัดหรือเปลี่ยนวิธีปรับขนาดรูปภาพภายในขอบเขต โดยค่าเริ่มต้น หากคุณไม่ได้ระบุตัวเลือก contentScale
ระบบจะใช้ ContentScale.Fit
ในตัวอย่างด้านล่าง คอมโพสิชันรูปภาพถูกจำกัดให้มีขนาด 150dp พร้อมเส้นขอบ และพื้นหลังเป็นสีเหลืองในคอมโพสิชัน Image
เพื่อแสดงตัวเลือก ContentScale
ต่างๆ ในตารางด้านล่าง
val imageModifier = Modifier .size(150.dp) .border(BorderStroke(1.dp, Color.Black)) .background(Color.Yellow) Image( painter = painterResource(id = R.drawable.dog), contentDescription = stringResource(id = R.string.dog_content_description), contentScale = ContentScale.Fit, modifier = imageModifier )
การตั้งค่าตัวเลือก ContentScale
ที่แตกต่างกันจะให้ผลลัพธ์ที่แตกต่างกัน ตารางด้านล่างจะช่วยคุณเลือกโหมด ContentScale
ที่ถูกต้อง
รูปภาพต้นฉบับ |
![]() |
![]() |
ContentScale |
ผลลัพธ์ - รูปภาพแนวตั้ง | ผลลัพธ์ - รูปภาพแนวนอน |
ContentScale.Fit : ปรับขนาดรูปภาพให้เท่าๆ กันโดยคงสัดส่วนภาพไว้ (ค่าเริ่มต้น) หากเนื้อหามีขนาดเล็กกว่าขนาด ระบบจะปรับขนาดรูปภาพให้พอดีกับขอบเขต |
![]() |
![]() |
ContentScale.Crop : ครอบตัดรูปภาพให้อยู่ตรงกลางพื้นที่ว่าง |
![]() |
![]() |
ContentScale.FillHeight : ปรับขนาดแหล่งที่มาโดยรักษาสัดส่วนการแสดงผลไว้เพื่อให้ขอบเขตตรงกับความสูงของปลายทาง |
![]() |
![]() |
ContentScale.FillWidth : ปรับขนาดแหล่งที่มาโดยรักษาสัดส่วนการแสดงผลไว้เพื่อให้ขอบเขตตรงกับความกว้างของปลายทาง |
![]() |
![]() |
ContentScale.FillBounds : ปรับขนาดเนื้อหาในแนวตั้งและแนวนอนอย่างไม่สม่ำเสมอเพื่อให้พอดีกับขอบเขตปลายทาง (หมายเหตุ: การดำเนินการนี้จะบิดเบือนรูปภาพหากคุณวางรูปภาพไว้ในคอนเทนเนอร์ที่ไม่ตรงกับสัดส่วนรูปภาพ) |
![]() |
![]() |
ContentScale.Inside : ปรับขนาดแหล่งที่มาเพื่อรักษาสัดส่วนการแสดงผลภายในขอบเขตปลายทาง หากแหล่งที่มามีขนาดเล็กกว่าหรือเท่ากับปลายทางในทั้ง 2 มิติ การดำเนินการจะคล้ายกับ "ไม่มี" เนื้อหาจะอยู่ในขอบเขตเสมอ หากเนื้อหามีขนาดเล็กกว่าขอบเขต ระบบจะไม่ปรับขนาด |
รูปภาพต้นทางใหญ่กว่าขอบเขต
![]() ![]() |
รูปภาพต้นทางใหญ่กว่าขอบเขต
![]() ![]() |
ContentScale.None : ไม่ใช้การปรับขนาดกับแหล่งที่มา หากเนื้อหามีขนาดเล็กกว่าขอบเขตปลายทาง ระบบจะไม่ปรับขนาดเนื้อหาให้พอดีกับพื้นที่ |
รูปภาพต้นทางใหญ่กว่าขอบเขต
![]() ![]() |
รูปภาพต้นทางใหญ่กว่าขอบเขต
![]() ![]() |
คลิปคอมโพสิชัน Image
ลงในรูปร่าง
หากต้องการปรับรูปภาพให้พอดีกับรูปร่าง ให้ใช้ตัวแก้ไข clip
ในตัว
หากต้องการครอบตัดรูปภาพเป็นรูปร่างวงกลม ให้ใช้ Modifier.clip(CircleShape)
โดยทำดังนี้
Image( painter = painterResource(id = R.drawable.dog), contentDescription = stringResource(id = R.string.dog_content_description), contentScale = ContentScale.Crop, modifier = Modifier .size(200.dp) .clip(CircleShape) )
data:image/s3,"s3://crabby-images/48507/48507b9a68528f9fcf0c16af97f63c2a7df74988" alt="การตัดรูปภาพด้วย CircleShape"
รูปร่างของมุมที่โค้งมน - ใช้ Modifier.clip(RoundedCornerShape(16.dp)
) พร้อมขนาดของมุมที่ต้องการให้โค้งมน
Image( painter = painterResource(id = R.drawable.dog), contentDescription = stringResource(id = R.string.dog_content_description), contentScale = ContentScale.Crop, modifier = Modifier .size(200.dp) .clip(RoundedCornerShape(16.dp)) )
data:image/s3,"s3://crabby-images/580c2/580c2c926c472fa0e47630916c3bce2d5563f268" alt="การตัดรูปภาพด้วย RoundedCornerShape"
นอกจากนี้ คุณยังสร้างรูปร่างการครอบตัดของคุณเองได้ด้วยโดยการขยาย Shape
และระบุ Path
สำหรับรูปร่างที่จะครอบตัด
class SquashedOval : Shape { override fun createOutline( size: Size, layoutDirection: LayoutDirection, density: Density ): Outline { val path = Path().apply { // We create an Oval that starts at ¼ of the width, and ends at ¾ of the width of the container. addOval( Rect( left = size.width / 4f, top = 0f, right = size.width * 3 / 4f, bottom = size.height ) ) } return Outline.Generic(path = path) } } Image( painter = painterResource(id = R.drawable.dog), contentDescription = stringResource(id = R.string.dog_content_description), contentScale = ContentScale.Crop, modifier = Modifier .size(200.dp) .clip(SquashedOval()) )
data:image/s3,"s3://crabby-images/1bfbd/1bfbd8fe5794507a62bcfe68b9e1e7a9dba6d151" alt="การตัดรูปภาพด้วยรูปร่างเส้นทางที่กำหนดเอง"
เพิ่มเส้นขอบให้กับคอมโพสิเบิล Image
การดำเนินการทั่วไปคือการรวม Modifier.border()
เข้ากับ Modifier.clip()
เพื่อสร้างเส้นขอบรอบรูปภาพ
val borderWidth = 4.dp Image( painter = painterResource(id = R.drawable.dog), contentDescription = stringResource(id = R.string.dog_content_description), contentScale = ContentScale.Crop, modifier = Modifier .size(150.dp) .border( BorderStroke(borderWidth, Color.Yellow), CircleShape ) .padding(borderWidth) .clip(CircleShape) )
data:image/s3,"s3://crabby-images/5d9c6/5d9c64d7371fa05dba811c30d0049c4d53d3e9d0" alt="ตัดรูปภาพและใส่เส้นขอบรอบๆ"
หากต้องการสร้างเส้นขอบไล่ระดับสี ให้ใช้ Brush
API เพื่อวาดเส้นขอบไล่ระดับสีรุ้งรอบรูปภาพ โดยทำดังนี้
val rainbowColorsBrush = remember { Brush.sweepGradient( listOf( Color(0xFF9575CD), Color(0xFFBA68C8), Color(0xFFE57373), Color(0xFFFFB74D), Color(0xFFFFF176), Color(0xFFAED581), Color(0xFF4DD0E1), Color(0xFF9575CD) ) ) } val borderWidth = 4.dp Image( painter = painterResource(id = R.drawable.dog), contentDescription = stringResource(id = R.string.dog_content_description), contentScale = ContentScale.Crop, modifier = Modifier .size(150.dp) .border( BorderStroke(borderWidth, rainbowColorsBrush), CircleShape ) .padding(borderWidth) .clip(CircleShape) )
data:image/s3,"s3://crabby-images/1c38b/1c38b26de63bce3d2f8b1829e77b232d80721ff8" alt="เส้นขอบวงกลมไล่ระดับสีรุ้ง"
กำหนดสัดส่วนภาพที่กำหนดเอง
หากต้องการเปลี่ยนรูปภาพเป็นสัดส่วนภาพที่กําหนดเอง ให้ใช้ Modifier.aspectRatio(16f/9f)
เพื่อระบุสัดส่วนที่กำหนดเองสำหรับรูปภาพ (หรือคอมโพสิชันใดก็ได้สำหรับการดำเนินการนี้)
Image( painter = painterResource(id = R.drawable.dog), contentDescription = stringResource(id = R.string.dog_content_description), modifier = Modifier.aspectRatio(16f / 9f) )
data:image/s3,"s3://crabby-images/c4a57/c4a57d73155b234fb3797424b1f5972b37939037" alt="การใช้ Modifier.aspectRatio(16f/9f) ในรูปภาพ"
Modifier.aspectRatio(16f/9f)
ในรูปภาพตัวกรองสี - เปลี่ยนสีพิกเซลของรูปภาพ
องค์ประกอบรูปภาพมีพารามิเตอร์ colorFilter
ที่สามารถเปลี่ยนเอาต์พุตของพิกเซลแต่ละพิกเซลของรูปภาพ
การใส่สีในรูปภาพ
การใช้ ColorFilter.tint(color, blendMode)
จะใช้โหมดผสมผสานกับสีที่ระบุในคอมโพสิชัน Image
ColorFilter.tint(color, blendMode)
ใช้ BlendMode.SrcIn
เพื่อปรับสีเนื้อหา ซึ่งหมายความว่าระบบจะแสดงสีที่ระบุไว้เมื่อภาพแสดงบนหน้าจอ ซึ่งมีประโยชน์สำหรับไอคอนและเวกเตอร์ที่ต้องจัดธีมแตกต่างกัน
Image( painter = painterResource(id = R.drawable.baseline_directions_bus_24), contentDescription = stringResource(id = R.string.bus_content_description), colorFilter = ColorFilter.tint(Color.Yellow) )
data:image/s3,"s3://crabby-images/4298a/4298aaf9bc853ea44a2f1fc7f87fc8c190ef0663" alt="ใช้ ColorFilter.tint กับ BlendMode.SrcIn"
BlendMode
อื่นๆ จะทำให้เกิดผลลัพธ์ที่แตกต่างกัน ตัวอย่างเช่น การตั้งค่า BlendMode.Darken
ด้วย Color.Green
ในรูปภาพจะให้ผลลัพธ์ดังต่อไปนี้
Image( painter = painterResource(id = R.drawable.dog), contentDescription = stringResource(id = R.string.dog_content_description), colorFilter = ColorFilter.tint(Color.Green, blendMode = BlendMode.Darken) )
data:image/s3,"s3://crabby-images/815a5/815a5ed87a80ab8ba660d3e6e403c0504d8dc586" alt="Color.Green tint with BlendMode.Darken"
ดูข้อมูลเพิ่มเติมเกี่ยวกับโหมดการผสมต่างๆ ที่มีได้ในเอกสารอ้างอิงเกี่ยวกับ BlendMode
การใช้ฟิลเตอร์ Image
กับเมทริกซ์สี
เปลี่ยนรูปภาพโดยใช้ตัวเลือกเมตริกซ์สี ColorFilter
เช่น หากต้องการใช้ฟิลเตอร์ขาวดำกับรูปภาพ คุณอาจใช้ ColorMatrix
และตั้งค่าความอิ่มตัวเป็น 0f
Image( painter = painterResource(id = R.drawable.dog), contentDescription = stringResource(id = R.string.dog_content_description), colorFilter = ColorFilter.colorMatrix(ColorMatrix().apply { setToSaturation(0f) }) )
data:image/s3,"s3://crabby-images/5058e/5058e19afbacfef99150d22db2dd3fe81d700249" alt="เมตริกซ์สีที่มีความอิ่มตัว 0 (รูปภาพขาวดํา)"
ปรับคอนทราสต์หรือความสว่างของImage
คอมโพส
หากต้องการเปลี่ยนคอนทราสต์และความสว่างของรูปภาพ ให้ใช้ ColorMatrix
เพื่อเปลี่ยนค่า ดังนี้
val contrast = 2f // 0f..10f (1 should be default) val brightness = -180f // -255f..255f (0 should be default) val colorMatrix = floatArrayOf( contrast, 0f, 0f, 0f, brightness, 0f, contrast, 0f, 0f, brightness, 0f, 0f, contrast, 0f, brightness, 0f, 0f, 0f, 1f, 0f ) Image( painter = painterResource(id = R.drawable.dog), contentDescription = stringResource(id = R.string.dog_content_description), colorFilter = ColorFilter.colorMatrix(ColorMatrix(colorMatrix)) )
data:image/s3,"s3://crabby-images/8a5dc/8a5dc0a29f845d377123b1f3f11340a5876730f5" alt="ปรับความสว่างและคอนทราสต์ของรูปภาพโดยใช้ ColorMatrix"
กลับค่าสีของคอมโพสิชัน Image
หากต้องการกลับสีของรูปภาพ ให้ตั้งค่า ColorMatrix
เพื่อกลับสี ดังนี้
val colorMatrix = floatArrayOf( -1f, 0f, 0f, 0f, 255f, 0f, -1f, 0f, 0f, 255f, 0f, 0f, -1f, 0f, 255f, 0f, 0f, 0f, 1f, 0f ) Image( painter = painterResource(id = R.drawable.dog), contentDescription = stringResource(id = R.string.dog_content_description), colorFilter = ColorFilter.colorMatrix(ColorMatrix(colorMatrix)) )
data:image/s3,"s3://crabby-images/d2045/d204500f0492d28817514d003d0f1a5646f55ddd" alt="สีสลับกันในรูปภาพ"
เบลอคอมโพสิชัน Image
หากต้องการเบลอรูปภาพ ให้ใช้ Modifier.blur()
โดยระบุ radiusX
และ radiusY
ซึ่งจะระบุรัศมีเบลอในแนวนอนและแนวตั้งตามลำดับ
Image( painter = painterResource(id = R.drawable.dog), contentDescription = stringResource(id = R.string.dog_content_description), contentScale = ContentScale.Crop, modifier = Modifier .size(150.dp) .blur( radiusX = 10.dp, radiusY = 10.dp, edgeTreatment = BlurredEdgeTreatment(RoundedCornerShape(8.dp)) ) )
data:image/s3,"s3://crabby-images/1ad95/1ad95fd875dd6eddb0293430a04adc37920fae3f" alt="ใช้ BlurEffect กับรูปภาพ"
เมื่อเบลอ Images
เราขอแนะนำให้ใช้ BlurredEdgeTreatment(Shape)
แทน BlurredEdgeTreatment.Unbounded
เนื่องจาก BlurredEdgeTreatment.Unbounded
ใช้สำหรับการเบลอการแสดงผลแบบกำหนดเองที่คาดว่าจะแสดงผลนอกขอบเขตของเนื้อหาต้นฉบับ สำหรับรูปภาพ รูปภาพจะไม่แสดงผลนอกขอบเขตของเนื้อหา แต่การเบลอสี่เหลี่ยมผืนผ้ามนอาจต้องใช้การแยกความแตกต่างนี้
ตัวอย่างเช่น หากตั้งค่า BlurredEdgeTreatment
เป็น "ไม่จำกัด" ในรูปภาพด้านบน ขอบของรูปภาพจะเบลอแทนที่จะคมชัด
Image( painter = painterResource(id = R.drawable.dog), contentDescription = stringResource(id = R.string.dog_content_description), contentScale = ContentScale.Crop, modifier = Modifier .size(150.dp) .blur( radiusX = 10.dp, radiusY = 10.dp, edgeTreatment = BlurredEdgeTreatment.Unbounded ) .clip(RoundedCornerShape(8.dp)) )
data:image/s3,"s3://crabby-images/dbe6c/dbe6ceb8e2975f1de237866225a5f79199ba26c3" alt="BlurEdgeTreatment.Unbounded"
แนะนำสำหรับคุณ
- หมายเหตุ: ข้อความลิงก์จะแสดงเมื่อ JavaScript ปิดอยู่
- ตัวแก้ไขกราฟิก
- กำลังโหลดรูปภาพ {:#loading-images}
- ไอคอน Material {:#material-icons}