Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jordond/materialkolor
🎨 A Compose multiplatform library for generating dynamic Material3 color schemes from a seed color
https://github.com/jordond/materialkolor
android compose compose-multiplatform compose-web kotlin kotlin-multiplatform material material-design material3
Last synced: 3 months ago
JSON representation
🎨 A Compose multiplatform library for generating dynamic Material3 color schemes from a seed color
- Host: GitHub
- URL: https://github.com/jordond/materialkolor
- Owner: jordond
- License: mit
- Created: 2023-07-15T22:16:56.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-11-06T15:18:17.000Z (3 months ago)
- Last Synced: 2024-11-06T16:27:10.791Z (3 months ago)
- Topics: android, compose, compose-multiplatform, compose-web, kotlin, kotlin-multiplatform, material, material-design, material3
- Language: Kotlin
- Homepage: https://materialkolor.com
- Size: 5.23 MB
- Stars: 511
- Watchers: 5
- Forks: 10
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- kmp-awesome - MaterialKolor
README
![Maven Central](https://img.shields.io/maven-central/v/com.materialkolor/material-kolor)
[![Kotlin](https://img.shields.io/badge/kotlin-v2.0.20-blue.svg?logo=kotlin)](http://kotlinlang.org)
[![Build](https://github.com/jordond/materialkolor/actions/workflows/ci.yml/badge.svg)](https://github.com/jordond/materialkolor/actions/workflows/ci.yml)
[![License](https://img.shields.io/github/license/jordond/MaterialKolor)](https://opensource.org/license/mit/)[![Compose Multiplatform](https://img.shields.io/badge/Compose%20Multiplatform-1.6.1-blue)](https://github.com/JetBrains/compose-multiplatform)
![badge-android](http://img.shields.io/badge/platform-android-6EDB8D.svg?style=flat)
![badge-ios](http://img.shields.io/badge/platform-ios-CDCDCD.svg?style=flat)
![badge-desktop](http://img.shields.io/badge/platform-desktop-DB413D.svg?style=flat)
![badge-js](http://img.shields.io/badge/platform-js%2Fwasm-FDD835.svg?style=flat)A Compose Multiplatform library for creating dynamic Material Design 3 color palettes from any
color.Check out [MaterialKolor Builder](https://materialkolor.com) to see MaterialKolor in action and
generate your own color schemes. It can export to MaterialKolor code, or plain Material 3 code.The KDoc is published at [docs.materialkolor.com](https://docs.materialkolor.com)
## Table of Contents
- [Platforms](#platforms)
- [Inspiration](#inspiration)
- [Setup](#setup)
- [Multiplatform](#multiplatform)
- [Single Platform](#single-platform)
- [Version Catalog](#version-catalog)
- [Usage](#usage)
- [Extensions](#extensions)
- [Harmonize Colors](#harmonize-colors)
- [Lighten and Darken](#lighten-and-darken)
- [Color Temperature](#color-temperature)
- [Generating from an Image](#generating-from-an-image)
- [Advanced](#advanced)
- [License](#license)
- [Changes from original source](#changes-from-original-source)## Platforms
This library is written for Compose Multiplatform, and can be used on the following platforms:
- Android
- iOS
- JVM (Desktop)
- JavaScript/wasm (Browser)You can see it in action by using [MaterialKolor Builder](https://materialkolor.com).
## Inspiration
The heart of this library comes from
the [material-color-utilities](https://github.com/material-foundation/material-color-utilities)
repository. It is currently
only a Java library, and I wanted to make it available to Kotlin Multiplatform projects. The source
code was taken and converted into a Kotlin Multiplatform library.I also incorporated the Compose ideas from another open source
library [m3color](https://github.com/Kyant0/m3color).## Setup
You can add this library to your project using Gradle.
### Multiplatform
To add to a multiplatform project, add the dependency to the common source-set:
```kotlin
kotlin {
sourceSets {
commonMain {
dependencies {
implementation("com.materialkolor:material-kolor:2.0.0")
}
}
}
}
```### Single Platform
For an Android only project, add the dependency to app level `build.gradle.kts`:
```kotlin
dependencies {
implementation("com.materialkolor:material-kolor:2.0.0")
}
```### Version Catalog
```toml
[versions]
materialKolor = "2.0.0"[libraries]
materialKolor = { module = "com.materialkolor:material-kolor", version.ref = "materialKolor" }
```## Usage
To generate a custom `ColorScheme` you simply need to call `dynamicColorScheme()` with your target
seed color:```kotlin
@Composable
fun MyTheme(
seedColor: Color,
useDarkTheme: Boolean = isSystemInDarkTheme(),
content: @Composable () -> Unit
) {
val colorScheme = rememberDynamicColorScheme(seedColor, useDarkTheme)MaterialTheme(
colors = colorScheme.toMaterialColors(),
content = content
)
}
```You can also pass in
a [`PaletteStyle`](material-kolor/src/commonMain/kotlin/com/materialkolor/PaletteStyle.kt) to
customize the generated palette:```kotlin
dynamicColorScheme(
seedColor = seedColor,
isDark = useDarkTheme,
style = PaletteStyle.Vibrant,
)
```### DynamicMaterialTheme
A `DynamicMaterialTheme` Composable is also available. It is a wrapper around `MaterialTheme` that
uses `dynamicColorScheme()` to generate a `ColorScheme` for you. You can animate the color scheme by
passing in `animate = true`.Example:
```kotlin
@Composable
fun MyTheme(
seedColor: Color,
useDarkTheme: Boolean = isSystemInDarkTheme(),
content: @Composable () -> Unit
) {
DynamicMaterialTheme(
seedColor = seedColor,
isDark = useDarkTheme,
animate = true,
content = content
)
}
```## Extensions
Included in the library are some extensions for working with colors. You can check out
the [/ktx](material-kolor/src/commonMain/kotlin/com/materialkolor/ktx) package for more information.But here are a couple useful examples:
### Harmonize Colors
If you want to harmonize a color with another you can use the `Color.harmonize()` function. You can
read more about color harmonization on
the [Material 3 Documentation](https://m3.material.io/styles/color/advanced/adjust-existing-colors#1cc12e43-237b-45b9-8fe0-9a3549c1f61e).Example:
```kotlin
val newColor = MaterialTheme.colorScheme.primary.harmonize(Color.Blue)
```There is an additional function specifically for harmonizing with the primary color:
```kotlin
val newColor = Color.Blue.harmonizeWithPrimary()
```**Note:** `Color.harmonize()` has an optional parameter `matchSaturation` which when set to `true`
will adjust the saturation from the other color.### Lighten and Darken
You can lighten or darken a color using the `Color.lighten()` and `Color.darken()` functions.
For example:
```kotlin
val newColor = MaterialTheme.colorScheme.primary.lighten(0.2f)
```Check out the demo app for a full example.
### Color Temperature
You can determine if a `Color` is warm or cold using the following:
```kotlin
val isWarm = MaterialTheme.colorScheme.primary.isWarm()
val isCold = MaterialTheme.colorScheme.primary.isCold()
```## Generating from an Image
You can calculate a seed color, or colors that are suitable for UI theming from an image. This is
useful for generating a color scheme from a user's profile picture, or a background image.To do so you can call `ImageBitmap.themeColors()`, `ImageBitmap.themeColor()` or the `@Composable`
function `rememberThemeColors()` or `rememberThemeColor()`:```kotlin
fun calculateSeedColor(bitmap: ImageBitmap): Color {
val suitableColors = bitmap.themeColors(fallback = Color.Blue)
return suitableColors.first()
}
```See [`ImageBitmap.kt`](material-kolor/src/commonMain/kotlin/com/materialkolor/ktx/ImageBitmap.kt)
for more information.Or in Compose land:
```kotlin
@Composable
fun DynamicTheme(image: ImageBitmap, content: @Composable () -> Unit) {
val seedColor = rememberThemeColor(image, fallback = MaterialTheme.colorScheme.primary)AnimatedDynamicMaterialTheme(
seedColor = seedColor,
content = content
)
}
```### Advanced
For a more advanced use-case you can use my other
library [kmPalette](https://github.com/jordond/kmpalette).You can get the dominant color from an image, or you can also generate a color palette.
Follow the instructions there to set it up, then as an example. You can use it to generate a color
theme from a remote image:```kotlin
@Composable
fun SampleTheme(
imageUrl: Url, // Url("http://example.com/image.jpg")
useDarkTheme: Boolean = isSystemInDarkTheme(),
content: @Composable () -> Unit,
) {
val networkLoader = rememberNetworkLoader()
val dominantColorState = rememberDominantColorState(loader = networkLoader)
LaunchedEffect(imageUrl) {
dominantColorState.updateFrom(imageUrl)
}AnimatedDynamicMaterialTheme(
seedColor = dominantColorState.color,
isDark = useDarkTheme,
content = content
)
}
```## License
The module `material-color-utilities` is licensed under the Apache License, Version 2.0. See
their [LICENSE](material-color-utilities/src/commonMain/kotlin/com/materialkolor/LICENSE) and their
repository [here](https://github.com/material-foundation/material-color-utilities) for more
information.### Changes from original source
- Convert Java code to Kotlin
- Convert library to Kotlin MultiplatformFor the remaining code see [LICENSE](LICENSE) for more information.