詳解UISlider(見た目をカスタマイズのいろは)

Sliderの色を変える

minimumTrackTintColorとmaximumTrackTintColorで左右の色を変更することができます

コード

slider.minimumTrackTintColor = .red
slider.maximumTrackTintColor = .green

両橋に画像を設定する

コード

slider.minimumValueImage = UIImage(named: "uni_cabbage")
slider.maximumValueImage = UIImage(named: "cooking_lemon")

背景を変更する

画像のサイズに関してはそのまま表示されてしまうので高さを自分で調節する必要があります。今回はデフォルトのUISliderの高さが30だったので画像の高さを30にして検証しています。

コード

let trackImg = UIImage(named: "bg_himawari_hatake_wide")!.resizableImage(withCapInsets: .zero, resizingMode: .tile)
slider.setMinimumTrackImage(trackImg, for: .normal)
slider.setMaximumTrackImage(trackImg, for: .normal)

つまみの画像を変更する

つまみに関しても背景画像と同じようにそのままのサイズでぶち込むとデカすぎるので高さを30に修正してから画像を入れています。

コード

slider.setThumbImage(UIImage(named: "sliderButton")!.resizableImage(withCapInsets: .zero, resizingMode: .tile), for: .normal)

タップ領域

UISliderのタップ領域に関しては高さの制約と画像を差し替えることで可能です。

Slider自体のScaleとかをいじれば標準のものでも実現できると思うのですがそちらは試していません。

UISliderの高さの制約を60にして画像の高さも60に合わせてみたときの挙動です。高さがわかりにくいのでUISliderに背景色を入れています。

タップで移動

コード

override func viewDidLoad() {
    super.viewDidLoad()
    
    let tapGestureRecognizer = UITapGestureRecognizer(target: self, action: #selector(sliderTapped(gestureRecognizer:)))
    self.slider.addGestureRecognizer(tapGestureRecognizer)
}

@objc func sliderTapped(gestureRecognizer: UIGestureRecognizer) {

   let pointTapped: CGPoint = gestureRecognizer.location(in: self.view)

   let positionOfSlider: CGPoint = slider.frame.origin
   let widthOfSlider: CGFloat = slider.frame.size.width
   let newValue = ((pointTapped.x - positionOfSlider.x) * CGFloat(slider.maximumValue) / widthOfSlider)

   slider.setValue(Float(newValue), animated: true)
}

参考文献

iPhone UISliderバーの画像を変更する

Tap on UISlider to Set the Value

【Swift】UISliderでminimumTrackTintColorが上手く変更できない場合