Changing radio button and checkbox color and appearance

In this blog, we will learn about Changing radio button and checkbox color and appearance in your android application.

The radio button and checkbox button all take the default accent color for selection from your application. Changing the layout to something that you want is not that simple, but is very easy if you follow through correctly.

After reading this blog, you can change the default colors of all your radio button and checkbox( whether created through XML or through java code).

APPROACH

For changing the colors of selected/ checked button state to some color of your choice, all you need to do is to create a drawable with correct state mapped to colors of your choice and a default color and set it in your styles.xml file.

CODE :

my_compound_button_color_selector.xml

styles.xml

 

And all your Radio Button and Checkbox colors will be changed from this settings.

Now, let’s see how we can change the appearance, what I needed was the button on the right side of the text and doing this was pretty easy.

APPROACH :

Your compound button should have layout params of (width: match_parent and height: wrap_content). now you need to reverse the layout direction from the parent layout direction. I needed this in my dynamic views created at runtime from java files, so I am sharing the snippet from Java code, but you can execute the same from your xmls too.

CODE :

And with this code, you can change the appearance of your compound buttons(Radio Button and Checkbox).

After following this blog, the appearance of your compound buttons will be like this from this code.

 

 

. . .

Comments (6)

Add Your Comment

  • Salman
    Thanks
    • anchit
      Your Most Welcome @Salman
  • Rafael Baptista
    Thank you!!
  • Tomek
    it’s working
  • css.php
    Hire Us!
    Brief us about your requirements and we'll get back to you.
    Woo! Hooy!
    We have just recieved your project brief and our expert will contact you shortly.
    Send Again
    Close