Jetpack-Compose-Tutorials
Jetpack-Compose-Tutorials copied to clipboard
🚀🧨📝 Series of Tutorials to learn about Jetpack Compose with subjects Material Widgets, Layout, SubcomposeLayout, custom layouts, State, custom rememberable, recomposition, LaunchedEffect, side-effe...
Jetpack Compose Tutorials and Playground
🤓 Overview
Series of Tutorials to learn about Jetpack Compose, Material Widgets, State, Animation, and Navigation. Easy to search in code and in app. Each chapter module contains its own content in code. SearchBar can be used to search with a tag or description available for each tutorial.
Recommended section is under constructions for now, when finished it will get recommended tags using previous searches using a database, domain with ViewModel.
data:image/s3,"s3://crabby-images/9e653/9e6534fcc0fe92cfadaa2fd87612fddab490fa6e" alt=""
Tutorial | Preview |
---|---|
1-1 Column, Row, Box, ModifiersCreate Row that adds elements in horizontal order, and Column that adds elements in vertical order. • Column • Row • Box • Modifier |
![]() |
1-2 Surface, Shape, ClickableCreate and modify Surface to draw background for Composables, add click action to any composable. Set weight or offset modifiers. • Surface • Shape • Clickable |
![]() |
Material Widgets
Tutorial | Preview |
---|---|
2-1 TextCreate Text component with different properties such as color, background, font weight, family, style, spacing and others • Text • Row • FontStyle • Annotated String Hyperlink |
![]() |
2-2 Button, IconButton, FAB, ChipCreate button with text and/or with image, Floating Action Button or Chips. Modify properties of buttons including color, text, and click actions. • Button • IconButton • FloatingActionButton • Chip |
![]() |
2-3 TextFieldCreate TextField component with regular style or outlined. Set error, colors, state, icons, and IME actions. • TextField • OutlinedTextField • IME • Phone format VisualTransformation • Regex |
![]() |
2-4 ImageCreate Image with image, vector resource or with Painter, set image and Content scales to fit, expand or shrink image. Change shape of Image or apply ColorFilter and PorterDuff modes. • Image • Canvas • Drawable • Bitmap |
![]() |
2-5 LazyColumn/Row/VerticalGridVertical, horizontal grid lists with LazyColumn, LazyRow and LazyVerticalGrid. Use contentPadding set paddings for lists, verticalArrangement or horizontalArrangement for padding between items, rememberLazyListState to manually scroll. • LazyColumn(Vertical RecyclerView) • LazyRow(Horizontal RecyclerView • LazyVerticalGrid(GridLayout) • StickyHeaders |
![]() |
2-6 TopAppbar & TabTopAppbar with actions, overflow menus. Tabs with text only, image only and image+text with different background, divider, and indicators. • TopAppBar • Overflow menu • TabRow and Tab • Tab Indicator, Divider |
![]() |
2-7 BottomNavigationBottom navigation bars allow movement between primary destinations in an app. BottomNavigation should contain multiple BottomNavigationItems, each representing a singular destination. • BottomNavigation • BottomNavigationItem |
![]() |
2-8 BottomAppBarA bottom app bar displays navigation and key actions at the bottom of screens. • BottomAppBar • Scaffold |
![]() |
2-9-1 Side NavigationA backdrop appears behind all other surfaces in an app, displaying contextual and actionable content. • Scaffold • Side Navigation • DrawerState |
![]() |
2-9-2 ModalDrawerModal navigation drawers block interaction with the rest of an app’s content with a scrim. They are elevated above most of the app’s UI and don’t affect the screen’s layout grid. • ModalDrawer • DrawerState • Scaffold |
![]() |
2-10-1 BottomSheetCreate bottom sheet using BottomSheetScaffold and rememberBottomSheetScaffoldState, create modal bottom sheets. • BottomSheetScaffold • BottomSheetState • ModalBottomSheetLayout |
![]() |
2-10-4 BottomDrawerBottomDrawer with BottomAppBar. • BottomDrawer • BottomAppBar • Scaffold |
![]() |
2-10-5 BackdropScaffoldBackdropScaffold provides an API to put together several material components to construct your screen. |
![]() |
2-11 Snackbar, Progress, SelectionCreate Snackbars with various layouts and styling, Checkboxes with selectable text, tri state checkbox, grouped radio buttons and sliders. • SnackBar • ProgressIndicator • Checkbox • TriStateCheckbox • Switch • RadioButton • Slider • RangeSlider |
![]() |
2-12 Dialog, AlertDialogCreate Dialog, and AlertDialog with standard and custom layouts. Implement on dismiss logic and get result when dialog is closed. • AlertDialog • Dialog • DialogProperties |
![]() |
Layout
Tutorial | Preview |
---|---|
3-1-1 Custom ModifierCreate custom layout using using layout, Measurable, Constraint, Placeable. • Custom Modifier • Measurable • Constraint • Placeable |
![]() |
3-1-3 graphicsLayerUse Modifier.offset{} and Modifier.graphicsLayer{} to scale, translate or change other properties of a Composable. • Modifier • graphicsLayer |
![]() |
3-2-1 Custom LayoutCreate custom layout using using MeasurePolicy and use intrinsic dimensions. • Custom Layout • Measurable • Constraint • Placeable |
![]() |
3-3-1 Scope&ParentDataModifierAdd custom modifiers to Composable inside a custom layout using its scope like align modifier only available in specific Composable like a custom Column. • Custom Layout • Scope • ParentDataModifier • Measurable • Constraint • Placeable |
![]() |
3-4 BoxWithConstraintsBoxWithConstraints is a composable that defines its own content according to the available space, based on the incoming constraints or the current LayoutDirection. • BoxWithConstraints • Constraint |
![]() |
3-5 SubcomposeLayoutSubcompose layout which allows to subcompose the actual content during the measuring stage for example to use the values calculated during the measurement as params for the composition of the children. • SubcomposeLayout • Constraint • Measurable • Constraint • Placeable |
![]() |
3-6-1 Custom Chat Layouts1Custom layout like whatsapp chat layout that moves time and message read status layout right or bottom based on message width. • Custom Layout • Measurable • Constraint • Placeable |
![]() |
3-6-2 Custom Chat SubcomposeLayoutCustom layout like whatsapp chat. Added quote and name tag resized to longest sibling using SubcomposeColumn from previous examples to have whole layout. • Custom Layout • SubcomposeLayout • Measurable • Constraint • Placeable |
![]() |
State
Tutorial | Preview |
---|---|
4-1 Remember&MutableStateRemember and mutableState effect recomposition and states. • remember • State • Recomposition |
![]() |
4-2-3 Scoped RecompositionHow hierarchy of Composables effects Smart Composition. • remember • Recomposition • State |
![]() |
4-4 Custom RememberCreate a custom remember and custom component to have badge that changes its shape based on properties set by custom rememberable. • remember • State • Recomposition • Custom Layout |
![]() |
4-5-1 SideEffect1Use remember functions like rememberCoroutineScope, and rememberUpdatedState and side-effect functions such as LaunchedEffect and DisposableEffect. • remember • rememberCoroutineScope • rememberUpdatedState • LaunchedEffect • DisposableEffect |
![]() |
4-5-2 SideEffect2Use SideEffect, derivedStateOf, produceState and snapshotFlow. • remember • SideEffect • derivedStateOf • produceStateOf • snapshotFlow |
![]() |
4-7-3 Compose Phases3How deferring a state read changes which phases of frame(Composition, Layout, Draw) are called. • Modifier • Recomposition • Composition • Layout • Draw |
![]() |
Gesture
Tutorial | Preview |
---|---|
5-1-1 ClickableUse clickable modifier, Indication. Indication to clip ripples, or create custom ripple effects. • clickable • Indication • rememberRipple • pointerInput • pointerInteropFilter |
![]() |
5-1-2 InteractionSource1Use Interaction source to collect interactions or change scale of Composables based on interaction state. • clickable • InteractionSource |
![]() |
5-1-3 InteractionSource2Use InteractionSource to update touch state of multiple Composable or another Composable based on current interaction. • clickable • InteractionSource |
![]() |
5-2 Tap&Drag GestureUse PointerInput to listen press, tap, long press, drag gestures. detectTapGestures is used for listening for tap, longPress, doubleTap, and press gestures. • pointerInput • pointerInteropFilter • detectTapGestures • detectDragGestures • onPress • onDoubleTap |
![]() |
5-3 Transform GesturesUse PointerInput to listen for detectTransformGesture to get centroid, pan, zoom and rotate params. • pointerInput • detectTransformGestures • centroid • pan • zoom |
![]() |
5-4-1 AwaitPointerEventScope1Use AwaitPointerEventScope to get awaitFirstDown for down events, waitForUpOrCancellation for up events, and awaitPointerEvent for move events with pointers. • AwaitPointerEventScope • PointerInputChange • awaitFirstDown • waitForUpOrCancellation • awaitPointerEvent • awaitTouchSlopOrCancellation • awaitDragOrCancellation |
![]() |
5-4-3 Centroid, Zoom, Pan, RotationUse AwaitPointerEventScope to calculate centroid position and size, zoom, pan, and rotation. • AwaitPointerEventScope • centroid • pan • zoom |
![]() |
5-6-2 Gesture Propagation1Consume different type of touch events in Composable in an hierarchy to display gesture propagation between parent and children with MOVE gestures. • AwaitPointerEventScope • pointerInput • consume • consumePositionChange • anyChangeConsumed |
![]() |
5-6-4 Transform PropagationConsume events to rotate, zoom, move or apply drag or move events on Composables. • AwaitPointerEventScope • detectTransformGestures • consume • consumePositionChange • anyChangeConsumed • pan • zoom |
![]() |
5-9-4 Collapsing TopAppBarCreate a collapsing TopAppBar using Modifier.nestedScroll and NestedScrollConnection. • nestedScroll • NestedScrollConnection |
![]() |
5-10-1 Image Touch DetectionDetect touch position on image and get color at touch position. • Image • AwaitPointerEventScope |
![]() |
5-11 Zoomable LazyColumnZoom images inside a LazyColum. • Image • Zoom • AwaitPointerEventScope |
![]() |
Graphics
Tutorial | Preview |
---|---|
6-1-1 Canvas Basics 1Use canvas draw basic shapes like line, circle, rectangle, and points with different attributes such as style, stroke cap, brush. • Canvas • DrawScope • Path • Path Effect |
![]() |
6-1-2 Canvas Basics 2Use canvas to draw arc, with path effect, stroke cap, stroke join, miter and other attributes and draw images with src, dst attributes. • Canvas • DrawScope • Path • Path Effect |
![]() |
6-1-3 Canvas PathsUse canvas to draw path using absolute and relative positions, adding arc to path, drawing custom paths, progress, polygons, quads, and cubic. • Canvas • DrawScope • Path • Path Effect |
![]() |
6-1-4 Canvas Path OpsUse canvas to clip paths, or canvas using path, or rectangle with operations such as Difference, Intersect, Union, Xor, or ReverseDifference.. • Canvas • DrawScope • Path • PathOperation • ClipOperation |
![]() |
6-1-5 Canvas Path SegmentsUse canvas to flatten Android Path to path segments and display PathSegment start and/or end points. • Canvas • DrawScope • Path • PathSegment |
![]() |
6-1-6 Canvas PathEffectUse PathEffect such as dashedPathEffect, cornerPathEffect, chainPathEffect and stompedPathEffect to draw shapes add path effects around Composables • Canvas • DrawScope • Path • Path Effect |
![]() |
6-2 Blend(Porter-Duff) ModesUse blend(Porter-Duff) modes to change drawing source/destination or clip based on blend mode ,and manipulate pixels. • Canvas • DrawScope • Path • Path Effect • BlendMode |
![]() |
6-4-2 Drawing AppDraw to canvas using touch down, move and up events using array of paths to have erase, undo, redo actions and set properties for each path separately. • Canvas • DrawScope • Path • AwaitPointerEventScope • PointerInputChange • BlendMode |
![]() |
6-5 Color PickerColor Picker that calculates angle from center and gets a color using hue and returns a color as in HSL or RGB color model. • Canvas • DrawScope • Path • AwaitPointerEventScope • PointerInputChange • BlendMode |
![]() |
6-6 Scale/Translation EditEditable Composable that changes position and scale when touched and dragged from handles or changes position when touched inside. • Canvas • DrawScope • Scale • Translate • AwaitPointerEventScope • PointerInputChange |
![]() |
Resources and References
Codelab Jetpack Compose Basics
Codelab Jetpack Compose Layouts
Codelab Jetpack Compose States
Codelab Jetpack Compose Advanced State
Developer Android
Developer Android Material
Jetpack Compose Samples
Under the hood of Jetpack Compose — part 2 of 2- Leland Richardson
What is “donut-hole skipping” in Jetpack Compose?-Vinay Gaba
Android Graphics
Playing with Paths-Nick Butcher
Custom Shape with Jetpack Compose-Julien Salvi
Porter Duff Mode
Porter/Duff Compositing and Blend Modes
Practical Image PorterDuff Mode Usage in Android-Elye
Android Image Lighting Control and Color Filtering-Elye
Android Image Color Change With ColorMatrix-Elye
Manipulating images and Drawables with Android’s ColorFilter-Nick Rout