Skip to content

Instantly share code, notes, and snippets.

@matinnasiri01
Created June 4, 2024 18:37
Show Gist options
  • Save matinnasiri01/3e6372a0fb67b118fb45f13f1d6f4aef to your computer and use it in GitHub Desktop.
Save matinnasiri01/3e6372a0fb67b118fb45f13f1d6f4aef to your computer and use it in GitHub Desktop.
This code creates a horizontal slider in Jetpack Compose that automatically and cyclically scrolls, adjusting item transparency based on their position.
/*
Matin Nasiri
mnasirii829@gmail.com
https:linkedin.com/in/matinnasiri01
I hope you are well when you read this file
*/
import androidx.compose.foundation.ExperimentalFoundationApi
import androidx.compose.foundation.layout.Box
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.PaddingValues
import androidx.compose.foundation.layout.fillMaxSize
import androidx.compose.foundation.layout.fillMaxWidth
import androidx.compose.foundation.layout.height
import androidx.compose.foundation.layout.padding
import androidx.compose.foundation.layout.width
import androidx.compose.foundation.pager.HorizontalPager
import androidx.compose.foundation.pager.rememberPagerState
import androidx.compose.foundation.shape.RoundedCornerShape
import androidx.compose.material3.Text
import androidx.compose.runtime.Composable
import androidx.compose.runtime.LaunchedEffect
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.draw.clip
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.graphics.graphicsLayer
import androidx.compose.ui.layout.ContentScale
import androidx.compose.ui.text.font.FontWeight
import androidx.compose.ui.unit.dp
import androidx.compose.ui.unit.sp
import androidx.compose.ui.util.lerp
import coil.compose.AsyncImage
import kotlinx.coroutines.delay
import me.nasiri.core.data.model.MovieModel
@Composable
@OptIn(ExperimentalFoundationApi::class)
fun PreviewSlider(list: List</* todo */>, modifier: Modifier = Modifier) {
val state = rememberPagerState { list.size }
// Auto-scrolling effect
LaunchedEffect(state) {
while (true) {
yield()
delay(3000)
val nextPage = (state.currentPage + 1) % list.size
state.animateScrollToPage(nextPage)
}
}
Column(modifier = modifier.fillMaxWidth()) {
HorizontalPager(state = state, contentPadding = PaddingValues(horizontal = 45.dp)) { page ->
SliderItem(
item = list[page % list.size],
modifier = Modifier.graphicsLayer {
val pageOffset = state.getOffsetFractionForPage(page).coerceIn(-1f, 1f)
alpha = lerp(
start = 0.4f,
stop = 1f,
fraction = 1f - kotlin.math.abs(pageOffset)
)
}
)
}
}
}
@Composable
fun SliderItem(item: /* todo */, modifier: Modifier = Modifier) {
Box(
modifier = modifier
.width(440.dp)
.height(200.dp)
.padding(horizontal = 8.dp)
) {
AsyncImage(
modifier = Modifier
.fillMaxSize()
.clip(RoundedCornerShape(16.dp)),
model = item.backdropPath,
contentScale = ContentScale.Crop,
contentDescription = "Image"
)
Text(
text = item.title!!,
fontSize = 20.sp,
fontWeight = FontWeight.Bold, color = Color.White,
modifier = Modifier
.align(Alignment.BottomStart)
.padding(8.dp)
)
Text(
text = item.releaseDate?.take(4)!!,
fontSize = 16.sp,
fontWeight = FontWeight.Bold, color = Color.White,
modifier = Modifier
.align(Alignment.TopEnd)
.padding(8.dp)
)
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment