Skip to content Skip to sidebar Skip to footer

How To Change Colour Of The Thumb In Seekbar?

I have the default seekbar in my android app. I noticed that when the thumb on the seekbar is held, it turns yellow. Instead, I want it to turn blue when it is held. How can this b

Solution 1:

Use image filters to change color of default State List Drawables (including SeekBar):

// Change seekbar color to green.SeekBarsb= (SeekBar) findViewById(R.id.seekBar1);
  sb.getProgressDrawable().setColorFilter(0xFF00FF00, PorterDuff.Mode.MULTIPLY);
  sb.getThumb().setColorFilter(0xFF00FF00, PorterDuff.Mode.MULTIPLY);

The method getThumb is only available since API 16+ (Jelly Bean).

Solution 2:

No need of additional styling. Android supports it via xml. Just add android:thumbTint="@color/yourColor" in your seekbar.

For eg.

<SeekBar
     android:layout_width="match_parent"
     android:layout_height="wrap_content"
     android:max="100"
     android:thumbTint="@color/red"
     android:progress="0" />

Solution 3:

If you don't like the default thumb, you will have to create your own Drawable, which you can then set the thumb in code with something like:

Drawablethumb= getResources().getDrawable( R.drawable.myThumb );
SeekBarmSeekBar= (SeekBar) findViewById(R.id.mySeekBar);
mSeekbar.setThumb(thumb);

Or you can set the thumb in XML with:

<SeekBar...android:thumb="@drawable/seek_thumb" />

The actual Drawable can be an image, shape, or any other kind of Drawable you could possibly desire. If you want the thumb to change appearance when it is pressed, you will want to create a State List Drawable.

Post a Comment for "How To Change Colour Of The Thumb In Seekbar?"