最近项目用到了蓝牙连接,搜索设备的内容,其中需要搜索过程中出现波纹的动画效果,在这里将项目中OC语言编写的这种动画效果,转换成Swift编写,下面简单介绍说明一下代码。

这里用到了两种方法实现波纹效果,一种是波纹持续显示,一种是点击以后出现一次波纹的效果

首先是第一种,持续显示波纹

这个内容是重写绘图方法,override func drawRect(rect: CGRect){ }

首先需要设置显示波纹的数量,然后运用for循环进行创建,动画效果,并且添加到layer上

let pulsingCountT:NSInteger = 4;
        let animationDurationN:Double = 4;
        let animationLayerR = CALayer.init();
        for i in 0 ..< pulsingCountT {
            let pulsingLayer = CALayer.init();
            pulsingLayer.frame = CGRectMake(0, 0, rect.size.width, rect.size.height);
            pulsingLayer.borderColor = UIColor.redColor().CGColor;
            pulsingLayer.borderWidth = 1;
            pulsingLayer.cornerRadius = rect.size.height/2;
            
            let defaultCurveE = CAMediaTimingFunction.init(name: kCAMediaTimingFunctionDefault);
            
            let animationGroupP = CAAnimationGroup.init();
            animationGroupP.fillMode = kCAFillModeBackwards;
            animationGroupP.beginTime = CACurrentMediaTime() + Double(i) * animationDurationN / Double(pulsingCountT);
            animationGroupP.duration = animationDurationN;
            animationGroupP.repeatCount = HUGE;
            animationGroupP.timingFunction = defaultCurveE;
            
            let scaleAnimationN = CABasicAnimation.init(keyPath: "transform.scale");
            scaleAnimationN.fromValue = 1.4;
            scaleAnimationN.toValue = 2.2;
            
            let opacityAnimationN = CAKeyframeAnimation.init(keyPath: "opacity");
            opacityAnimationN.values = [1,0.9,0.8,0.7,0.6,0.5,0.4,0.3,0.2,0.1,0];
            opacityAnimationN.keyTimes = [0,0.1,0.2,0.3,0.4,0.5,0.6,0.7,0.8,0.9,1];
            
            animationGroupP.animations = [scaleAnimationN,opacityAnimationN];
            pulsingLayer.addAnimation(animationGroupP, forKey: "plulsing");
            animationLayerR.addSublayer(pulsingLayer);
            
        }
        self.layer.addSublayer(animationLayerR);

绘图完成后,进行添加

//圈视图
        circleV = CircleView.init();
        circleV.frame = CGRectMake(100, 60, 100, 100);
        circleV.hidden = true;
        circleV.backgroundColor = UIColor.clearColor();
        self.view.addSubview(circleV);
        //类方法的调用,只能类本事调用,与OC中的类方法(加号)形式一样
        CircleView.showLogStr();
        
        //点击出现圈视图,第一种持续扩散的圈
        let button1 = UIButton.init(frame: CGRectMake(100, 60, 100, 100));
        button1.setTitle("开启搜索", forState: .Normal);
        button1.backgroundColor = UIColor.yellowColor();
        button1.layer.cornerRadius = 50;
        button1.clipsToBounds = true;
        button1.setTitleColor(UIColor.blueColor(), forState: .Normal);
        button1.addTarget(self, action: #selector(button1Click), forControlEvents: .TouchUpInside);
        self.view.addSubview(button1);

//按钮的点击事件
    func button1Click(btn:UIButton) {
        circleV.hidden = false;
    }

然后是实现点击出现一次波纹的效果

这里用到了类似于OC中类别category文件的实现,使用extension创建类似于类别文件:extension UIView { }

//创建可点击出现的圆圈方法,参数一:表示圈的颜色,参数二:表示圈相对于View扩散的比例大小
    func showCircleAnimationLayerWithColor(circleColor:UIColor,andScale aScale:CGFloat){
        if (self.superview == false) && (circleColor == true) {
            return;
        }
        
        let pathFrameE = CGRectMake(-CGRectGetMidX(self.bounds), -CGRectGetMidY(self.bounds), self.bounds.size.width, self.bounds.size.height);
        
        let pathH = UIBezierPath.init(roundedRect: pathFrameE, cornerRadius: self.layer.cornerRadius);
        
        let shapePositionN = self.superview?.convertPoint(self.center, fromView: self.superview);
        
        //内圈1
        let circleShapeE1 = CAShapeLayer.init();
        circleShapeE1.path = pathH.CGPath;
        circleShapeE1.position = shapePositionN!;
        circleShapeE1.fillColor = UIColor.clearColor().CGColor;
        //不透明
        circleShapeE1.opacity = 0;
        circleShapeE1.strokeColor = circleColor.CGColor;
        circleShapeE1.lineWidth = 0.6;
        self.superview?.layer.addSublayer(circleShapeE1);
        
        let scaleAnimationN1 = CABasicAnimation.init(keyPath: "transform.scale");
        scaleAnimationN1.fromValue = NSValue.init(CATransform3D: CATransform3DIdentity);
        scaleAnimationN1.toValue = NSValue.init(CATransform3D: CATransform3DMakeScale(aScale, aScale, 1));
        scaleAnimationN1.duration = 2;
        scaleAnimationN1.timingFunction = CAMediaTimingFunction.init(name: kCAMediaTimingFunctionLinear);
        circleShapeE1.addAnimation(scaleAnimationN1, forKey: nil);
        
        let alphaAnimationN1 = CABasicAnimation.init(keyPath: "opacity");
        alphaAnimationN1.fromValue = 1;
        alphaAnimationN1.toValue = 0;
        alphaAnimationN1.duration = 1.8;
        alphaAnimationN1.timingFunction = CAMediaTimingFunction.init(name: kCAMediaTimingFunctionEaseOut);
        circleShapeE1.addAnimation(alphaAnimationN1, forKey: nil);
        
        //内圈2
        let circleShapeE2 = CAShapeLayer.init();
        circleShapeE2.path = pathH.CGPath;
        circleShapeE2.position = shapePositionN!;
        circleShapeE2.fillColor = circleColor.CGColor;
        //不透明
        circleShapeE2.opacity = 0;
        circleShapeE2.strokeColor = UIColor.clearColor().CGColor;
        circleShapeE2.lineWidth = 0;
        self.superview?.layer.insertSublayer(circleShapeE2, atIndex: 0);
        
        let scaleAnimationN2 = CABasicAnimation.init(keyPath: "transform.scale");
        scaleAnimationN2.fromValue = NSValue.init(CATransform3D: CATransform3DIdentity);
        scaleAnimationN2.toValue = NSValue.init(CATransform3D: CATransform3DMakeScale(aScale, aScale, 1));
        scaleAnimationN2.duration = 2;
        scaleAnimationN2.timingFunction = CAMediaTimingFunction.init(name: kCAMediaTimingFunctionLinear);
        circleShapeE2.addAnimation(scaleAnimationN2, forKey: nil);
        
        let alphaAnimationN2 = CABasicAnimation.init(keyPath: "opacity");
        alphaAnimationN2.fromValue = 0.8;
        alphaAnimationN2.toValue = 0;
        alphaAnimationN2.duration = 1.7;
        alphaAnimationN2.timingFunction = CAMediaTimingFunction.init(name: kCAMediaTimingFunctionEaseOut);
        circleShapeE2.addAnimation(alphaAnimationN2, forKey: nil);
        
        //线程
        let timeE:dispatch_time_t = dispatch_time(DISPATCH_TIME_NOW, 2*Int64(NSEC_PER_SEC));
        dispatch_after(timeE, dispatch_get_main_queue()) {
            circleShapeE1.removeFromSuperlayer();
            circleShapeE2.removeFromSuperlayer();
        };
    }

方法的调用:

//第二种方式,点击出现一个圈视图,而不是持续
        let button2 = UIButton.init(frame: CGRectMake(100, 270, 120, 60));
        //根据width与height,1:2的比例创建一个椭圆视图
        button2.updateMaskToBounds(button2.bounds);
        button2.setTitle("点击", forState: .Normal);
        button2.backgroundColor = UIColor.yellowColor();
        //button2.layer.cornerRadius = 30;
        button2.clipsToBounds = true;
        button2.setTitleColor(UIColor.blueColor(), forState: .Normal);
        button2.addTarget(self, action: #selector(button2Click), forControlEvents: .TouchUpInside);
        self.view.addSubview(button2);

按钮点击方法

func button2Click(btn:UIButton) {
        btn.showCircleAnimationLayerWithColor(UIColor.whiteColor(), andScale: 3);
    }

效果图:

源代码Demo(还有类方法的使用):http://download.csdn.net/detail/hbblzjy/9631221

Swift基础之显示波纹样式的更多相关文章

  1. Swift基础语法学习总结(转)

    Swift基础语法学习总结 1.基础  1.1) swift还是使用// 和/* */ 来注释,并且/* */允许多行注释. 1.2) swift使用print和println打印,它的传参是一个泛型 ...

  2. Swift基础语法学习总结

    Swift基础语法学习总结Swift高级语法学习总结Swift语法总结补充(一) 1.基础  1.1) swift还是使用// 和/* */ 来注释,并且/* */允许多行注释. 1.2) swift ...

  3. Swift基础之PickerView(时间)选择器

    代码讲解:(后面有额外代码讲解) 首页设计UIPickerView的样式设计: leftArray = ["花朵","颜色","形状"]; ...

  4. swift基础:第六部分:类与对象

    http://reactnative.cn/docs/0.24/getting-started.html#content(react Native 开发文档) 互联网这个时代,你松懈一天,就会有很多很 ...

  5. swift基础:第二部分:函数和闭包

    今天本来想利用上午的时间本来打算将swift基础部分学习完的,不巧的是,后台来和我讨论用户评价的接口,讨论过后,商讨出一种可行的方案,十几分钟时间过去了,我拿到将接口介入到已经完成的页面中,完美,终于 ...

  6. Android项目实战(十四):TextView显示html样式的文字

    项目需求: TextView显示一段文字,格式为:(消息个数,不确定)条消息 这段文字中名字和数字的长度是不确定的,还要求名字和数字各自有各自的颜色. 一开始我想的是用(转) SpannableStr ...

  7. swift -- 基础

    swift -- 基础 1.常量和变量 常量: let 变量: var 2.声明常量和变量 常量的声明: let let  a = 1         //末尾可以不加分号,等号两边的空格必须对应(同 ...

  8. iOS Swift 模块练习/swift基础学习

    SWIFT项目练习     SWIFT项目练习2 iOS Swift基础知识代码 推荐:Swift学习使用知识代码软件 0.swift中的宏定义(使用方法代替宏) 一.视图  +控件 1.UIImag ...

  9. Swift基础学习

    Swift基础学习  http://c.biancheng.net/cpp/html/2242.html 这个网站最近看了一下,对于基本语法解释概括的相对全面,如同重新练习一遍OC似的,挺全面的,谢谢 ...

随机推荐

  1. 【Tensorflow系列】使用Inception_resnet_v2训练自己的数据集并用Tensorboard监控

    [写在前面] 用Tensorflow(TF)已实现好的卷积神经网络(CNN)模型来训练自己的数据集,验证目前较成熟模型在不同数据集上的准确度,如Inception_V3, VGG16,Inceptio ...

  2. 第一次C语言作业

    1. 求圆的面积和周长 输入圆的半径,求圆的周长和面积 流程图 测试结果: 实验问题:1.加号输入到引号内部导致运算终止 解决办法:通过改正加号位置是算法正确并继续运行 2判断闰年 输入一个四位年份, ...

  3. 反向Ajax之Socket.io

    1.什么是反向ajax? 传统的ajax的困惑? 新需求--当服务器端数据发生变化时,客户端(浏览器端)如何即时得到通知呢? 找一些实际的案例:客服系统.在线聊天 这类应用,有一个显著的特点: 数据并 ...

  4. 关于一些基础的Java问题的解答(二)

    6. Hashcode的作用 官方对于hashCode的解释如下: Whenever it is invoked on the same object more than once during an ...

  5. 利用create-react-app结合react-redux、react-router4构建单页应用

    1.创建项目: a.全局安装create-react-app: npm  install  create-react-app  -g b.执行create-react-app  my-projectN ...

  6. 学习C语言第一天!

    整理心得笔记: 1)c语言程序由函数构成,每个函数可以实现一个或多个功能.  2)一个正规程序可以有多个函数,但是有且只有一个主函数.  3)函数只有在被调用的时候才执行,主函数由系统调用执行.  4 ...

  7. opencv视屏流嵌入wxpython框架

    前几篇博客分享搭建人脸识别与情绪判断的环境和源码,但是没有UI,界面很难看,一打开就是opencv弹出的一个视屏框.处女座的我看着非常难受,于是决定做一个UI,稍微规矩好看一点,再怎么说,这样的话也算 ...

  8. 深度解读GoogleNet之Inception V1

    GoogleNet设计的目的 GoogleNet设计的初衷是为了提高在网络里面的计算资源的利用率. Motivation 网络越大,意味着网络的参数较多,尤其当数据集很小的时候,网络更容易发生过拟合. ...

  9. android 获取栈顶activty的方法总结(兼容API 5.0)

    声明:本文为Dujinyang CSDN原创投稿文章,未经许可,禁止任何形式的转载. 最近5.0\6.0\7.0 安卓系统都陆续上岗了,兼容性和代码更新是个很头疼的问题,这次我们来说下TASK的基础和 ...

  10. synchronized与条件同步

    在并发编程中,有这样的需求:当满足某个条件时线程执行同步块中的代码,条件不满足时,让线程在此等待,直至条件满足再执行同步代码块. java的Object类即提供了一类这样的方法wait(),notif ...