动画绘制水波纹

使用drawRect:方式绘制的动画效果,右图为占用了多少CPU.

虽然画起来挺好看的,但占用的内存真心吃不消,原因其实很简单哦,drawRect:方法只调用CPU进行图形绘制,所以非常非常的消耗CPU性能,把它集成到应用程序中,我觉得是不靠谱的呢.

//
//  WaterView.h
//  Cell
//
//  Copyright (c) 2014年 Y.X. All rights reserved.
//

#import <UIKit/UIKit.h>

@interface WaterView : UIView

@end
//
//  WaterView.m
//  Cell
//
//  Copyright (c) 2014年 Y.X. All rights reserved.
//

#import "WaterView.h"

@interface WaterView ()

{
    UIColor *_currentWaterColor;
    float   _currentLinePointY;

    float   a;
    float   b;

    BOOL    flag;
}

@end

@implementation WaterView

- (id)initWithFrame:(CGRect)frame
{
    self = [super initWithFrame:frame];
    if (self)
    {
        [self setBackgroundColor:[UIColor clearColor]];

        a    = 1.5;
        b    = 0;
        flag = NO;

        _currentWaterColor = [UIColor colorWithRed:86/255.0f
                                             green:202/255.0f
                                              blue:139/255.0f
                                             alpha:1];

        _currentLinePointY = 250;

        [NSTimer scheduledTimerWithTimeInterval:0.02
                                         target:self
                                       selector:@selector(linkRun)
                                       userInfo:nil
                                        repeats:YES];
    }
    return self;
}

- (void)linkRun
{
    if (flag) {
        a += 0.01;
    }else{
        a -= 0.01;
    }

    if (a<=1) {
        flag = YES;
    }

    if (a>=1.5) {
        flag = NO;
    }

    b+=0.1;

    [self setNeedsDisplay];
}

- (void)drawRect:(CGRect)rect
{
    // 获取一个path
    CGMutablePathRef path = CGPathCreateMutable();

    {
        // 移动到起始点
        CGPathMoveToPoint(path, nil, 0, 100);

        // 绘制水平方向上所有的点
        float y = _currentLinePointY;
        CGPathMoveToPoint(path, NULL, 0, y);
        for(float x = 0; x <= 320; x++)
        {
            y= a * sin(x/180.f * M_PI + 4*b / M_PI) * 5 + _currentLinePointY;
            CGPathAddLineToPoint(path, nil, x, y);
        }

        // 移动到屏幕底部
        CGPathAddLineToPoint(path, nil, 320, rect.size.height);
        CGPathAddLineToPoint(path, nil, 0, rect.size.height);

        // 闭合曲线
        CGPathAddLineToPoint(path, nil, 0, _currentLinePointY);
    }

    // 获取绘制句柄
    CGContextRef context = UIGraphicsGetCurrentContext();

    // 设置线宽为1
    CGContextSetLineWidth(context, 1);

    // 设置颜色为红色
    CGContextSetFillColorWithColor(context, [UIColor redColor].CGColor);

    // context接受path
    CGContextAddPath(context, path);

    // context填充path
    CGContextFillPath(context);

    // 描绘path
    CGContextDrawPath(context, kCGPathStroke);

    // 释放path
    CGPathRelease(path);
}

@end

以下效果:

效率相差十万八千里呢,这是因为CoreAnimation使用GPU渲染,所以不仅流畅,还消耗CPU,如果配置的路径多一些,动画效果将会非常流畅的.

//
//  RootViewController.m
//  Cell
//
//  Copyright (c) 2014年 Y.X. All rights reserved.
//

#import "RootViewController.h"
#import "YXGCD.h"

@interface RootViewController ()

@property (nonatomic, strong) GCDTimer  *timer;

@end

@implementation RootViewController

- (void)viewDidLoad
{
    [super viewDidLoad];

    self.view.backgroundColor  = [UIColor blackColor];

    // shapeLayer
    CAShapeLayer *circleLayer = [CAShapeLayer layer];
    circleLayer.frame         = (CGRect){CGPointMake(0, 0), CGSizeMake(200, 200)};
    circleLayer.position      = self.view.center;
    circleLayer.path          = [self path1].CGPath;
    circleLayer.fillColor     = [UIColor redColor].CGColor;
    circleLayer.strokeColor   = [UIColor redColor].CGColor;
    circleLayer.lineWidth     = 2.f;
    [self.view.layer addSublayer:circleLayer];

    // 定时器
    _timer = [[GCDTimer alloc] initInQueue:[GCDQueue mainQueue]];
    [_timer event:^{
        static int i = 0;
        if (i++ % 2 == 0)
        {
            CABasicAnimation *circleAnim = [CABasicAnimation animationWithKeyPath:@"path"];
            circleAnim.removedOnCompletion = NO;
            circleAnim.duration  = 1;
            circleAnim.fromValue = (__bridge id)(circleLayer.path);
            circleAnim.toValue   = (__bridge id)[self path2].CGPath;
            circleLayer.path = [self path2].CGPath;
            [circleLayer addAnimation:circleAnim forKey:@"animateCirclePath"];
        }
        else
        {
            CABasicAnimation *circleAnim = [CABasicAnimation animationWithKeyPath:@"path"];
            circleAnim.removedOnCompletion = NO;
            circleAnim.duration  = 1;
            circleAnim.fromValue = (__bridge id)(circleLayer.path);
            circleAnim.toValue   = (__bridge id)[self path1].CGPath;
            circleLayer.path = [self path1].CGPath;
            [circleLayer addAnimation:circleAnim forKey:@"animateCirclePath"];
        }
    } timeInterval:NSEC_PER_SEC];
    [_timer start];

}

- (UIBezierPath *)path1
{
    //// Bezier Drawing
    UIBezierPath* bezierPath = [UIBezierPath bezierPath];
    [bezierPath moveToPoint: CGPointMake(0.5, 38.5)];
    [bezierPath addCurveToPoint: CGPointMake(124.5, 38.5) controlPoint1: CGPointMake(0.5, 38.5) controlPoint2: CGPointMake(74.82, 114.88)];
    [bezierPath addCurveToPoint: CGPointMake(240.5, 38.5) controlPoint1: CGPointMake(174.18, -37.88) controlPoint2: CGPointMake(240.5, 38.5)];
    [bezierPath addLineToPoint: CGPointMake(240.5, 120.5)];
    [bezierPath addLineToPoint: CGPointMake(0.5, 120.5)];
    [bezierPath addLineToPoint: CGPointMake(0.5, 38.5)];
    [bezierPath closePath];

    return bezierPath;
}

- (UIBezierPath *)path2
{
    //// Bezier Drawing
    UIBezierPath* bezierPath = [UIBezierPath bezierPath];
    [bezierPath moveToPoint: CGPointMake(0.5, 38.5)];
    [bezierPath addCurveToPoint: CGPointMake(124.5, 38.5) controlPoint1: CGPointMake(0.5, 38.5) controlPoint2: CGPointMake(64.14, -22.65)];
    [bezierPath addCurveToPoint: CGPointMake(240.5, 38.5) controlPoint1: CGPointMake(184.86, 99.65) controlPoint2: CGPointMake(240.5, 38.5)];
    [bezierPath addLineToPoint: CGPointMake(240.5, 120.5)];
    [bezierPath addLineToPoint: CGPointMake(0.5, 120.5)];
    [bezierPath addLineToPoint: CGPointMake(0.5, 38.5)];
    [bezierPath closePath];

    return bezierPath;
}

@end

不过,使用path路径动画绘制波形图需要考验你的空间感觉了.

动画绘制水波纹

时间: 2024-12-18 08:43:09

动画绘制水波纹的相关文章

用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

Android L中水波纹点击效果的实现

博主参加了2014 CSDN博客之星评选,帮我投一票吧. 点击给我投票 前言 前段时间android L(android 5.0)出来了,界面上做了一些改动,主要是添加了若干动画和一些新的控件,相信大家对view的点击效果-水波纹很有印象吧,点击一个view,然后一个水波纹就会从点击处扩散开来,本文就来分析这种效果的实现.首先,先说下L上的实现,这种波纹效果,L上提供了一种动画,叫做Reveal效果,其底层是通过拿到view的canvas然后不断刷新view来完成的,这种效果需要view的支持,

自定义控件---继承View类方式(五彩绚烂的水波纹案例)

---------------------------------------看效果(还有动画效果哦)---------------------------------------------------- activity_main.xml <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent"

多个彩色水波纹扩散效果

布局 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=

Android -- 贝塞尔实现水波纹动画(划重点!!)

1,昨天看到了一个挺好的ui效果,是使用贝塞尔曲线实现的,就和大家来分享分享,还有,在写博客的时候我经常会把自己在做某种效果时的一些问题给写出来,而不是像很多文章直接就给出了解决方法,这里给大家解释一下,这里写出我遇到的一些问题不是为了凑整片文章的字数,而是希望大家能从根源下知道它是怎么解决的,而不是你直接百度搜索这个问题解决的代码,好了,说了这么多,只是想告诉大家,我后面会在过程中提很多问题(邪恶脸,嘿嘿嘿),好吧,来看看今天的效果: 2,what is the fuck?,这就是你说的很好看

Android自定义水波纹动画Layout

Android自定义水波纹动画Layout 源码是双11的时候就写好了,但是我觉得当天发不太好,所以推迟了几天,没想到过了双11女友就变成了前女友,桑心.唉不说了,来看看代码吧. 展示效果 Hi前辈 话不多说,我们先来看看效果: 这一张是<Hi前辈>的搜索预览图,你可以在这里下载这个APP查看更多效果:http://www.wandoujia.com/apps/com.superlity.hiqianbei LSearchView 这是一个MD风格的搜索框,集成了ripple动画以及searc

超酷的计步器APP——炫酷功能实现,自定义水波纹特效、自定义炫酷开始按钮、属性动画的综合体验

超酷的计步器APP--炫酷功能实现,自定义水波纹特效.自定义炫酷开始按钮.属性动画的综合体验 好久没写博客了,没给大家分享技术了,真是有些惭愧.这段时间我在找工作,今年Android的行情也不怎么好,再加上我又是一个应届生,所以呢,更是不好找了.但是我没有放弃,经过自己的不懈努力,还是找到了自己喜欢的Android工作,心里的一块石头终于落下了.但是迎接我来的是更多的挑战,我喜欢那种不断的挑战自我,在困难中让自己变得更强大的感觉.相信阳光总在风雨后,因为每一个你不满意的现在,都有一个你没有努力的

HTML5 Canvas水波纹动画特效

HTML5的Canvas特性非常实用,我们不仅可以在Canvas画布上绘制各种图形,也可以制作绚丽的动画,比如这次介绍的水波纹动画特效.以前我们也分享过一款基于HTML5 WebGL的水波荡漾动画,让人惊叹不已,这次分享的HTML5 Canvas水波纹动画同样非常震撼人心. 在线演示          源码下载 <!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8&q

用drawRect以及CAReplicatorLayer绘制动态水波纹

大大简化了写水波纹效果的难度,你可以根据示例自己组装水波纹效果,本设计是几个工具组合在一起完成的效果, DrawRectObject 以及 ReplicatorLineAnimationView 均可以独立完成更复杂的功能. 说明 1. 用sine计算正玄曲线 2. 用CAReplicatorLayer实现重复移动的效果 效果 源码 https://github.com/YouXianMing/UI-Component-Collection 中的 DrawRectObject // // Wav