How to add and use custom colors in an Android project
data:image/s3,"s3://crabby-images/b6283/b6283d6dab3a9d5fd6ceacdf08c7e1602be03f81" alt="Oscar de la Hera Gomez"
data:image/s3,"s3://crabby-images/16611/16611ac2e24b1044a2122f4535a47dc878d0d0eb" alt="Four flowers that represent Kotlin, Android, Jetpack Compose and Android Studio. Beneath them sits the text "Custom Color""
A step by step guide on adding and using custom colors in a Kotlin, Jetpack Compose, Android project using Android Studio.
We recommend that you clone our Open Source Kotlin Starter Project, checking out the main branch and carrying out the steps below. The changes can be found on the tutorial/basics/custom-color branch.
git clone git@github.com:delasign/kotlin-android-starter-project.git
Please note that this tutorial covers how to add and use custom colors for both the colors.xml file as well as the Color.kt file. Each of these files use a different type of color value: ARGB Hexadecimals and android.graphics.Color.
Step One: Determine the ARGB color value
data:image/s3,"s3://crabby-images/2adfb/2adfb2510d6f2932198893f9d24b16982e4b8c95" alt="A screenshot of FixGuide's Color converter, highlighting where you can enter a hex value and where you can gather the ARGB value."
Android's color.xml file uses ARGB hexadecimals.
Use the link below to convert your color to an ARGB hexadecimal.
Make sure you copy the ARGB value.
Step Two: Add the color to the color values
data:image/s3,"s3://crabby-images/afb37/afb374fb6323ac000a41491e2d5c101560dada97" alt="A screenshot of Android Studio showing the color.xml. We have highlighted where we have added the custom color, using the code that is available below."
In res > values > color.xml, add your color using code similar to the one below.
How to use this color value
data:image/s3,"s3://crabby-images/e8e44/e8e44963b6c2800628f263d14258dad0278acdf6" alt="A screenshot of the ic_launcher_background.xml file in Android studio with a highlight of where we have used the custom color value."
This color can be used in your code using "@color/custom_grey", where custom_grey is the name of the color that you added.
Please note that this color type is only to be used in xml files. To use colors as part of Jetpack Compose Composables, follow the next two steps.
Step Three: Determine the Android Graphics Color
data:image/s3,"s3://crabby-images/8bd49/8bd49b6669ae387abf0e15aed7ea650b4eca0bf3" alt="A screenshot of ConvertingColor.com showing a highlight on where you can find the Android.graphics.color."
Android's Color.kt file uses android.graphics.Color values.
Use the link below to convert your color to an android.graphics.Color.
Make sure you copy the Android value.
Step Four: Add to Colors
data:image/s3,"s3://crabby-images/820c9/820c9d8f117a8d457efd0295ac32c3f67661d5b7" alt="A screenshot of Android Studio showing the color.kt file with a highlight on the newly added value."
Under ui.theme > Colors.kt, add the android.graphics.color using code similar to the one below.
If you are using our open source project, please note that the theme folder is now found under the styleguide folder in our main branch as it forms part of the Styleguide.
val CustomGrey = Color(0xFF949494)
How to use this color value
data:image/s3,"s3://crabby-images/be06e/be06e2411480e23e83b8cbf608f7a7ea0fd9caaa" alt="A screenshot of Android Studio showing the Main Activity file, with a color added to the Greetings Composable."
To use this color value, provide the name to a Color parameter within a Composable.
Looking to implement light mode or dark mode?
To learn how to use dark mode or light mode, consult the tutorial below.