Unleashing Creativity with Custom Modifiers in Android Jetpack Compose | by Nirbhay Pherwani | Aug, 2023
Mobile App Development
0
Example 1 — Gradient Background Modifier
Create a custom modifier that applies a gradient background to a composable. This can be used to provide a consistent visual theme across your app’s components.
fun Modifier.gradientBackground(colors: List<Color>): Modifier = composed {
drawWithContent {
drawRect(
brush = Brush.verticalGradient(colors),
size = size
)
drawContent()
}
}
Usage —
Column(
modifier = Modifier
.gradientBackground(listOf(Color.Blue, Color.Green, Color.White))
.fillMaxSize(),
horizontalAlignment = Alignment.CenterHorizontally,
verticalArrangement = Arrangement.Center,
) {
Text("Custom modifier was applied on me!")
}
Example 2 — Aspect Ratio Modifier
Design a custom modifier that enforces a specific aspect ratio for an image. This ensures that images maintain a consistent look across various screens.
fun Modifier.aspectRatio(ratio: Float): Modifier = composed {
layout { measurable, constraints ->
val width = constraints.maxWidth
val height = (width / ratio).toInt()
val placeable = measurable.measure(
constraints.copy(minHeight = height, maxHeight = height)
)
layout(width, height) {
placeable.place(0, 0)
}
}
}
Usage —
Image(
painter = painterResource(id = R.drawable.stock_wallapaper),
contentDescription = null,
modifier = Modifier
.aspectRatio(16/9f)
.fillMaxWidth(), // modify as needed
contentScale = ContentScale.Crop
)
Some more example ideas for custom modifiers —
- Elevation Modifier: Apply elevation to a composable, giving it a subtle shadow for a sense of depth.
- Underline Modifier: Add an underline to a text composable, creating emphasis.
- Circular Progress Modifier: Display a circular progress indicator around a composable.
- Image Tint Modifier: Change the tint color of an image to match your app’s color scheme.
- Parallax Scroll Modifier: Apply a parallax effect to a composable when it’s scrolled.
- Slidable Modifier: Create a slidable panel effect for a composable, revealing hidden content.
- Custom Border Modifier: Add a customized border to a composable, with options for width, color, and shape.
- Animated Scale Modifier: Apply a scaling animation to a composable to enhance interaction.
- Loading State Modifier: Modify a composable to display a loading state with a progress indicator.
Here’s another custom modifier just for the fun of it!
Related Posts
Leave a Reply Cancel reply
Categories
- ! Без рубрики (1)
- ++PU (1)
- 1 (1)
- 1w (1)
- 1win Brazil (1)
- 1win India (1)
- 1WIN Official In Russia (1)
- 1win Turkiye (1)
- 1xbet egypt (1)
- 2ankarafayansustasi.net_may (1)
- ankarafayansustasi.netsiteai apr (1)
- Artificial intelligence (1)
- Arts & Entertainment, Photography (1)
- belugasitesi_mAY (1)
- BH_TOPsitesi apr (1)
- BHsitesy_may (2)
- Blog (3)
- Bookkeeping (14)
- Bootcamp de programação (2)
- Bootcamp de programación (2)
- BT_TOPsitesi apr (1)
- casino (5)
- casinom-hub (1)
- casinom-hub.comsitesi apr (3)
- colombian mail order brides (1)
- Cryptocurrency exchange (2)
- Dinamobet_next (1)
- Disease & Illness, Colon Cancer (1)
- Dumanbet (1)
- Dumanbet_next (1)
- Finance, Insurance (1)
- FinTech (5)
- Forex Trading (11)
- Galabet (1)
- Health & Fitness, Fitness Equipment (1)
- Hitbet (1)
- Home & Family, Crafts (1)
- Home & Family, Gardening (1)
- Internet Business, Audio-Video Streaming (1)
- Internet Business, Ecommerce (1)
- Internet Business, Email Marketing (1)
- Internet Business, Internet Marketing (1)
- IT Вакансії (1)
- IT Образование (5)
- IT Освіта (1)
- latin women dating (1)
- mail order bride (1)
- Mars bahis (2)
- Matadorbet (1)
- minimiri.comsitesi apr (3)
- Mobile App Development (771)
- Mostbet Russia (1)
- New Post (1)
- News (1)
- PB_TOPsitesi apr (1)
- PBsitesi_may (1)
- Pusulabet (1)
- redmirepool.bizsitesi apr (2)
- redmirepoolsitesi_may (1)
- Reference & Education, College (1)
- Reference & Education, Sociology (1)
- Rokusitesi apr (1)
- Sober living (6)
- Society, Divorce (1)
- Software development (7)
- Superbetin (1)
- Tempobet_next (1)
- thelongeststride.comsitesi apr (1)
- tipobet-turkiyesitesi apr (1)
- Ultrabet (1)
- Uncategorized (1)
- Игра (2)
- казино (1)
- Криптовалюты (1)
- Новости Криптовалют (1)
- Финтех (7)
- Форекс Брокеры (9)
- Форекс обучение (2)