W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
在iOS 5中,蘋果引入了一個新的CALayer
子類叫做CAEmitterLayer
。CAEmitterLayer
是一個高性能的粒子引擎,被用來創(chuàng)建實時例子動畫如:煙霧,火,雨等等這些效果。
CAEmitterLayer
看上去像是許多CAEmitterCell
的容器,這些CAEmitierCell
定義了一個例子效果。你將會為不同的例子效果定義一個或多個CAEmitterCell
作為模版,同時CAEmitterLayer
負責基于這些模版實例化一個粒子流。一個CAEmitterCell
類似于一個CALayer
:它有一個contents
屬性可以定義為一個CGImage
,另外還有一些可設置屬性控制著表現(xiàn)和行為。我們不會對這些屬性逐一進行詳細的描述,你們可以在CAEmitterCell
類的頭文件中找到。
我們來舉個例子。我們將利用在一圓中發(fā)射不同速度和透明度的粒子創(chuàng)建一個火爆炸的效果。清單6.13包含了生成爆炸的代碼。圖6.13是運行結果
清單6.13 用CAEmitterLayer
創(chuàng)建爆炸效果
#import "ViewController.h"
#import
@interface ViewController ()
@property (nonatomic, weak) IBOutlet UIView *containerView;
@end
@implementation ViewController
- (void)viewDidLoad
{
[super viewDidLoad];
?
//create particle emitter layer
CAEmitterLayer *emitter = [CAEmitterLayer layer];
emitter.frame = self.containerView.bounds;
[self.containerView.layer addSublayer:emitter];
//configure emitter
emitter.renderMode = kCAEmitterLayerAdditive;
emitter.emitterPosition = CGPointMake(emitter.frame.size.width / 2.0, emitter.frame.size.height / 2.0);
//create a particle template
CAEmitterCell *cell = [[CAEmitterCell alloc] init];
cell.contents = (__bridge id)[UIImage imageNamed:@"Spark.png"].CGImage;
cell.birthRate = 150;
cell.lifetime = 5.0;
cell.color = [UIColor colorWithRed:1 green:0.5 blue:0.1 alpha:1.0].CGColor;
cell.alphaSpeed = -0.4;
cell.velocity = 50;
cell.velocityRange = 50;
cell.emissionRange = M_PI * 2.0;
//add particle template to emitter
emitter.emitterCells = @[cell];
}
@end
圖6.13 火焰爆炸效果
CAEMitterCell
的屬性基本上可以分為三種:
color
屬性指定了一個可以混合圖片內(nèi)容顏色的混合色。在示例中,我們將它設置為桔色。emissionRange
屬性的值是2π,這意味著例子可以從360度任意位置反射出來。如果指定一個小一些的值,就可以創(chuàng)造出一個圓錐形alphaSpeed
設置為-0.4,就是說例子的透明度每過一秒就是減少0.4,這樣就有發(fā)射出去之后逐漸小時的效果。CAEmitterLayer
的屬性它自己控制著整個例子系統(tǒng)的位置和形狀。一些屬性比如birthRate
,lifetime
和celocity
,這些屬性在CAEmitterCell
中也有。這些屬性會以相乘的方式作用在一起,這樣你就可以用一個值來加速或者擴大整個例子系統(tǒng)。其他值得提到的屬性有以下這些:
preservesDepth
,是否將3D例子系統(tǒng)平面化到一個圖層(默認值)或者可以在3D空間中混合其他的圖層renderMode
,控制著在視覺上粒子圖片是如何混合的。你可能已經(jīng)注意到了示例中我們把它設置為kCAEmitterLayerAdditive
,它實現(xiàn)了這樣一個效果:合并例子重疊部分的亮度使得看上去更亮。如果我們把它設置為默認的kCAEmitterLayerUnordered
,效果就沒那么好看了(見圖6.14).Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: