粒子动画


CAEmitterLayer * emitterLayer = [CAEmitterLayer layer];//粒子发射器图层
    emitterLayer.emitterPosition = CGPointMake(0, 0);
    emitterLayer.emitterSize = CGSizeMake(100, 100);//粒子发射器的范围
    emitterLayer.emitterMode = kCAEmitterLayerOutline;//发射模式
    emitterLayer.emitterShape = kCAEmitterLayerLine;//粒子模式
    
    CAEmitterCell * emitterCell = [CAEmitterCell emitterCell];//创建粒子
    emitterCell.contents = (__bridge id)([UIImage imageNamed:@"Expression_64"].CGImage);//设置粒子内容
    emitterCell.scale = 0.8;//设置粒子缩放比例
    emitterCell.scaleRange = 0.5;//缩放范围
    emitterCell.birthRate = 1;//每秒粒子产生数量
    emitterCell.lifetime = 5;//粒子生命周期
//    emitterCell.alphaSpeed = -0.01;//粒子透明速度
    emitterCell.velocity = 80;//粒子速度
    emitterCell.velocityRange = 50;
    emitterCell.emissionRange = M_PI;//设置角度
    emitterCell.spin = M_PI_4;//设置粒子旋转角速度
    
    emitterLayer.emitterCells = @[emitterCell];
    
    [self.view.layer addSublayer:emitterLayer];

/* 
 1、CAEmitterCell
 
 CAEmitterCell *effectCell = [CAEmitterCell emitterCell];
 
 effectCell 几个重要属性:
 
 1).birthRate 顾名思义没有这个也就没有effectCell,这个必须要设置,具体含义是每秒某个点产生的effectCell数量
 
 2).lifetime & lifetimeRange 表示effectCell的生命周期,既在屏幕上的显示时间要多长。
 
 3).contents 这个和CALayer一样,只是用来设置图片
 
 4).name 这个是当effectCell存在caeEmitter 的emitterCells中用来辨认的。用到setValue forKeyPath比较有用
 
 5).velocity & velocityRange & emissionRange 表示cell向屏幕右边飞行的速度 & 在右边什么范围内飞行& +-角度扩散
 
 6).把cell做成array放进caeEmitter.emitterCells里去。caeEmitter.renderMode有个效果很不错,能变成火的就是kCAEmitterLayerAdditive
 
 属性:
 
 alphaRange:  一个粒子的颜色alpha能改变的范围;
 
 alphaSpeed:粒子透明度在生命周期内的改变速度;
 
 birthrate:粒子参数的速度乘数因子;
 
 blueRange:一个粒子的颜色blue 能改变的范围;
 
 blueSpeed: 粒子blue在生命周期内的改变速度;
 
 color:粒子的颜色
 
 contents:是个CGImageRef的对象,既粒子要展现的图片;
 
 contentsRect:应该画在contents里的子rectangle:
 
 emissionLatitude:发射的z轴方向的角度
 
 emissionLongitude:x-y平面的发射方向
 
 emissionRange;周围发射角度
 
 emitterCells:粒子发射的粒子
 
 enabled:粒子是否被渲染
 
 greenrange: 一个粒子的颜色green 能改变的范围;
 
 greenSpeed: 粒子green在生命周期内的改变速度;
 
 lifetime:生命周期
 
 lifetimeRange:生命周期范围
 
 magnificationFilter:不是很清楚好像增加自己的大小
 
 minificatonFilter:减小自己的大小
 
 minificationFilterBias:减小大小的因子
 
 name:粒子的名字
 
 redRange:一个粒子的颜色red 能改变的范围;
 
 redSpeed; 粒子red在生命周期内的改变速度;
 
 scale:缩放比例:
 
 scaleRange:缩放比例范围;
 
 scaleSpeed:缩放比例速度:
 
 spin:子旋转角度
 
 spinrange:子旋转角度范围
 
 style:不是很清楚:
 
 velocity:速度
 
 velocityRange:速度范围
 
 xAcceleration:粒子x方向的加速度分量
 
 yAcceleration:粒子y方向的加速度分量
 
 zAcceleration:粒子z方向的加速度分量
 
 2、CAEmitterLayer
 
 CAEmitterLayer提供了一个基于Core Animation的粒子发射系统,粒子用CAEmitterCell来初始化。粒子画在背景层盒边界上
 
 属性:
 
 birthRate:粒子产生系数,默认1.0;
 
 emitterCells: 装着CAEmitterCell对象的数组,被用于把粒子投放到layer上;
 
 emitterDepth:决定粒子形状的深度联系:emittershape
 
 emitterMode:发射模式
 
 NSString * const kCAEmitterLayerPoints;
 
 NSString * const kCAEmitterLayerOutline;
 
 NSString * const kCAEmitterLayerSurface;
 
 NSString * const kCAEmitterLayerVolume;
 
 emitterPosition:发射位置
 
 emitterShape:发射源的形状:
 
 NSString * const kCAEmitterLayerPoint;
 
 NSString * const kCAEmitterLayerLine;
 
 NSString * const kCAEmitterLayerRectangle;
 
 NSString * const kCAEmitterLayerCuboid;
 
 NSString * const kCAEmitterLayerCircle;
 
 NSString * const kCAEmitterLayerSphere;
 
 emitterSize:发射源的尺寸大;
 
 emitterZposition:发射源的z坐标位置;
 
 lifetime:粒子生命周期
 
 preservesDepth:不是多很清楚(粒子是平展在层上)
 
 renderMode:渲染模式:
 
 NSString * const kCAEmitterLayerUnordered;
 
 NSString * const kCAEmitterLayerOldestFirst;
 
 NSString * const kCAEmitterLayerOldestLast;
 
 NSString * const kCAEmitterLayerBackToFront;
 
 NSString * const kCAEmitterLayerAdditive;
 
 scale:粒子的缩放比例:
 
 seed:用于初始化随机数产生的种子
 
 spin:自旋转速度
 
 velocity:粒子速度
 
 */

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,132评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,802评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,566评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,858评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,867评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,695评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,064评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,705评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,915评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,677评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,796评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,432评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,041评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,992评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,223评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,185评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,535评论 2 343

推荐阅读更多精彩内容