1.用CAEmitterLayer产生粒子效果

2.封装CAEmitterLayer

3.封装下雪、下雨的粒子效果控件

一、用CAEmitterLayer产生粒子效果

- (void)emitterLayer {

// 1.创建出Layer

CAEmitterLayer *emitterLayer = [CAEmitterLayer layer];

//
显示边框

emitterLayer.borderWidth = 1.f;

//
给定尺寸

emitterLayer.frame = CGRectMake(, , , );

//emitterLayer.mask  = YES;不超过范围

//
发射点

emitterLayer.emitterPosition = CGPointMake(,);

//
发射模式

emitterLayer.emitterMode =kCAEmitterLayerSurface;

//
发射形状

emitterLayer.emitterShape =kCAEmitterLayerLine;

//
加入layer

[self.view.layeraddSublayer:emitterLayer];

// 2.创建粒子

CAEmitterCell *cell = [CAEmitterCell emitterCell];

//
粒子产生率

cell.birthRate = 10.f;

//
粒子生命周期

cell.lifetime = 10.f;

//
速度值

cell.velocity = ;

//
速度值的微调值

cell.velocityRange = 3.f;

// y轴加速度

cell.yAcceleration = 2.f;

//
发射角度

cell.emissionRange = 4.f *
M_1_PI;

//
设置粒子颜色

cell.color = [UIColorblackColor].CGColor;

//
设置图片

cell.contents = (__bridgeid)([UIImage imageNamed:@"snow"].CGImage);

//
让CAEmitterCell与CAEmitterLayer产生关联

emitterLayer.emitterCells = @[cell];

}

二、封装CAEmitterLayer

@interface CAEmitterLayerView :
UIView

/**

*  模仿setter.getter方法

*/

- (void)setEmitterLayer:(CAEmitterLayer *)layer;

- (CAEmitterLayer *)emitterLayer;

/**

*  显示出当前view

*/

- (void)show;

/**

*  隐藏当前view

*/

- (void)hide;

@end

二、封装 CAEmitterLayer

1.替换CAEmitterLayer成UIView子类的backedLayer

2.将CAEmitterLayer封装的类作为“抽象”父类

#import "CAEmitterLayerView.h"

@interface CAEmitterLayerView () {

//因为 CAEmitterLayer的參数许多,採用这样的小技巧,设置set,get方法

CAEmitterLayer  *_emitterLayer;

}

@end

@implementation CAEmitterLayerView

+ (Class)layerClass {//必需要写这个,否则新建返回layer,不是 CAEmitterLayer

return [CAEmitterLayerclass];

}

- (instancetype)initWithFrame:(CGRect)frame {

self = [superinitWithFrame:frame];

if (self) {

_emitterLayer = (CAEmitterLayer *)self.layer;

}

return
self;

}

- (void)show {

}

- (void)hide {

}

- (void)setEmitterLayer:(CAEmitterLayer *)layer {

_emitterLayer = layer;

}

- (CAEmitterLayer *)emitterLayer {

return_emitterLayer;

}

@end

- (void)viewDidLoad {

[superviewDidLoad];

CAEmitterLayerView *layerView = [[CAEmitterLayerView alloc]initWithFrame:CGRectMake(,,,)];

NSLog(@"%@", layerView.layer);

}

三、封装下雪、下雨的粒子效果控件

#import "CAEmitterLayerView.h"

@interface RainView :CAEmitterLayerView

@end

#import "RainView.h"

@implementation RainView

- (instancetype)initWithFrame:(CGRect)frame {

self = [superinitWithFrame:frame];

if (self) {

//初始化设置

[selfsetup];

}

return
self;

}

- (void)setup {

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 /2.f, -
);

}

- (void)show {

//
配置

CAEmitterCell *rainflake  = [CAEmitterCell emitterCell];

rainflake.birthRate       =25.f;

rainflake.speed           =10.f;

rainflake.velocity        =10.f;

rainflake.velocityRange   =10.f;

rainflake.yAcceleration   =1000.f;

rainflake.contents        = (__bridgeid)([UIImage imageNamed:@"rain"].CGImage);

rainflake.color           = [UIColorblackColor].CGColor;

rainflake.lifetime        =7.f;

rainflake.scale           =0.2f;

rainflake.scaleRange      =0.f;

//
加入动画

self.emitterLayer.emitterCells =@[rainflake];

}

@end

封装 CAEmitterLayer

@interface SnowView :CAEmitterLayerView

@end

#import "SnowView.h"

@implementation SnowView

- (instancetype)initWithFrame:(CGRect)frame {

self = [superinitWithFrame:frame];

if (self) {

//初始化设置

[selfsetup];

}

return
self;

}

- (void)setup {

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 /2.f, -
);

}

- (void)show {

//
配置

CAEmitterCell *snowflake  = [CAEmitterCell emitterCell];

snowflake.birthRate       =1.f;

snowflake.speed           =10.f;

snowflake.velocity        =2.f;

snowflake.velocityRange   =10.f;

snowflake.yAcceleration   =10.f;

snowflake.emissionRange   =0.5 *M_PI;

snowflake.spinRange       =0.25 *M_PI;

snowflake.contents        = (__bridgeid)([UIImage imageNamed:@"snow"].CGImage);

snowflake.color           = [UIColorredColor].CGColor;

snowflake.lifetime        =60.f;

snowflake.scale           =0.5;

snowflake.scaleRange      =0.3;

//
加入动画

self.emitterLayer.emitterCells =@[snowflake];

}

@end

封装 CAEmitterLayer

#import "CAEmitterLayerView.h"

#import "SnowView.h"

#import "RainView.h"

@interface ViewController ()

@end

@implementation ViewController

- (void)viewDidLoad {

[superviewDidLoad];

UIImageView *alphaView1 = [[UIImageView alloc]initWithFrame:CGRectMake(,,,)];

alphaView1.image        = [UIImage imageNamed:@"alpha"];

UIImageView *alphaView2 = [[UIImageView alloc]initWithFrame:CGRectMake(,,,)];

alphaView2.image        = [UIImage imageNamed:@"alpha"];

//
加入下雪效果

CAEmitterLayerView *snowView = [[SnowView alloc]initWithFrame:CGRectMake(,,,)];

snowView.maskView            = alphaView1;//加maskView。效果不突兀

[self.viewaddSubview:snowView];

[snowViewshow];

//
加入下雨效果

CAEmitterLayerView *rainView = [[RainView alloc]initWithFrame:CGRectMake(,,,)];

rainView.maskView            = alphaView2;

[self.viewaddSubview:rainView];

[rainViewshow];

}

@end

使用带粒子效果的 CAEmitterLayer的更多相关文章

  1. 能产生粒子效果的CAEmitterLayer

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

  2. CAEmitterLayer实现粒子效果

    在iOS 5中,苹果引入了一个新的CALayer子类叫做CAEmitterLayer.CAEmitterLayer是一个高性能的粒子引擎,被用来创建实时例子动画如:烟雾,火,雨等等这些效果. CAEm ...

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

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

  4. 雪花降落CAEmitterLayer粒子效果

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

  5. iOS开发——UI进阶篇(十八)核心动画小例子,转盘(裁剪图片、自定义按钮、旋转)图片折叠、音量震动条、倒影、粒子效果

    一.转盘(裁剪图片.自定义按钮.旋转) 1.裁剪图片 将一张大图片裁剪为多张 // CGImageCreateWithImageInRect:用来裁剪图片 // image:需要裁剪的图片 // re ...

  6. iOS 开发之粒子效果

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

  7. cocos2d粒子效果

    第9章 粒子效果 游戏开发者通常使用粒子系统来制作视觉特效.粒子系统能够发射大量细小的粒子并对他们进行渲染,而且效率要远高于渲染同样数目的精灵.粒子系统可以模拟下雨.火焰.雪.爆炸.蒸气拖尾以及其他多 ...

  8. Cocos2d-x实现粒子效果的三种方式

    在Cocos2d-x中,实现粒子效果可以有三种方法. Normal 0 10 pt 0 2 false false false EN-US ZH-CN X-NONE $([{£¥·'"〈&l ...

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

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

随机推荐

  1. CAD参数绘制点(网页版)

    点在CAD中的作用除了可以分割对象外,还能测量对象,点不仅表示一个小的实体,而且通过点作为绘图的参考标记. pdmode是一个控制point的形式的系统变量,当pdmode=0时是可见的一个点,当pd ...

  2. java.util.MissingResourceException: Can't find bundle for base name db, locale zh_CN

    在使用Bundle来加载配置文件的时候, 爆出了这个错误: 原因? 没有找到需要加载的配置文件,因为配置文件必须放在src目录下面, 如果放进了com.bj186.crm的包下面,就必须添加包的名称到 ...

  3. 题解 洛谷P4198/BZOJ2957【楼房重建】

    每个楼房,还有修改操作.简单的想到用线段树来维护信息. 显然线段树只需要维护y/x即可,对于每一个楼房,能看见的条件就是前面楼房的y/x的严格小于当前楼房的y/x. 线段树的区间修改不再赘述. 那么怎 ...

  4. 笔试算法题(52):简介 - KMP算法(D.E. Knuth, J.H. Morris, V.R. Pratt Algorithm)

    议题:KMP算法(D.E. Knuth, J.H. Morris, V.R. Pratt Algorithm) 分析: KMP算法用于在一个主串中找出特定的字符或者模式串.现在假设主串为长度n的数组T ...

  5. 笔试算法题(25):复制拥有多个指针的链表 & 判断二元树B是否为A的子树

    出题:定义一个复杂链表:在单向链表的基础上,每个节点附加一个指向链表中其他任意节点的指针sibling,实现CNode* Clone(Cnode *head)函数复制这个复杂链表: 分析: 解法1:将 ...

  6. 搭建分布式yarn

    1.在前一篇准备好Hadoop的基础上配置,链接 http://www.cnblogs.com/cici20166/p/6266367.html 2./etc/profile 配置环境变量 expor ...

  7. element-UI 多表单重置的时候的坑

    问题细化一下是这样的:比如我有一个用来修改数据的表单,第一条数据是{name: 'Xixi', age: 12},打开表单后就有两个输入框分别填的是Xixi和12,此时我修改Xixi为Haha,调用t ...

  8. Matlab学习笔记(三)

    二.MATLAB基础知识 (四)数组 MATLAB总是把数组看作存储和运算的基本单位,标量数据也被看作是(1×1)的数组 一维数组的创建 创建一维数组的几种方法:(e_two_14.m) 直接输入法: ...

  9. UVA 1589 象棋

    题意: 给出一个黑方的将, 然后 红方有 2 ~ 7 个棋子, 给出摆放位置,问是否已经把黑将将死, 红方已经将军. 分析: 分情况处理, 车 马 炮, 红将情况跟车是一样的. 建一个数组board保 ...

  10. webstrom破解-webstrom2018.2.4破解方法(xjl456852原创)

    方法一: 获取注册码: http://idea.lanyus.com/ 方法二: 使用破解补丁 放在安装目录的bin目录下,并且编辑bin目录下的文件 如果使用的32位的webstrom就编辑webs ...