iOS swift UISlider改变进度条的高度和圆形滑块的大小

文章目录

1.改变进度条的高度(亲测有效)

swift 复制代码
import UIKit

class CustomSlider: UISlider {
    // 设置轨道高度
    var trackHeight: CGFloat = 10

    // 重写 trackRect(forBounds:) 方法来自定义轨道的尺寸
    override func trackRect(forBounds bounds: CGRect) -> CGRect {
        // 获取默认的轨道矩形
        var rect = super.trackRect(forBounds: bounds)
        // 修改矩形的高度
        rect.size.height = trackHeight
        return rect
    }
}

// 使用示例
let slider = CustomSlider(frame: CGRect(x: 0, y: 0, width: 200, height: 30))
slider.trackHeight = 20 // 设置进度条的宽度为20点

2.改变圆形滑块的大小(亲测有效)

swift 复制代码
import UIKit

class ViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()

        // 创建 UISlider
        let slider = UISlider(frame: CGRect(x: 50, y: 100, width: 300, height: 50))
        self.view.addSubview(slider)

        // 创建一个50x50点的自定义滑块图像
        let thumbImage = UIImage(named: "customThumbImage") // 确保您有一个名为 "customThumbImage" 的50x50点的图像
        slider.setThumbImage(thumbImage, for: .normal)
    }
}
  • 用下面的方法圆形滑块的大小没有变化
swift 复制代码
import UIKit

class CustomSlider: UISlider {
    // 设置滑块的大小
    var thumbSize: CGSize = CGSize(width: 30, height: 30)

    // 重写 thumbRect 方法来自定义滑块的尺寸
    override func thumbRect(forBounds bounds: CGRect, trackRect rect: CGRect, value: Float) -> CGRect {
        // 获取默认的滑块矩形
        let defaultRect = super.thumbRect(forBounds: bounds, trackRect: rect, value: value)
        // 计算新的滑块矩形
        let newRect = CGRect(x: defaultRect.origin.x, y: defaultRect.origin.y + (defaultRect.size.height - thumbSize.height) / 2, width: thumbSize.width, height: thumbSize.height)
        return newRect
    }
}

// 使用示例
let slider = CustomSlider(frame: CGRect(x: 0, y: 0, width: 200, height: 30))
slider.thumbSize = CGSize(width: 40, height: 40) // 设置滑块的大小为40x40
相关推荐
橘子海全栈攻城狮23 分钟前
【源码+文档+调试讲解】实验室耗材管理系统springboot 094
java·开发语言·spring boot·后端·spring
范纹杉想快点毕业27 分钟前
《嵌入式硬件从入门到精通:电源 / 模电 / 数电 / 通信核心全解析》
java·开发语言·数据库·单片机·嵌入式硬件
Ryan ZX35 分钟前
【Go语言基础】Go语言开发环境搭建
开发语言·后端·golang
x***J3481 小时前
后端服务限流算法,计数器与滑动窗口
java·开发语言
二川bro1 小时前
第51节:Three.js源码解析 - 核心架构设计
开发语言·javascript·ecmascript
-大头.1 小时前
响应式编程实战:WebFlux与RSocket深度解析
java·开发语言
异步的告白1 小时前
C语言-数据结构-2-单链表程序-增删改查
c语言·开发语言·数据结构
CryptoRzz2 小时前
印度股票数据 PHP 对接文档 覆盖 BSE(孟买证券交易所)和 NSE(印度国家证券交易所)的实时数据
android·服务器·开发语言·区块链·php
lkbhua莱克瓦242 小时前
集合进阶6——TreeMap底层原理
java·开发语言·笔记·学习方法·hashmap
普通网友2 小时前
内存对齐与缓存友好设计
开发语言·c++·算法