Swift5学习之旅之UISlider(滑块控制)、UIStepper(步进控制)

2023-11-02 15:08

本文主要是介绍Swift5学习之旅之UISlider(滑块控制)、UIStepper(步进控制),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Swift5学习之旅----UISlider(滑块控制)、UIStepper(步进控制)

在这里插入图片描述

  • UISlider

相关功能代码

import UIKitclass MySlider: UISlider {override init(frame: CGRect) {super.init(frame: frame)}required init?(coder: NSCoder) {fatalError("init(coder:) has not been implemented")}func slider(){self.minimumValue = 0.0self.maximumValue = 100.0self.setValue(20, animated: true)//两端的图标、滑动条的颜色self.minimumValueImage = UIImage(systemName: "slider.horizontal.3")self.maximumValueImage = UIImage(systemName: "slider.horizontal.below.rectangle")self.minimumTrackTintColor = UIColor.blackself.maximumTrackTintColor = UIColor.gray
//        self.minimumTrackImage(for: .highlighted)// 滑块滑动停止后才触发ValueChanged事件self.isContinuous = false//滑块的设计self.thumbTintColor = UIColor.greenself.setThumbImage(UIImage(systemName: "heart"), for: .normal)self.setThumbImage(UIImage(systemName: "heart"), for: .highlighted)}}
  • 根据Slider、Stepper自定义贝塞斯达曲线

在这里插入图片描述

import UIKitclass CircleProgressView: UIView {let circleLayer = CAShapeLayer()let progressLayer = CAShapeLayer()
//    var progress: CGFloat = 0.0override init(frame: CGRect){super.init(frame: frame)draw(frame)}required init?(coder: NSCoder) {fatalError("init(coder:) has not been implemented")}override func draw(_ rect: CGRect) {super.draw(rect)//画出一个环形的layercircleLayer.frame = self.boundsself.layer.addSublayer(circleLayer)circleLayer.fillColor = UIColor.clear.cgColorcircleLayer.strokeColor = UIColor.gray.cgColorcircleLayer.opacity = 0.2circleLayer.lineWidth = 5//勾勒layer的轨迹,贝塞斯达曲线let path: UIBezierPath = UIBezierPath(arcCenter: CGPoint(x: frame.size.width / 2.0, y: frame.size.height / 2.0), radius: 90, startAngle: CGFloat(Double.pi * -210) / 180.0, endAngle: CGFloat(Double.pi * 30) / 180.0, clockwise: true)circleLayer.path = path.cgPath//设置进度layerprogressLayer.frame = boundsprogressLayer.fillColor = UIColor.clear.cgColorprogressLayer.strokeColor = UIColor.red.cgColorprogressLayer.lineCap = .roundprogressLayer.lineWidth = 9progressLayer.path = path.cgPathprogressLayer.strokeEnd = 0.2self.layer.addSublayer(progressLayer)}}
  • UIStepper
    相关代码
import UIKitclass MyStepper: UIStepper {override init(frame: CGRect) {super.init(frame: frame)self.maximumValue = 100self.minimumValue = 0self.value = 20self.stepValue = 1//设置stepper可以按住不放连续更改值self.isContinuous = true}required init?(coder: NSCoder) {fatalError("init(coder:) has not been implemented")}
}
  • 三者之间的联系实现
class ViewController: UIViewController {
//    let frame:CGRect = CGRect(x: 100, y: 400, width: 300, height: 300)override func viewDidLoad() {super.viewDidLoad()// Do any additional setup after loading the view.let slider = MySlider(frame: CGRect(x: 40, y: 100, width: self.view.bounds.width - 100, height: 40))slider.tag = 997slider.slider()self.view.addSubview(slider)let label = Mylabel(frame: CGRect(x: 80, y: 200, width: 200, height: 40))label.tag = 1000self.view.addSubview(label)// 响应事件slider.addTarget(self, action: #selector(sliderValueChange(slider:)), for: UIControl.Event.valueChanged)let activityIndicator = MyActivity(frame: CGRect(x: 50, y: 300, width: 50, height: 50))self.view.addSubview(activityIndicator)let circle = CircleProgressView(frame: CGRect(x: 100, y: 400, width: 300, height: 300))circle.tag = 999self.view.addSubview(circle)let stepper = MyStepper(frame: CGRect(x: 100, y: 700, width: 100, height: 100))stepper.addTarget(self, action: #selector(stepperValueChange(stepper:)), for: .valueChanged)stepper.tag = 998self.view.addSubview(stepper)}@objc func sliderValueChange(slider: UISlider){let value = slider.valuelet stepper = self.view.viewWithTag(998) as! UIStepperstepper.value = Double(value)let lab: UILabel = self.view.viewWithTag(1000) as! UILabellab.text = String(format: "slider当前值为:%.2f", arguments: [value])let circleView: CircleProgressView = self.view.viewWithTag(999) as! CircleProgressViewcircleView.progressLayer.strokeEnd = CGFloat(value/100)print("slider当前值是\(value)")}@objc func stepperValueChange(stepper: UIStepper){let value = stepper.valuelet slider = self.view.viewWithTag(997) as! UISliderslider.value = Float(value)stepper.value = Double(value)let lab: UILabel = self.view.viewWithTag(1000) as! UILabellab.text = String(format: "slider当前值为:%.2f", arguments: [value])let circleView: CircleProgressView = self.view.viewWithTag(999) as! CircleProgressViewcircleView.progressLayer.strokeEnd = CGFloat(value/100)print("slider当前值是\(value)")}
}
  • 整体代码

Github还没上传,先用着Dropbox吧,看完有收获的感谢点个赞👍

Dropbox连接
https://www.dropbox.com/sh/g1l8cqg5jp5j5a9/AAAli9UDDtDls00DfZWISc-Ha?dl=0
Dropbox Slider

这篇关于Swift5学习之旅之UISlider(滑块控制)、UIStepper(步进控制)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/331444

相关文章

Spring如何使用注解@DependsOn控制Bean加载顺序

《Spring如何使用注解@DependsOn控制Bean加载顺序》:本文主要介绍Spring如何使用注解@DependsOn控制Bean加载顺序,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录1.javascript 前言2. 代码实现总结1. 前言默认情况下,Spring加载Bean的顺

基于Python开发Windows屏幕控制工具

《基于Python开发Windows屏幕控制工具》在数字化办公时代,屏幕管理已成为提升工作效率和保护眼睛健康的重要环节,本文将分享一个基于Python和PySide6开发的Windows屏幕控制工具,... 目录概述功能亮点界面展示实现步骤详解1. 环境准备2. 亮度控制模块3. 息屏功能实现4. 息屏时间

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Python远程控制MySQL的完整指南

《Python远程控制MySQL的完整指南》MySQL是最流行的关系型数据库之一,Python通过多种方式可以与MySQL进行交互,下面小编就为大家详细介绍一下Python操作MySQL的常用方法和最... 目录1. 准备工作2. 连接mysql数据库使用mysql-connector使用PyMySQL3.

如何搭建并配置HTTPD文件服务及访问权限控制

《如何搭建并配置HTTPD文件服务及访问权限控制》:本文主要介绍如何搭建并配置HTTPD文件服务及访问权限控制的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、安装HTTPD服务二、HTTPD服务目录结构三、配置修改四、服务启动五、基于用户访问权限控制六、

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

MySQL精准控制Binlog日志数量的三种方案

《MySQL精准控制Binlog日志数量的三种方案》作为数据库管理员,你是否经常为服务器磁盘爆满而抓狂?Binlog就像数据库的“黑匣子”,默默记录着每一次数据变动,但若放任不管,几天内这些日志文件就... 目录 一招修改配置文件:永久生效的控制术1.定位my.cnf文件2.添加核心参数不重启热更新:高手应

重新对Java的类加载器的学习方式

《重新对Java的类加载器的学习方式》:本文主要介绍重新对Java的类加载器的学习方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍1.1、简介1.2、符号引用和直接引用1、符号引用2、直接引用3、符号转直接的过程2、加载流程3、类加载的分类3.1、显示

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

SpringBoot请求参数接收控制指南分享

《SpringBoot请求参数接收控制指南分享》:本文主要介绍SpringBoot请求参数接收控制指南,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Spring Boot 请求参数接收控制指南1. 概述2. 有注解时参数接收方式对比3. 无注解时接收参数默认位置