Swift39/90Days - 如何实现圆形加载进度条
发布时间:2020-12-14 02:20:15 所属栏目:百科 来源:网络整理
导读:Swift90Days - 如何实现圆形加载进度条 今天照着 raywenderlich 的教程学习了一下使用 CAShapeLayer 实现一个原型的加载指示器。完成效果如图: 后面显示图片的动画暂且不谈,先说这个红色的圆环动画。 通过自定义一个 UIView 实现了这个红色的加载指示器,
Swift90Days - 如何实现圆形加载进度条今天照着 raywenderlich 的教程学习了一下使用 CAShapeLayer 实现一个原型的加载指示器。完成效果如图:
后面显示图片的动画暂且不谈,先说这个红色的圆环动画。 通过自定义一个 let circlePathLayer = CAShapeLayer() let circleRadius: CGFloat = 20.0 func configure() { circlePathLayer.frame = bounds circlePathLayer.lineWidth = 2 circlePathLayer.fillColor = UIColor.clearColor().CGColor circlePathLayer.strokeColor = UIColor.redColor().CGColor layer.addSublayer(circlePathLayer) backgroundColor = UIColor.whiteColor() progress = 0 } 其实也没什么,就是设置 override func layoutSubviews() { super.layoutSubviews() circlePathLayer.frame = bounds circlePathLayer.path = UIBezierPath(ovalInRect: circleFrame()).CGPath } 至于动画,则是通过 var progress: CGFloat { get { return circlePathLayer.strokeEnd } set { if (newValue > 1) { circlePathLayer.strokeEnd = 1 } else if (newValue < 0) { circlePathLayer.strokeEnd = 0 } else { circlePathLayer.strokeEnd = newValue } } } 嗯挺简单也挺实用的,刚好公司里面有用到。完整的教程和项目源码见原文。 原文链接:
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |