zoukankan      html  css  js  c++  java
  • 用path动画绘制水波纹

    用path动画绘制水波纹

    效果

    源码

    //
    //  ViewController.m
    //  PathAnimation
    //
    //  Created by YouXianMing on 15/7/3.
    //  Copyright (c) 2015年 YouXianMing. All rights reserved.
    //
    
    #import "ViewController.h"
    
    @interface ViewController ()
    
    @property (nonatomic, strong)  CAShapeLayer   *animationLayer;
    @property (nonatomic, strong)  NSTimer        *timer;
    
    @property (nonatomic)          CGPathRef       oldPath;
    @property (nonatomic)          CGPathRef       path;
    
    @end
    
    @implementation ViewController
    
    - (void)viewDidLoad {
        [super viewDidLoad];
        
        self.animationLayer               = [CAShapeLayer layer];
        self.animationLayer.borderWidth   = 0.5f;
        self.animationLayer.frame         = CGRectMake(0, 0, 200, 200);
        self.animationLayer.position      = self.view.center;
        self.animationLayer.path          = [self createPath].CGPath;
        self.animationLayer.fillColor     = [UIColor redColor].CGColor;
        [self.view.layer addSublayer:self.animationLayer];
        _timer = [NSTimer scheduledTimerWithTimeInterval:0.5f target:self selector:@selector(event) userInfo:nil repeats:YES];
    }
    
    - (void)event {
        
        _oldPath = self.animationLayer.path;
        _path    = [self createPath].CGPath;
        
        CABasicAnimation *basicAnimation   = [CABasicAnimation animationWithKeyPath:@"path"];
        basicAnimation.duration            = 0.5;
        basicAnimation.fromValue           = (__bridge id)(_oldPath);
        basicAnimation.toValue             = (__bridge id)_path;
        self.animationLayer.path           = _path;
        
        [self.animationLayer addAnimation:basicAnimation forKey:@"animateCirclePath"];
    }
    
    - (UIBezierPath *)createPath {
        
        static int count = 0;
        
        CGFloat controlPoint1_X = 0;
        CGFloat controlPoint1_Y = 0;
        CGFloat controlPoint2_X = 0;
        CGFloat controlPoint2_Y = 0;
        
        if (count ++ % 2 == 0) {
            
            controlPoint1_X = [self randomNum_70_79];
            controlPoint1_Y = [self randomNum_70_79];
            
            controlPoint2_X = [self randomNum_120_129];
            controlPoint2_Y = [self randomNum_120_129];
            
        } else {
        
            controlPoint1_X = [self randomNum_70_79];
            controlPoint1_Y = [self randomNum_120_129];
            
            controlPoint2_X = [self randomNum_120_129];
            controlPoint2_Y = [self randomNum_70_79];
            
        }
        
        // 获取贝塞尔曲线
        UIBezierPath* bezierPath = [UIBezierPath bezierPath];
        
        // A
        [bezierPath moveToPoint:CGPointMake(0, 100)];
        
        // B (Curve)
        [bezierPath addCurveToPoint:CGPointMake(200, 100)
                      controlPoint1:CGPointMake(controlPoint1_X, controlPoint1_Y)
                      controlPoint2:CGPointMake(controlPoint2_X, controlPoint2_Y)];
        
        // C
        [bezierPath addLineToPoint:CGPointMake(200, 200)];
        
        // D
        [bezierPath addLineToPoint:CGPointMake(0, 200)];
        
        // 闭合曲线
        [bezierPath closePath];
        
        return bezierPath;
    }
    
    /**
     *  随机数 70 - 79
     *
     *  @return 随机数
     */
    - (CGFloat)randomNum_70_79 {
    
        return (CGFloat)(arc4random() % 10 + 70);
    }
    
    /**
     *  随机数 120 - 129
     *
     *  @return 随机数
     */
    - (CGFloat)randomNum_120_129 {
    
        return (CGFloat)(arc4random() % 10 + 120);
    }
    
    @end

    核心

  • 相关阅读:
    理解CNN卷积层与池化层计算
    大话卷积神经网络(CNN)
    给你一个卷积神经网络工作原理最直观的解释
    Tensorflow快餐教程(9)
    Thymeleaf学习内容
    Thymeleaf分页
    Springmvc+Hibernate在Eclipse启动Tomcat需要很长时间的解决方法
    通过hibernate session.connection()获得数据库连接时,导致的查询缓慢甚至假死机问题
    springmvc入门基础之注解和参数传递
    eclipse下启动tomcat出现Setting property 'source' to 'org.eclipse.jst.jee.server: '错误的解决办法
  • 原文地址:https://www.cnblogs.com/YouXianMing/p/4619746.html
Copyright © 2011-2022 走看看