-
Notifications
You must be signed in to change notification settings - Fork 187
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Migrated relevant MotionCompose snippets into snippets (#411)
* Migrated relevant MotionCompose snippets into snippets * Apply Spotless --------- Co-authored-by: riggaroo <[email protected]>
- Loading branch information
Showing
14 changed files
with
1,262 additions
and
4 deletions.
There are no files selected for viewing
182 changes: 182 additions & 0 deletions
182
compose/snippets/src/main/java/com/example/compose/snippets/animations/demo/Cheese.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,182 @@ | ||
/* | ||
* Copyright 2024 The Android Open Source Project | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* https://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
*/ | ||
|
||
package com.example.compose.snippets.animations.demo | ||
|
||
import androidx.annotation.DrawableRes | ||
import com.example.compose.snippets.R | ||
|
||
val CheeseImages = listOf( | ||
R.drawable.cheese_1, | ||
R.drawable.cheese_2, | ||
R.drawable.cheese_3, | ||
R.drawable.cheese_4, | ||
R.drawable.cheese_5 | ||
) | ||
|
||
val CheeseNames = listOf( | ||
"Abbaye de Belloc", "Abbaye du Mont des Cats", "Abertam", "Abondance", "Ackawi", | ||
"Acorn", "Adelost", "Affidelice au Chablis", "Afuega'l Pitu", "Airag", "Airedale", | ||
"Aisy Cendre", "Allgauer Emmentaler", "Alverca", "Ambert", "American Cheese", | ||
"Ami du Chambertin", "Anejo Enchilado", "Anneau du Vic-Bilh", "Anthoriro", "Appenzell", | ||
"Aragon", "Ardi Gasna", "Ardrahan", "Armenian String", "Aromes au Gene de Marc", | ||
"Asadero", "Asiago", "Aubisque Pyrenees", "Autun", "Avaxtskyr", "Baby Swiss", | ||
"Babybel", "Baguette Laonnaise", "Bakers", "Baladi", "Balaton", "Bandal", "Banon", | ||
"Barry's Bay Cheddar", "Basing", "Basket Cheese", "Bath Cheese", "Bavarian Bergkase", | ||
"Baylough", "Beaufort", "Beauvoorde", "Beenleigh Blue", "Beer Cheese", "Bel Paese", | ||
"Bergader", "Bergere Bleue", "Berkswell", "Beyaz Peynir", "Bierkase", "Bishop Kennedy", | ||
"Blarney", "Bleu d'Auvergne", "Bleu de Gex", "Bleu de Laqueuille", | ||
"Bleu de Septmoncel", "Bleu Des Causses", "Blue", "Blue Castello", "Blue Rathgore", | ||
"Blue Vein (Australian)", "Blue Vein Cheeses", "Bocconcini", "Bocconcini (Australian)", | ||
"Boeren Leidenkaas", "Bonchester", "Bosworth", "Bougon", "Boule Du Roves", | ||
"Boulette d'Avesnes", "Boursault", "Boursin", "Bouyssou", "Bra", "Braudostur", | ||
"Breakfast Cheese", "Brebis du Lavort", "Brebis du Lochois", "Brebis du Puyfaucon", | ||
"Bresse Bleu", "Brick", "Brie", "Brie de Meaux", "Brie de Melun", "Brillat-Savarin", | ||
"Brin", "Brin d' Amour", "Brin d'Amour", "Brinza (Burduf Brinza)", | ||
"Briquette de Brebis", "Briquette du Forez", "Broccio", "Broccio Demi-Affine", | ||
"Brousse du Rove", "Bruder Basil", "Brusselae Kaas (Fromage de Bruxelles)", "Bryndza", | ||
"Buchette d'Anjou", "Buffalo", "Burgos", "Butte", "Butterkase", "Button (Innes)", | ||
"Buxton Blue", "Cabecou", "Caboc", "Cabrales", "Cachaille", "Caciocavallo", "Caciotta", | ||
"Caerphilly", "Cairnsmore", "Calenzana", "Cambazola", "Camembert de Normandie", | ||
"Canadian Cheddar", "Canestrato", "Cantal", "Caprice des Dieux", "Capricorn Goat", | ||
"Capriole Banon", "Carre de l'Est", "Casciotta di Urbino", "Cashel Blue", "Castellano", | ||
"Castelleno", "Castelmagno", "Castelo Branco", "Castigliano", "Cathelain", | ||
"Celtic Promise", "Cendre d'Olivet", "Cerney", "Chabichou", "Chabichou du Poitou", | ||
"Chabis de Gatine", "Chaource", "Charolais", "Chaumes", "Cheddar", | ||
"Cheddar Clothbound", "Cheshire", "Chevres", "Chevrotin des Aravis", "Chontaleno", | ||
"Civray", "Coeur de Camembert au Calvados", "Coeur de Chevre", "Colby", "Cold Pack", | ||
"Comte", "Coolea", "Cooleney", "Coquetdale", "Corleggy", "Cornish Pepper", | ||
"Cotherstone", "Cotija", "Cottage Cheese", "Cottage Cheese (Australian)", | ||
"Cougar Gold", "Coulommiers", "Coverdale", "Crayeux de Roncq", "Cream Cheese", | ||
"Cream Havarti", "Crema Agria", "Crema Mexicana", "Creme Fraiche", "Crescenza", | ||
"Croghan", "Crottin de Chavignol", "Crottin du Chavignol", "Crowdie", "Crowley", | ||
"Cuajada", "Curd", "Cure Nantais", "Curworthy", "Cwmtawe Pecorino", | ||
"Cypress Grove Chevre", "Danablu (Danish Blue)", "Danbo", "Danish Fontina", | ||
"Daralagjazsky", "Dauphin", "Delice des Fiouves", "Denhany Dorset Drum", "Derby", | ||
"Dessertnyj Belyj", "Devon Blue", "Devon Garland", "Dolcelatte", "Doolin", | ||
"Doppelrhamstufel", "Dorset Blue Vinney", "Double Gloucester", "Double Worcester", | ||
"Dreux a la Feuille", "Dry Jack", "Duddleswell", "Dunbarra", "Dunlop", "Dunsyre Blue", | ||
"Duroblando", "Durrus", "Dutch Mimolette (Commissiekaas)", "Edam", "Edelpilz", | ||
"Emental Grand Cru", "Emlett", "Emmental", "Epoisses de Bourgogne", "Esbareich", | ||
"Esrom", "Etorki", "Evansdale Farmhouse Brie", "Evora De L'Alentejo", "Exmoor Blue", | ||
"Explorateur", "Feta", "Feta (Australian)", "Figue", "Filetta", "Fin-de-Siecle", | ||
"Finlandia Swiss", "Finn", "Fiore Sardo", "Fleur du Maquis", "Flor de Guia", | ||
"Flower Marie", "Folded", "Folded cheese with mint", "Fondant de Brebis", | ||
"Fontainebleau", "Fontal", "Fontina Val d'Aosta", "Formaggio di capra", "Fougerus", | ||
"Four Herb Gouda", "Fourme d' Ambert", "Fourme de Haute Loire", "Fourme de Montbrison", | ||
"Fresh Jack", "Fresh Mozzarella", "Fresh Ricotta", "Fresh Truffles", "Fribourgeois", | ||
"Friesekaas", "Friesian", "Friesla", "Frinault", "Fromage a Raclette", "Fromage Corse", | ||
"Fromage de Montagne de Savoie", "Fromage Frais", "Fruit Cream Cheese", | ||
"Frying Cheese", "Fynbo", "Gabriel", "Galette du Paludier", "Galette Lyonnaise", | ||
"Galloway Goat's Milk Gems", "Gammelost", "Gaperon a l'Ail", "Garrotxa", "Gastanberra", | ||
"Geitost", "Gippsland Blue", "Gjetost", "Gloucester", "Golden Cross", "Gorgonzola", | ||
"Gornyaltajski", "Gospel Green", "Gouda", "Goutu", "Gowrie", "Grabetto", "Graddost", | ||
"Grafton Village Cheddar", "Grana", "Grana Padano", "Grand Vatel", | ||
"Grataron d' Areches", "Gratte-Paille", "Graviera", "Greuilh", "Greve", | ||
"Gris de Lille", "Gruyere", "Gubbeen", "Guerbigny", "Halloumi", | ||
"Halloumy (Australian)", "Haloumi-Style Cheese", "Harbourne Blue", "Havarti", | ||
"Heidi Gruyere", "Hereford Hop", "Herrgardsost", "Herriot Farmhouse", "Herve", | ||
"Hipi Iti", "Hubbardston Blue Cow", "Hushallsost", "Iberico", "Idaho Goatster", | ||
"Idiazabal", "Il Boschetto al Tartufo", "Ile d'Yeu", "Isle of Mull", "Jarlsberg", | ||
"Jermi Tortes", "Jibneh Arabieh", "Jindi Brie", "Jubilee Blue", "Juustoleipa", | ||
"Kadchgall", "Kaseri", "Kashta", "Kefalotyri", "Kenafa", "Kernhem", "Kervella Affine", | ||
"Kikorangi", "King Island Cape Wickham Brie", "King River Gold", "Klosterkaese", | ||
"Knockalara", "Kugelkase", "L'Aveyronnais", "L'Ecir de l'Aubrac", "La Taupiniere", | ||
"La Vache Qui Rit", "Laguiole", "Lairobell", "Lajta", "Lanark Blue", "Lancashire", | ||
"Langres", "Lappi", "Laruns", "Lavistown", "Le Brin", "Le Fium Orbo", "Le Lacandou", | ||
"Le Roule", "Leafield", "Lebbene", "Leerdammer", "Leicester", "Leyden", "Limburger", | ||
"Lincolnshire Poacher", "Lingot Saint Bousquet d'Orb", "Liptauer", "Little Rydings", | ||
"Livarot", "Llanboidy", "Llanglofan Farmhouse", "Loch Arthur Farmhouse", | ||
"Loddiswell Avondale", "Longhorn", "Lou Palou", "Lou Pevre", "Lyonnais", "Maasdam", | ||
"Macconais", "Mahoe Aged Gouda", "Mahon", "Malvern", "Mamirolle", "Manchego", | ||
"Manouri", "Manur", "Marble Cheddar", "Marbled Cheeses", "Maredsous", "Margotin", | ||
"Maribo", "Maroilles", "Mascares", "Mascarpone", "Mascarpone (Australian)", | ||
"Mascarpone Torta", "Matocq", "Maytag Blue", "Meira", "Menallack Farmhouse", | ||
"Menonita", "Meredith Blue", "Mesost", "Metton (Cancoillotte)", "Meyer Vintage Gouda", | ||
"Mihalic Peynir", "Milleens", "Mimolette", "Mine-Gabhar", "Mini Baby Bells", "Mixte", | ||
"Molbo", "Monastery Cheeses", "Mondseer", "Mont D'or Lyonnais", "Montasio", | ||
"Monterey Jack", "Monterey Jack Dry", "Morbier", "Morbier Cru de Montagne", | ||
"Mothais a la Feuille", "Mozzarella", "Mozzarella (Australian)", | ||
"Mozzarella di Bufala", "Mozzarella Fresh, in water", "Mozzarella Rolls", "Munster", | ||
"Murol", "Mycella", "Myzithra", "Naboulsi", "Nantais", "Neufchatel", | ||
"Neufchatel (Australian)", "Niolo", "Nokkelost", "Northumberland", "Oaxaca", | ||
"Olde York", "Olivet au Foin", "Olivet Bleu", "Olivet Cendre", | ||
"Orkney Extra Mature Cheddar", "Orla", "Oschtjepka", "Ossau Fermier", "Ossau-Iraty", | ||
"Oszczypek", "Oxford Blue", "P'tit Berrichon", "Palet de Babligny", "Paneer", "Panela", | ||
"Pannerone", "Pant ys Gawn", "Parmesan (Parmigiano)", "Parmigiano Reggiano", | ||
"Pas de l'Escalette", "Passendale", "Pasteurized Processed", "Pate de Fromage", | ||
"Patefine Fort", "Pave d'Affinois", "Pave d'Auge", "Pave de Chirac", "Pave du Berry", | ||
"Pecorino", "Pecorino in Walnut Leaves", "Pecorino Romano", "Peekskill Pyramid", | ||
"Pelardon des Cevennes", "Pelardon des Corbieres", "Penamellera", "Penbryn", | ||
"Pencarreg", "Perail de Brebis", "Petit Morin", "Petit Pardou", "Petit-Suisse", | ||
"Picodon de Chevre", "Picos de Europa", "Piora", "Pithtviers au Foin", | ||
"Plateau de Herve", "Plymouth Cheese", "Podhalanski", "Poivre d'Ane", "Polkolbin", | ||
"Pont l'Eveque", "Port Nicholson", "Port-Salut", "Postel", "Pouligny-Saint-Pierre", | ||
"Pourly", "Prastost", "Pressato", "Prince-Jean", "Processed Cheddar", "Provolone", | ||
"Provolone (Australian)", "Pyengana Cheddar", "Pyramide", "Quark", | ||
"Quark (Australian)", "Quartirolo Lombardo", "Quatre-Vents", "Quercy Petit", | ||
"Queso Blanco", "Queso Blanco con Frutas --Pina y Mango", "Queso de Murcia", | ||
"Queso del Montsec", "Queso del Tietar", "Queso Fresco", "Queso Fresco (Adobera)", | ||
"Queso Iberico", "Queso Jalapeno", "Queso Majorero", "Queso Media Luna", | ||
"Queso Para Frier", "Queso Quesadilla", "Rabacal", "Raclette", "Ragusano", "Raschera", | ||
"Reblochon", "Red Leicester", "Regal de la Dombes", "Reggianito", "Remedou", | ||
"Requeson", "Richelieu", "Ricotta", "Ricotta (Australian)", "Ricotta Salata", "Ridder", | ||
"Rigotte", "Rocamadour", "Rollot", "Romano", "Romans Part Dieu", "Roncal", "Roquefort", | ||
"Roule", "Rouleau De Beaulieu", "Royalp Tilsit", "Rubens", "Rustinu", "Saaland Pfarr", | ||
"Saanenkaese", "Saga", "Sage Derby", "Sainte Maure", "Saint-Marcellin", | ||
"Saint-Nectaire", "Saint-Paulin", "Salers", "Samso", "San Simon", "Sancerre", | ||
"Sap Sago", "Sardo", "Sardo Egyptian", "Sbrinz", "Scamorza", "Schabzieger", "Schloss", | ||
"Selles sur Cher", "Selva", "Serat", "Seriously Strong Cheddar", "Serra da Estrela", | ||
"Sharpam", "Shelburne Cheddar", "Shropshire Blue", "Siraz", "Sirene", "Smoked Gouda", | ||
"Somerset Brie", "Sonoma Jack", "Sottocenare al Tartufo", "Soumaintrain", | ||
"Sourire Lozerien", "Spenwood", "Sraffordshire Organic", "St. Agur Blue Cheese", | ||
"Stilton", "Stinking Bishop", "String", "Sussex Slipcote", "Sveciaost", "Swaledale", | ||
"Sweet Style Swiss", "Swiss", "Syrian (Armenian String)", "Tala", "Taleggio", "Tamie", | ||
"Tasmania Highland Chevre Log", "Taupiniere", "Teifi", "Telemea", "Testouri", | ||
"Tete de Moine", "Tetilla", "Texas Goat Cheese", "Tibet", "Tillamook Cheddar", | ||
"Tilsit", "Timboon Brie", "Toma", "Tomme Brulee", "Tomme d'Abondance", | ||
"Tomme de Chevre", "Tomme de Romans", "Tomme de Savoie", "Tomme des Chouans", "Tommes", | ||
"Torta del Casar", "Toscanello", "Touree de L'Aubier", "Tourmalet", | ||
"Trappe (Veritable)", "Trois Cornes De Vendee", "Tronchon", "Trou du Cru", "Truffe", | ||
"Tupi", "Turunmaa", "Tymsboro", "Tyn Grug", "Tyning", "Ubriaco", "Ulloa", | ||
"Vacherin-Fribourgeois", "Valencay", "Vasterbottenost", "Venaco", "Vendomois", | ||
"Vieux Corse", "Vignotte", "Vulscombe", "Waimata Farmhouse Blue", | ||
"Washed Rind Cheese (Australian)", "Waterloo", "Weichkaese", "Wellington", | ||
"Wensleydale", "White Stilton", "Whitestone Farmhouse", "Wigmore", "Woodside Cabecou", | ||
"Xanadu", "Xynotyro", "Yarg Cornish", "Yarra Valley Pyramid", "Yorkshire Blue", | ||
"Zamorano", "Zanetti Grana Padano", "Zanetti Parmigiano Reggiano" | ||
) | ||
|
||
data class Cheese( | ||
val id: Long, | ||
val name: String, | ||
@DrawableRes val image: Int | ||
) { | ||
companion object { | ||
fun all(): List<Cheese> { | ||
return CheeseNames.mapIndexed { i, name -> | ||
Cheese( | ||
id = (i + 1).toLong(), | ||
name = name, | ||
image = CheeseImages[ | ||
((name.hashCode() % CheeseImages.size) + CheeseImages.size) % | ||
CheeseImages.size | ||
] | ||
) | ||
} | ||
} | ||
} | ||
} |
58 changes: 58 additions & 0 deletions
58
...ose/snippets/src/main/java/com/example/compose/snippets/animations/demo/SimpleScaffold.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
/* | ||
* Copyright 2024 The Android Open Source Project | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* https://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
*/ | ||
|
||
package com.example.compose.snippets.animations.demo | ||
|
||
import androidx.compose.foundation.layout.Box | ||
import androidx.compose.foundation.layout.BoxScope | ||
import androidx.compose.foundation.layout.fillMaxSize | ||
import androidx.compose.foundation.layout.padding | ||
import androidx.compose.foundation.layout.statusBarsPadding | ||
import androidx.compose.material3.ExperimentalMaterial3Api | ||
import androidx.compose.material3.Scaffold | ||
import androidx.compose.material3.Text | ||
import androidx.compose.material3.TopAppBar | ||
import androidx.compose.runtime.Composable | ||
import androidx.compose.ui.Modifier | ||
|
||
@OptIn(ExperimentalMaterial3Api::class) | ||
@Composable | ||
fun SimpleScaffold( | ||
title: String, | ||
modifier: Modifier = Modifier, | ||
content: @Composable BoxScope.() -> Unit | ||
) { | ||
Scaffold( | ||
topBar = { | ||
TopAppBar( | ||
title = { | ||
Text(text = title) | ||
}, | ||
modifier = Modifier | ||
.statusBarsPadding() | ||
) | ||
}, | ||
modifier = modifier | ||
) { padding -> | ||
Box( | ||
modifier = Modifier | ||
.fillMaxSize() | ||
.padding(padding) | ||
) { | ||
content() | ||
} | ||
} | ||
} |
110 changes: 110 additions & 0 deletions
110
...rc/main/java/com/example/compose/snippets/animations/demo/custom/CustomCanvasAnimation.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,110 @@ | ||
/* | ||
* Copyright 2024 The Android Open Source Project | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* https://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
*/ | ||
|
||
package com.example.compose.snippets.animations.demo.custom | ||
|
||
import androidx.compose.animation.core.Animatable | ||
import androidx.compose.animation.core.Spring | ||
import androidx.compose.animation.core.SpringSpec | ||
import androidx.compose.animation.core.spring | ||
import androidx.compose.foundation.Canvas | ||
import androidx.compose.foundation.layout.Box | ||
import androidx.compose.foundation.layout.fillMaxSize | ||
import androidx.compose.foundation.layout.size | ||
import androidx.compose.runtime.Composable | ||
import androidx.compose.runtime.LaunchedEffect | ||
import androidx.compose.runtime.mutableStateOf | ||
import androidx.compose.runtime.remember | ||
import androidx.compose.ui.Alignment | ||
import androidx.compose.ui.Modifier | ||
import androidx.compose.ui.graphics.Brush | ||
import androidx.compose.ui.graphics.Color | ||
import androidx.compose.ui.graphics.graphicsLayer | ||
import androidx.compose.ui.layout.onSizeChanged | ||
import androidx.compose.ui.tooling.preview.Preview | ||
import androidx.compose.ui.unit.IntSize | ||
import androidx.compose.ui.unit.dp | ||
import kotlinx.coroutines.delay | ||
|
||
/** | ||
* A custom loading animation example using Canvas and draw APIs, combined with | ||
* Animatable to show the use of the animateTo() function used sequentially. | ||
*/ | ||
@Composable | ||
@Preview | ||
fun CustomCanvasBouncyLoader() { | ||
val yOffset = remember { | ||
Animatable(0f) | ||
} | ||
val scale = remember { | ||
Animatable(1f) | ||
} | ||
LaunchedEffect("bouncyLoader") { | ||
delay(400) | ||
// We use the Animatable.animateTo() API here to demonstrate the coroutine usage - each | ||
// item is animating one after the other, as the animateTo function is sequential. | ||
// Animate y to half the height | ||
yOffset.animateTo(0.5f, bouncyAnimationSpec) | ||
scale.animateTo(3f, bouncyAnimationSpec) | ||
delay(500) | ||
scale.animateTo(10f, bouncyAnimationSpec) | ||
delay(500) | ||
scale.animateTo(50f, bouncyAnimationSpec) | ||
} | ||
val size = remember { | ||
mutableStateOf(IntSize.Zero) | ||
} | ||
Box( | ||
Modifier | ||
.fillMaxSize() | ||
.onSizeChanged { | ||
// We get the size change of the whole composable, and use this to determine how | ||
// big the ball should be. | ||
size.value = it | ||
} | ||
) { | ||
GradientCircle( | ||
Modifier | ||
.align(Alignment.TopCenter) | ||
.size(26.dp) | ||
.graphicsLayer { | ||
// We use .graphicsLayer here to perform the animation as we are animating | ||
// multiple properties of our Gradient circle at once, and this is more | ||
// efficient than using multiple modifiers. | ||
// .graphicsLayer also defers these changes to the Draw phase of Compose, | ||
// therefore minimizing recompositions required to do this. | ||
scaleX = scale.value | ||
scaleY = scale.value | ||
translationY = yOffset.value * size.value.height | ||
} | ||
) | ||
} | ||
} | ||
|
||
@Composable | ||
private fun GradientCircle(modifier: Modifier = Modifier) { | ||
val brush = remember { | ||
Brush.verticalGradient(listOf(Color(0xFFF56E34), Color(0xFF234EDA))) | ||
} | ||
Canvas(modifier = modifier) { | ||
drawCircle(brush = brush) | ||
} | ||
} | ||
|
||
private val bouncyAnimationSpec: SpringSpec<Float> = spring( | ||
dampingRatio = Spring.DampingRatioMediumBouncy, | ||
stiffness = Spring.StiffnessLow | ||
) |
Oops, something went wrong.