Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ajalt/colormath
Multiplatform Kotlin color conversion and manipulation
https://github.com/ajalt/colormath
color css-color kotlin kotlin-multiplatform
Last synced: about 21 hours ago
JSON representation
Multiplatform Kotlin color conversion and manipulation
- Host: GitHub
- URL: https://github.com/ajalt/colormath
- Owner: ajalt
- License: mit
- Created: 2018-07-05T01:01:41.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2024-05-22T19:29:56.000Z (8 months ago)
- Last Synced: 2024-05-22T19:45:52.869Z (8 months ago)
- Topics: color, css-color, kotlin, kotlin-multiplatform
- Language: Kotlin
- Homepage: https://ajalt.github.io/colormath/
- Size: 12.8 MB
- Stars: 287
- Watchers: 9
- Forks: 18
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- kmp-awesome - Colormath - Multiplatform Kotlin color conversion and manipulation (Libraries / 🔧 Utils)
README
Colormath is a Kotlin Multiplatform library for color manipulation and conversion.
Colormath can:
- Convert between color models and spaces
- Manipulate colors with transformations such as mixing and chromatic adaptation
- Calculate attributes such as WCAG contrast and perceptual color difference
- Generate gradients with custom interpolation methods and easing functions
- Parse and render colors as strings, including all representations from the CSS spec```kotlin
// Create an sRGB color
val color = RGB("#ff23cc")// Interpolate with another color
val mixed = color.interpolate(RGB(0.1, 0.4, 1), 0.5f)
// RGB("#8c45e6")// Convert to a different color space
val lab = mixed.toLAB()
// LAB(46.3, 60.9, -70)// Change the transparency
val labA = lab.copy(alpha = 0.25f)
// LAB(46.3, 60.9, -70, 0.25)// Adapt white point
val lab50 = labA.convertTo(LAB50)
// LAB50(45, 55.1812, 72.5911, 0.25)// Render as a css color string
println(lab50.formatCssString())
// "lab(45% 55.1812 -72.5911 / 0.25)"
```## Documentation
The full documentation can be found on [the website](https://ajalt.github.io/colormath).
You can also [try it online](https://ajalt.github.io/colormath/tryit/)
## Installation
Colormath is distributed through [Maven Central](https://search.maven.org/artifact/com.github.ajalt.colormath/colormath/).
```groovy
dependencies {
implementation("com.github.ajalt.colormath:colormath:3.6.1")
// optional extensions for interop with other platforms
//
// android.graphics.Color
implementation("com.github.ajalt.colormath:colormath-ext-android-color:3.6.1")
// androidx.annotation.ColorInt
implementation("com.github.ajalt.colormath:colormath-ext-android-colorint:3.6.1")
// androidx.compose.ui.graphics.Color
implementation("com.github.ajalt.colormath:colormath-ext-jetpack-compose:3.6.1")
}
```###### If you're using Maven instead of Gradle, use `colormath-jvm`
#### Multiplatform
Colormath publishes artifacts for all
[Tier 1 and Tier 2](https://kotlinlang.org/docs/native-target-support.html)
targets, as well as `mingwX64` and `wasmJs`.#### Snapshots
Snapshot builds are also available
You'll need to add the Sonatype snapshots repository:```kotlin
repositories {
maven {
url = uri("https://oss.sonatype.org/content/repositories/snapshots/")
}
}
```