扩展:https://github.com/lichtschlag/Dazzle

 //创建出Layer
    CAEmitterLayer *emitterLayer = [CAEmitterLayer layer];
    
    //显示边框
    emitterLayer.borderWidth = ;
    //给定尺寸
    emitterLayer.frame = CGRectMake(, , , );
//    emitterLayer.masksToBounds = YES;
    //发射点
    emitterLayer.emitterPosition = CGPointMake(, );
    //发射模式
    emitterLayer.emitterMode = kCAEmitterLayerSurface;
    //发射形状
    emitterLayer.emitterShape = kCAEmitterLayerLine;
    //添加Layer
    [self.view.layer addSublayer:emitterLayer];
    
    CAEmitterCell *cell = [CAEmitterCell emitterCell];
    //粒子产生率
    cell.birthRate = .f;
    //粒子生命周期
    cell.lifetime = .f;
    //速度值
    cell.velocity = ;
    //速度值得微调值
    cell.velocityRange = .f;
    //y轴加速度
    cell.yAcceleration = .f;
    //发射角度(角度越大偏移越大)
    cell.emissionRange = .f *M_1_PI;
    //设置粒子颜色
//    cell.color = [UIColor blackColor].CGColor;
    //设置图片
    cell.contents = (__bridge id)([UIImage imageNamed:@"test1"].CGImage);
    emitterLayer.emitterCells = @[cell];

效果图:

例子:下雪下雨的封装

基类:WJCAEmitterLayerView

#import <UIKit/UIKit.h>

@interface WJCAEmitterLayerView : UIView
/**
 *  模仿setter getter方法
 */
- (void)setEmitterLayer:(CAEmitterLayer *)layer;
- (CAEmitterLayer *)emitterLayer; /**
 *  显示当前View
 */
- (void)show;
/**
 *  隐藏当前View
 */
- (void)hide; @end
#import "WJCAEmitterLayerView.h"

@interface WJCAEmitterLayerView () {
    CAEmitterLayer *_emitterLayer;
} @end @implementation WJCAEmitterLayerView + (Class)layerClass {
    return [CAEmitterLayer class];
    
} - (instancetype)initWithFrame:(CGRect)frame {
    self = [super initWithFrame:frame];
    if (self) {
        _emitterLayer = (CAEmitterLayer *)self.layer;
    }
    return self;
} - (void)setEmitterLayer:(CAEmitterLayer *)layer { } - (CAEmitterLayer *)emitterLayer {
    return _emitterLayer;
} - (void)show { } - (void)hide { } @end

封装下雪下雨view集成基类

下雪:

#import "SnowView.h"

@implementation SnowView

- (instancetype)initWithFrame:(CGRect)frame {
    self = [super initWithFrame:frame];
    if (self) {
        [self initEmitterLayerProperties];
    }
    return self;
} - (void)initEmitterLayerProperties {
     //初始化一些参数
//    self.emitterLayer.masksToBounds = YES;
    self.emitterLayer.emitterShape = kCAEmitterLayerLine;
    self.emitterLayer.emitterMode = kCAEmitterLayerSurface;
    self.emitterLayer.emitterSize = self.frame.size;
    self.emitterLayer.emitterPosition = CGPointMake(self.bounds.size.width/.f, );
} - (void)show {
    //添加 CAEmitterCell
    CAEmitterCell *snowflake = [CAEmitterCell emitterCell];
    snowflake.birthRate = .f;
    snowflake.speed = .f;
    snowflake.velocity = .f;
    snowflake.velocityRange = .f;
    snowflake.yAcceleration = .f;
    snowflake.emissionRange = 0.5 *M_PI;
    snowflake.spinRange = 0.25 *M_PI;
    snowflake.contents = (__bridge id)([UIImage imageNamed:@"test1"].CGImage);
    snowflake.color = [UIColor redColor].CGColor;
    snowflake.lifetime = .f;
    snowflake.scale = 0.5;
    snowflake.scaleRange = 0.3;
    //添加动画
    self.emitterLayer.emitterCells = @[snowflake];
} - (void)hide {
    
} @end

下雨:

#import "RainView.h"

@implementation RainView

- (instancetype)initWithFrame:(CGRect)frame {
    self = [super initWithFrame:frame];
    if (self) {
        [self initEmitterLayerProperties];
    }
    return self;
} - (void)initEmitterLayerProperties {
    //初始化一些参数
    self.emitterLayer.masksToBounds = YES;
    self.emitterLayer.emitterShape = kCAEmitterLayerLine;
    self.emitterLayer.emitterMode = kCAEmitterLayerSurface;
    self.emitterLayer.emitterSize = self.frame.size;
    self.emitterLayer.emitterPosition = CGPointMake(self.bounds.size.width/.f, );
} - (void)show {
    //添加 CAEmitterCell
    CAEmitterCell *snowflake = [CAEmitterCell emitterCell];
    snowflake.birthRate = .f;
    snowflake.speed = .f;
    snowflake.velocity = .f;
    snowflake.velocityRange = .f;
    snowflake.yAcceleration = .f;
//    snowflake.emissionRange = 0.5 *M_PI;
//    snowflake.spinRange = 0.25 *M_PI;
    snowflake.contents = (__bridge id)([UIImage imageNamed:@"test1"].CGImage);
    snowflake.color = [UIColor greenColor].CGColor;
    snowflake.lifetime = .f;
    snowflake.scale = 0.2;
    snowflake.scaleRange = .f;
    //添加动画
    self.emitterLayer.emitterCells = @[snowflake];
} - (void)hide {
    
} @end

调用:

    WJCAEmitterLayerView *snoView = [[SnowView alloc]initWithFrame:CGRectMake(, ,CGRectGetWidth(self.view.bounds), )];
    [self.view addSubview:snoView];
    [snoView show];

//    snoView.maskView = alpaView;可以让边缘模糊

iOS-CAEmitterLayer(粒子效果)的更多相关文章

  1. 雪花降落CAEmitterLayer粒子效果

    CAEmitterLayer 实现雪花效果   首先需要导入#import <QuartzCore/QuartzCore.h>   /**在iOS 5中,苹果引入了一个新的CALayer子 ...

  2. CAEmitterLayer 粒子效果(发射器)

    //创建Layer CAEmitterLayer *emitterLayer = [CAEmitterLayer layer]; //边框 emitterLayer.borderWidth = 1.0 ...

  3. iOS动画开发之五——炫酷的粒子效果

    在上几篇博客中,我们对UIView层的动画以及iOS的核心动画做了介绍,基本已经可以满足iOS应用项目中所有的动画需求,如果你觉得那些都还不够炫酷,亦或是你灵光一现,想用UIKit框架写出一款炫酷的休 ...

  4. iOS CAEmitterLayer 实现粒子发射动画效果

    iOS CAEmitterLayer 实现粒子发射动画效果 效果图 代码已上传 GitHub:https://github.com/Silence-GitHub/CoreAnimationDemo 动 ...

  5. iOS 烟花撒花效果,图层渐变,图层倒影特效。CAEmitterLayer粒子发射器

    iOS 烟花撒花效果,图层渐变,图层倒影特效.CAEmitterLayer粒子发射器 上一节我写了一个关于视图图层的相关类,有关CALayer这个类的使用和一些使用方法,详细看这里,就是我们在处理视图 ...

  6. iOS CALayer之CAEmitterLayer粒子发射器的神奇效果

    https://www.jianshu.com/p/c54ffd7412e7 想必以前QQ空间的点赞效果大家都知道吧,点赞之后按钮周围会有一圈爆裂的小圆点:还有微信的红包雨表情动画等,以及烟花,火焰效 ...

  7. iOS 开发之粒子效果

    本文由糖炒小虾.Benna翻译 ,校对:sai.u0u0.iven.子龙山人 iOS 5中的UIKit粒子系统教程 Ray的话:这是第15篇.也是最后一篇<iOS 5 盛宴>中的iOS 5 ...

  8. swift 实现漂亮的粒子效果CAEmitterLayer

    一些粒子效果 我们经常会在一些游戏或者应用中看到一些炫酷的粒子效果,我们在iOS中也能很轻松的搞一些粒子效果 我们本次做得是一个下雪的效果,看下效果图 源码地址: https://github.com ...

  9. 能产生粒子效果的CAEmitterLayer

    能产生粒子效果的CAEmitterLayer 下雪效果: // // RootViewController.m // Cell // // Copyright (c) 2014年 Y.X. All r ...

  10. 使用带粒子效果的 CAEmitterLayer

    1.用CAEmitterLayer产生粒子效果 2.封装CAEmitterLayer 3.封装下雪.下雨的粒子效果控件 一.用CAEmitterLayer产生粒子效果 - (void)emitterL ...

随机推荐

  1. oracle自定义job名字,job调度

    一.调试创建 begin -- create_schedule dbms_scheduler.create_schedule(schedule_name => 's_change_send_da ...

  2. ZygoteInit 相关分析

    上一篇文章我们已经分析到调用com.android.internal.os.ZygoteInit类的main函数. 今天分析一下com.android.internal.os.ZygoteInit类的 ...

  3. 黑客群体的露面说明互联网公司开始回馈IT行业了,

    揭开中国黑客群体的神秘面纱 年薪数百万 2015-04-26 09:59:45 15259 次阅读 14 次推荐 稿源:经济观察报 33 条评论   在网络世界有专属的代号,那里才是他们最习惯的“世界 ...

  4. golang的goroutine与channel

    Golang的goroutine是非抢占式的, 令人相当蛋疼! 有痛不能呻吟...只能配合channel在各goroutine之间传递信号来实现抢占式, 而这形成了golang最灵活与最具性能的核心. ...

  5. Nginx Gzip 压缩配置

    Nginx Gzip 压缩配置 随着nginx的发展,越来越多的网站使用nginx,因此nginx的优化变得越来越重要,今天我们来看看nginx的gzip压缩到底是怎么压缩的呢? gzip(GNU-Z ...

  6. SharePoint 2010 RBS 安装和配置的一些记录

    1.SharePoint 2010 RBS FILESTREAM Provider 的“垃圾收集”: 在SharePoint 中删除上传的文档RBS并不会在文件系统删除文档,理解只是在内容数据库删除了 ...

  7. [shell基础]——tr命令

    (1) tr 字符替换 测试文本内容 # cat /etc/hosts 127.0.0.1 localhost localhost.localdomain localhost4 localhost4. ...

  8. Oracle EBS中查询Profile的各种SQL【转载】

    1.List E-Business Suite Profile Option Values For All Levels SELECT p.profile_option_name SHORT_NAME ...

  9. “我爱淘”冲刺阶段Scrum站立会议7

    完成任务: 大事不好,今天的任务还没有完成,没有通过xml文件通过服务器显示到软件中. 计划任务: 实现通过服务器将xml文件中的数据显示到软件中. 遇到问题: 服务器已经配好,并且解析xml文件的代 ...

  10. 文本阴影text-shadow

    文本阴影text-shadow text-shadow可以用来设置文本的阴影效果. 语法: text-shadow: X-Offset Y-Offset blur color; X-Offset:表示 ...