Swift版本仿网易云音乐播放音乐动画效果

个人技术博客站欢迎您


创建一个继承于UIView的视图我们叫他XTActivityView

/// 立方柱的个数
    var numberOfRect = 0;
        /// 立方柱的颜色
    var rectBackgroundColor: UIColor?
        /// 立方柱初始化大小
    var defaultSize: CGSize?
        /// 立方柱之间的间距
    var space: CGFloat = 0.0

进行初始化

override init(frame: CGRect) {
        super.init(frame: frame)
        self.createDefaultAttribute(frame)
    }
func createDefaultAttribute(frame: CGRect) -> Void {
        numberOfRect = 6;
        self.rectBackgroundColor = UIColor.blackColor()
        space = 1;
        defaultSize = frame.size
    }

提供开始和结束接口(即创建和移除)

func startAnimation() {
        self.addRect()
    }
func stopAnimation() {
        self.removeRect()
    }

添加矩形

func addRect() -> Void {
        self.removeRect()
        self.hidden = false
        for  i in 0...numberOfRect {
        let x = (CGFloat)(i) * (5 + space)
        let rView = UIView.init(frame: CGRectMake(x,0,5,defaultSize!.height))
            rView.backgroundColor = rectBackgroundColor
            rView.layer.addAnimation(self.addAnimateWithDelay((Double)(i) * 0.2),forKey: "Tbrotate")
        self.addSubview(rView)
        }
    }

动画效果

func addAnimateWithDelay(delay: Double) -> CAAnimation {
        let animation = CABasicAnimation.init(keyPath: "transform.rotation.x")
        animation.repeatCount = MAXFLOAT;
        animation.removedOnCompletion = true;
        animation.autoreverses = false;
        animation.timingFunction = camediatimingFunction.init(name: kcamediatimingFunctionLinear)
        animation.fromValue = NSNumber.init(float: 0)
        animation.tovalue = NSNumber.init(double: M_PI)
        animation.duration = (Double)(numberOfRect) * 0.2;
        animation.beginTime = CACurrentMediaTime() + delay;
        return animation;
    }

移除矩形

func removeRect() -> Void {
        if self.subviews.count > 0 {
            self.removeFromSuperview()
        }
        self.hidden = true
    }

在控制器中调用

self.view.backgroundColor = UIColor.whiteColor()
let xt = XTActivityView.init(frame: CGRectMake(0,10,80,15))
xt.startAnimation()
self.navigationItem.rightBarButtonItem = UIBarButtonItem.init(customView: xt)
xt.performSelector(Selector("stopAnimation"),withObject: nil,afterDelay: 5)

各位大大我是demo地址 点赞喔
个人技术博客站欢迎您

相关文章

软件简介:蓝湖辅助工具,减少移动端开发中控件属性的复制和粘...
现实生活中,我们听到的声音都是时间连续的,我们称为这种信...
前言最近在B站上看到一个漂亮的仙女姐姐跳舞视频,循环看了亿...
【Android App】实战项目之仿抖音的短视频分享App(附源码和...
前言这一篇博客应该是我花时间最多的一次了,从2022年1月底至...
因为我既对接过session、cookie,也对接过JWT,今年因为工作...