- Welcome
- Getting started
- Foundations
-
Components
- Accordion
- Alert
- Alignment
- Aria Live
- Autosuggest
- Badge
- Banner Alert
- Bar Chart
- Blockquote
- Bottom Navigation
- Bottom Sheet
- Breadcrumb
- Breakpoint
- Button
- Calendar
- Card
- Card Button
- Carousel
- Checkbox
- Chip
- Code
- Content Cards
- Data Table
- Datepicker
- Description List
- Dialog
- Divider
- Drawer
- Field Set
- Flare
- Flat List
- Flight Leg
- Floating Action Button
- Floating Notification
- Form Label
- Form Validation
- Graphic Promotion
- Horizontal Navigation
- Icon
- Image
- Infinite Scroll
- Link
- List
- Map
- Mobile Scroll Container
- Modal
- Navigation Bar
- Nudger
- Overlay
- Page Indicator
- Pagination
- Panel
- Phone Input
- Picker
- Popover
- Price
- Progress Bar
- Radio Button
- Rating
- Scrollable Calendar
- Section List
- Select
- Skeleton
- Skip Link
- Slider
- Snackbar
- Spinner
- Split Input
- Star Rating
- Switch
- Table
- Text
- Text Input
- Theming
- Ticket
- Toast
- Tooltip
- Touchable Native Feedback
- Touchable Overlay
- Content
- Accessibility
Carousel
The carousel component allows a series of content to cycle horizontally.
Carousel
Default
Day | Night |
---|---|
![]() |
![]() |
Installation
Backpack Compose is available through Maven Central. Check the main Readme for a complete installation guide.
Usage
Example of a Carousel:
import net.skyscanner.backpack.compose.carousel.BpkCarousel
import net.skyscanner.backpack.compose.carousel.rememberBpkCarouselState
// show carousel with image index 1
val state = rememberBpkCarouselState(totalImages = totalImages)
BpkCarousel(state){ index ->
Image(painter = painterResource(id = imageResAtIndex(index)), contentDescription = "")
}
Example of a image changed callback:
import androidx.compose.runtime.LaunchedEffect
import net.skyscanner.backpack.compose.carousel.BpkCarousel
import net.skyscanner.backpack.compose.carousel.rememberBpkCarouselState
val state = rememberBpkCarouselState(totalImages = totalImages)
LaunchedEffect(state.currentPage) {
print("current page: ${state.currentPage}")
}
BpkCarousel(state) { index ->
Image(painter = painterResource(id = imageResAtIndex(index)), contentDescription = "")
}
Example of starting in a different image:
import net.skyscanner.backpack.compose.carousel.BpkCarousel
import net.skyscanner.backpack.compose.carousel.rememberBpkCarouselState
// show carousel with image index 1
val state = rememberBpkCarouselState(totalImages = totalImages, currentImage = currentImage)
BpkCarousel(state) { index ->
Image(painter = painterResource(id = imageResAtIndex(index)), contentDescription = "")
}
Made with ❤️ by Skyscanner © 2023
© 2023 Skyscanner Backpack. Page last updated on Mar 2, 2023, 09:22