Fix queue changing
This commit is contained in:
parent
69c76556a2
commit
891f1bce34
34 changed files with 1007 additions and 132 deletions
|
@ -0,0 +1,73 @@
|
|||
package code.name.monkey.retromusic.extensions
|
||||
|
||||
import androidx.annotation.ColorInt
|
||||
import androidx.core.graphics.ColorUtils
|
||||
import androidx.palette.graphics.Palette
|
||||
|
||||
|
||||
fun getSuitableColorFor(palette: Palette, i: Int, i2: Int): Int {
|
||||
val dominantSwatch = palette.dominantSwatch
|
||||
if (dominantSwatch != null) {
|
||||
if (hasEnoughContrast(i, dominantSwatch.rgb)) {
|
||||
return dominantSwatch.rgb
|
||||
}
|
||||
}
|
||||
val vibrantSwatch = palette.vibrantSwatch
|
||||
if (vibrantSwatch != null) {
|
||||
if (hasEnoughContrast(i, vibrantSwatch.rgb)) {
|
||||
return vibrantSwatch.rgb
|
||||
}
|
||||
}
|
||||
val darkVibrantSwatch = palette.darkVibrantSwatch
|
||||
if (darkVibrantSwatch != null) {
|
||||
if (hasEnoughContrast(i, darkVibrantSwatch.rgb)) {
|
||||
return darkVibrantSwatch.rgb
|
||||
}
|
||||
}
|
||||
val lightVibrantSwatch = palette.lightVibrantSwatch
|
||||
if (lightVibrantSwatch != null) {
|
||||
if (hasEnoughContrast(i, lightVibrantSwatch.rgb)) {
|
||||
return lightVibrantSwatch.rgb
|
||||
}
|
||||
}
|
||||
val darkMutedSwatch = palette.darkMutedSwatch
|
||||
if (darkMutedSwatch != null) {
|
||||
if (hasEnoughContrast(i, darkMutedSwatch.rgb)) {
|
||||
return darkMutedSwatch.rgb
|
||||
}
|
||||
}
|
||||
val lightMutedSwatch = palette.lightMutedSwatch
|
||||
if (lightMutedSwatch != null) {
|
||||
if (hasEnoughContrast(i, lightMutedSwatch.rgb)) {
|
||||
return lightMutedSwatch.rgb
|
||||
}
|
||||
}
|
||||
val mutedSwatch = palette.mutedSwatch
|
||||
if (mutedSwatch != null) {
|
||||
if (hasEnoughContrast(i, mutedSwatch.rgb)) {
|
||||
return mutedSwatch.rgb
|
||||
}
|
||||
}
|
||||
return i2
|
||||
}
|
||||
|
||||
fun hasEnoughContrast(i: Int, i2: Int): Boolean {
|
||||
return ColorUtils.calculateContrast(i2, i) >= 2.toDouble()
|
||||
}
|
||||
|
||||
fun hasEnoughLuminance(i: Int): Boolean {
|
||||
return ColorUtils.calculateLuminance(i) >= 0.4f.toDouble()
|
||||
}
|
||||
|
||||
fun isBlack(fArr: FloatArray): Boolean {
|
||||
return fArr[2] <= 0.035f
|
||||
}
|
||||
|
||||
fun isNearRedLine(fArr: FloatArray): Boolean {
|
||||
val f = fArr[0]
|
||||
return f >= 10.0f && f <= 37.0f && fArr[1] <= 0.82f
|
||||
}
|
||||
|
||||
fun isDark(@ColorInt i: Int): Boolean {
|
||||
return ColorUtils.calculateLuminance(i) < 0.5
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue