Rainbow

Project Url: skydoves/Rainbow
Introduction: 🌈 An easy way to apply gradations and tinting for Android.
More: Author   ReportBugs   
Tags:

License API BuildStatus Android Weekly KotlinWeekly Javadoc

🌈 An expressive Kotlin DSL for dynamically creating and
applying gradients, text shaders, and tints to any Android View.

Download

Maven Central

Gradle

Add the dependency below on your root build.gradle.kts file:

dependencies {
    implementation("com.github.skydoves:rainbow:1.1.0")
}

Usage

We can apply gradations and tinting to any views easily using Rainbow class.

Palette

A gradient is defined by a collection of colors, which we refer to as a palette. The palette lambda block is the primary mechanism for constructing this collection.

Within the lambda, you can add colors using the contextColor and color functions. The contextColor function resolves a color resource from your colors.xml file, whereas the color function accepts a ColorInt value directly. These functions should be used with the unary + operator to add them to the palette.

Rainbow(myCardView).palette { // constructs a palette for collecting colors.
  +contextColor(R.color.red_200) // getting a color from the resource
  +contextColor(R.color.yellow_200)
  +contextColor(R.color.green_200)
  +contextColor(R.color.blue_200)
  +color(Color.WHITE) // getting a color
}.withAlpha(225) // sets alpha (0~255)
 .foreground() // applies gradations to myCardView

Here is kotlin extension ways to apply gradations using View.rainbow() method to views.

myLinearLayout.rainbow().palette {
  +contextColor(R.color.skyBlue)
  +contextColor(R.color.colorPrimary)
}.background(orientation = RainbowOrientation.TOP_BOTTOM, radius = 8)

Background, Foreground

Once a palette is defined, you can apply the resulting gradient to a view's background or foreground.

Rainbow(myCardView).palette {
  +contextColor(R.color.red_200)
  +contextColor(R.color.yellow_200)
}.background() // or foreground()

The gradient's orientation and corner radius can be customized. There are eight predefined orientations available in the RainbowOrientation enum.

background(orientation = RainbowOrientation.RIGHT_LEFT, radius = 8)
background(orientation = RainbowOrientation.TOP_BOTTOM, radius = 8)
foreground(RainbowOrientation.DIAGONAL_TOP_LEFT, 8)
foreground(RainbowOrientation.DIAGONAL_BOTTOM_RIGHT, 8)

Shading TextViews

For TextView instances, Rainbow provides a shade method that applies the gradient to the text itself, creating a multi-colored text effect.

myTextView.rainbow().palette {
  +contextColor(R.color.colorPrimary)
  +contextColor(R.color.md_orange_100)
  +contextColor(R.color.md_blue_200)
}.shade()

You can also define a palette from a color array resource declared in XML.

// In res/values/colors.xml:
// <array name="rainbow_colors">
//   <item>@color/red_100</item>
//   <item>@color/blue_100</item>
// </array>

myTextView.rainbow().palette {
  +colorArray(R.array.rainbow_colors)
}.shade()

Tinting Views

The tint method applies the defined palette as a tint color. This is effective for views that support tinting, such as ImageView, CompoundButton, and any views implementing TintableBackgroundView.

myCheckBox.rainbow().palette {
  +contextColor(R.color.red_200)
  +contextColor(R.color.blue_200)
}.tint()
Rainbow(myCheckBox).palette {
  +contextColor(R.color.red_200)
}.tint()

Drawable

If you need the gradient as a GradientDrawable object for use elsewhere, you can retrieve it with the getDrawable method.

val gradientDrawable = Rainbow(myView).palette {
  +contextColor(R.color.red_200)
  +contextColor(R.color.yellow_200)
}.getDrawable()

// Now you can use the drawable instance as needed.
someOtherView.background = gradientDrawable

RainbowView

RainbowView is a versatile view that renders a multi-color gradient. It sources its colors from a color-array resource.

RainbowView in xml layout

<com.skydoves.rainbow.RainbowView
  android:id="@+id/rainbowView"
  android:layout_width="match_parent"
  android:layout_height="100dp"
  app:rainbowView_colors="@array/rainbow_colors"
  app:rainbowView_orientation="left_right"
  app:rainbowView_radius="12dp" />

The rainbowView_colors attributes gets color list from the color-array from your colors.xml.

<resources>
  <color name="colorPrimary">#C51162</color>
  ...
  <array name="colors">
    <item>@color/red_100</item>
    <item>@color/orange_100</item>
    <item>@color/yellow_100</item>
    <item>@color/green_100</item>
    ...
  </array>
</resources>

BinaryRainbowView

BinaryRainbowView is a simplified version for creating two or three-color gradients directly from color attributes.

<com.skydoves.rainbow.BinaryRainbowView
  android:layout_width="match_parent"
  android:layout_height="80dp"
  app:binaryRainbowView_startColor="@color/md_green_100" // starting color of the gradient.
  app:binaryRainbowView_centerColor="@color/white" // center color of the gradient.
  app:binaryRainbowView_endColor="@color/skyBlue" // end color of the gradient.
  app:binaryRainbowView_orientation="bottom_top" // gradient orientation.
  app:binaryRainbowView_radius="12dp" // corner radius
/>

Shuffle

Both RainbowView and BinaryRainbowView support dynamic shuffling of their palette colors. Calling the shuffleColors() method will randomly reorder the gradient colors, providing a simple way to create dynamic visual effects.

val rainbowView = findViewById<RainbowView>(R.id.rainbowView)
rainbowView.shuffleColors()

val binaryRainbowView = findViewById<BinaryRainbowView>(R.id.binaryRainbowView)
binaryRainbowView.shuffleColors()

Find this library useful? :heart:

Support it by joining stargazers for this repository. :star:

License

```xml Copyright 2019 skydoves (Jaewoong Eum)

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

http://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.

Apps
About Me
GitHub: Trinea
Facebook: Dev Tools