Make UISlider height larger?

33,784

Solution 1

I found what I was looking for. The following method just needs to be edited in a subclass.

override func trackRect(forBounds bounds: CGRect) -> CGRect {
   var customBounds = super.trackRect(forBounds: bounds)
   customBounds.size.height = ...
   return customBounds
}

Solution 2

The accepted answer will undesirably change the slider's width in some cases, like if you're using a minimumValueImage and maximumValueImage. If you only want to change the height and leave everything else alone, then use this code:

override func trackRect(forBounds bounds: CGRect) -> CGRect {
   var newBounds = super.trackRect(forBounds: bounds)
   newBounds.size.height = 12
   return newBounds
}

Solution 3

Here's my recent swifty implementation, building on CularBytes's ...

open class CustomSlider : UISlider {
    @IBInspectable open var trackWidth:CGFloat = 2 {
        didSet {setNeedsDisplay()}
    }

    override open func trackRect(forBounds bounds: CGRect) -> CGRect {
        let defaultBounds = super.trackRect(forBounds: bounds)
        return CGRect(
            x: defaultBounds.origin.x,
            y: defaultBounds.origin.y + defaultBounds.size.height/2 - trackWidth/2,
            width: defaultBounds.size.width,
            height: trackWidth
        )
    }
}

Use this on a UISlider in a storyboard by setting its custom class Custom class setting

The IBInspectable allows you to set the height from the storyboard Height from storyboard

Solution 4

For those that would like to see some working code for changing the track size.

class CustomUISlider : UISlider {

    override func trackRect(forBounds bounds: CGRect) -> CGRect {

        //keeps original origin and width, changes height, you get the idea
        let customBounds = CGRect(origin: bounds.origin, size: CGSize(width: bounds.size.width, height: 5.0))
        super.trackRect(forBounds: customBounds)
        return customBounds
    }

    //while we are here, why not change the image here as well? (bonus material)
    override func awakeFromNib() {
        self.setThumbImage(UIImage(named: "customThumb"), for: .normal)
        super.awakeFromNib()
    }
}

Only thing left is changing the class inside the storyboard:

storyboardstuff

You can keep using your seekbar action and outlet to the object type UISlider, unless you want to add some more custom stuff to your slider.

Share:
33,784
Josue Espinosa
Author by

Josue Espinosa

LinkedIn / GitHub / Portfolio

Updated on July 09, 2022

Comments

  • Josue Espinosa
    Josue Espinosa almost 2 years

    I've been searching for a way to make the UISlider progress bar taller, like increasing the height of the slider but couldn't find anything. I don't want to use a custom image or anything, just make it taller, so the UISlider doesn't look so thin. Is there an easy way to do this that I'm missing?

  • Cutetare
    Cutetare almost 10 years
    This is good (and works), but don't forget to call bounds = [super trackRectForBounds:bounds]; or else it will change the slider frame..
  • Michael
    Michael over 8 years
    Meh. This works but it messes the alignment of the UISlider up quite a bit and the setThumbImage function doesn't work.
  • CularBytes
    CularBytes over 8 years
    Please elaborate why it messes the alignment up? Are you sure setThumbImage doesn't work? I've just checked in Xcode 7.0 beta, Swift 2.0
  • Michael
    Michael over 8 years
    I think the origin isn't centering it vertically (like the default UISlider). I just added a top constraint to counter it.
  • Iulian Onofrei
    Iulian Onofrei over 8 years
    @Cutetare, Why would you need to call the super trackRectForBounds: method if you want to pass your own bounds?
  • Mark Bourke
    Mark Bourke almost 8 years
    Because this changes the whole frame instead of just the bar like the question stated and doesn't re-adjust the corner radius or the thumb slider frames so everything looks disproportionate.
  • CularBytes
    CularBytes over 7 years
    @BrightFuture Are you sure forBounds bounds is swift 3? Is the complete code working on swift 3? I'm not currently into swift 3 development but just want to verify, looks odd.
  • Bright
    Bright over 7 years
    @CularBytes yes it does, the code is converted by Xcode
  • Fernando Mata
    Fernando Mata about 6 years
    Just as an extra step, you can add newBounds.origin.y -= 6 (or your new value divided by 2) just to be sure it's centered in Y with the new thickness value.
  • Tim
    Tim over 5 years
    @FernandoMata not quite 6... need to subtract (newHeight-originalHeight)/2 from y
  • mgarciaisaia
    mgarciaisaia about 5 years
    The @IBInspectable is an amazing addition 👍
  • Bijender Singh Shekhawat
    Bijender Singh Shekhawat almost 4 years
    Thanx bro for this.