Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mahozad/wavy-slider
Multiplatform wavy slider/progress bar similar to the one in Android 13
https://github.com/mahozad/wavy-slider
android compose-multiplatform jetpack jetpack-compose kotlin kotlin-multiplatform kotlin-multiplatform-sample material material-design material-you material3 progress-bar sine-wave slider wavy-slider
Last synced: 2 months ago
JSON representation
Multiplatform wavy slider/progress bar similar to the one in Android 13
- Host: GitHub
- URL: https://github.com/mahozad/wavy-slider
- Owner: mahozad
- License: apache-2.0
- Created: 2023-07-04T12:35:02.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-08-02T06:43:07.000Z (6 months ago)
- Last Synced: 2024-08-02T09:29:08.181Z (6 months ago)
- Topics: android, compose-multiplatform, jetpack, jetpack-compose, kotlin, kotlin-multiplatform, kotlin-multiplatform-sample, material, material-design, material-you, material3, progress-bar, sine-wave, slider, wavy-slider
- Language: Kotlin
- Homepage: https://mahozad.ir/wavy-slider
- Size: 7.56 MB
- Stars: 147
- Watchers: 2
- Forks: 5
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-kotlin - Wavy Slider - A demo (and usable) multiplatform Compose library that shows how to make a UI component targeting multiple platforms (Libraries)
- kmp-awesome - Wavy slider
- awesome - WavySlider
README
[![Kotlin version]][Kotlin release]
[![Compose Multiplatform version]][Compose Multiplatform release]
[![Latest Maven Central release]][Library on Maven Central]
# Wavy slider
Animated [Material](https://material.io) wavy slider and progress/seek bar similar to the one used in [**Android 13** media controls](https://www.xda-developers.com/android-13-beta-1-media-controls-animation/).
It has curly, wobbly, squiggly, wiggly, jiggly, wriggly, dancing movements.
Some users call it the **sperm**.The library can be used in [Jetpack Compose](https://developer.android.com/jetpack/compose) and [Compose Multiplatform](https://github.com/JetBrains/compose-multiplatform) projects like
a regular Material [Slider](https://developer.android.com/reference/kotlin/androidx/compose/material3/package-summary#Slider(kotlin.Float,kotlin.Function1,androidx.compose.ui.Modifier,kotlin.Boolean,kotlin.ranges.ClosedFloatingPointRange,kotlin.Int,kotlin.Function0,androidx.compose.material3.SliderColors,androidx.compose.foundation.interaction.MutableInteractionSource)).
Supported target platforms are Android, iOS, Desktop (JVM), and JavaScript (Kotlin/JS and Kotlin/Wasm).## Demo
For a live, interactive Web demo go to https://mahozad.ir/wavy-slider.
For real-world apps in various platforms using the library, see the [showcase](showcase) directory.## Usage
```kotlin
implementation("ir.mahozad.multiplatform:wavy-slider:2.0.0")
```Setup for multiplatform projects
If you target a subset of the library supported platforms, add the library to your common source set:
```kotlin
kotlin {
sourceSets {
commonMain.dependencies {
implementation/* OR api */("ir.mahozad.multiplatform:wavy-slider:2.0.0")
// ...
}
// ...
```If you have targets that are not supported by the library,
add the library separately to each supported target:```kotlin
kotlin {
val desktopMain /* OR jvmMain */ by getting {
dependencies {
implementation/* OR api */("ir.mahozad.multiplatform:wavy-slider:2.0.0")
// ...
}
}
androidMain.dependencies {
implementation/* OR api */("ir.mahozad.multiplatform:wavy-slider:2.0.0")
// ...
}
// Other targets...
```Using the WavySlider is much like using the Material Slider
(you can even make it a regular flat Slider):```kotlin
import ir.mahozad.multiplatform.wavyslider.material/*OR material3*/.WavySlider
import ir.mahozad.multiplatform.wavyslider.WaveDirection.*@Composable
fun MyComposable() {
var fraction by remember { mutableStateOf(0.5f) }
WavySlider(
value = fraction,
onValueChange = { fraction = it },
waveLength = 16.dp, // Set this to 0.dp to make the Slider flat
waveHeight = 16.dp, // Set this to 0.dp to make the Slider flat
waveVelocity = 15.dp to HEAD, // Speed per second and its direction
waveThickness = 4.dp, // Defaults to 4.dp irregardless of variant
trackThickness = 4.dp, // Defaults to a thickness based on variant
incremental = false, // Whether to gradually increase waveHeight
// animationSpecs = ... // Customize various animations of the wave
)
}
```## Related
- AOSP native squiggly progress: [Main branch][Android main branch implementation] ❖ [Android 14][Android 14 branch implementation] ❖ [Android 13][Android 13 branch implementation]
- LinearWavyProgressIndicator (available since [Material 3 v1.4.0-alpha01][Material 3 v1.4.0-alpha01])
- Squiggly slider (Android-only): https://github.com/saket/squiggly-slider
- Wave slider (Android-only): https://github.com/galaxygoldfish/waveslider
- Squiggly seekbar (Flutter): https://github.com/hannesgith/squiggly_slider
- Sliders with custom styles: https://github.com/krottv/compose-sliders
- Customizable seeker/slider: https://github.com/2307vivek/Seeker
- Squiggly text underlines: https://github.com/saket/ExtendedSpans
- Waveform seekbar: https://github.com/massoudss/waveformSeekBar
- Colorful sliders: https://github.com/SmartToolFactory/Compose-Colorful-Sliders
- StackOverflow posts:
+ [How to create the Android 13 squiggly slider using Jetpack Compose?](https://stackoverflow.com/q/77927207/8583692)
+ [Implement new slider in Android 13 media player via Jetpack Compose](https://stackoverflow.com/q/75268182/8583692)
+ [Wave like seek bar for music player app in android jetpack compose](https://stackoverflow.com/q/77661902/8583692)
+ [Squiggly Seekbar with Animation in Flutter](https://stackoverflow.com/q/75889414/8583692)
+ [Is it possible to make a squiggly line?](https://stackoverflow.com/q/17285514/8583692)[Kotlin version]: https://img.shields.io/badge/Kotlin-2.0.21-303030.svg?labelColor=303030&logo=
[Compose Multiplatform version]: https://img.shields.io/badge/Compose_Multiplatform-1.7.0-303030.svg?labelColor=303030&logo=
[Latest Maven Central release]: https://img.shields.io/maven-central/v/ir.mahozad.multiplatform/wavy-slider?label=Maven%20Central&labelColor=303030&logo=
[Kotlin release]: https://github.com/JetBrains/kotlin/releases/tag/v2.0.21
[Compose Multiplatform release]: https://github.com/JetBrains/compose-multiplatform/releases/tag/v1.7.0
[Library on Maven Central]: https://repo1.maven.org/maven2/ir/mahozad/multiplatform/wavy-slider/2.0.0/
[Android main branch implementation]: https://android.googlesource.com/platform/frameworks/base/+/refs/heads/main/packages/SystemUI/src/com/android/systemui/media/controls/ui/drawable/SquigglyProgress.kt
[Android 14 branch implementation]: https://android.googlesource.com/platform/frameworks/base/+/refs/heads/android14-release/packages/SystemUI/src/com/android/systemui/media/controls/ui/SquigglyProgress.kt
[Android 13 branch implementation]: https://android.googlesource.com/platform/frameworks/base/+/refs/heads/android13-release/packages/SystemUI/src/com/android/systemui/media/SquigglyProgress.kt
[Material 3 v1.4.0-alpha01]: https://github.com/androidx/androidx/blob/androidx-main/compose/material3/material3/src/commonMain/kotlin/androidx/compose/material3/WavyProgressIndicator.kt#L132