CAEmitterCell

//

 

        

     CAEmitterLayer * emitter = [CAEmitterLayer layer];

    //视图大小

    emitter.frame =  self.weakView.bounds;

   //加入视图中

   [self.weakView.layer addSublayer:emitter];

 

 // emitter.renderMode = kCAEmitterLayerAdditive;//重叠模式

       //粒子散发位置中心

    emitter.emitterPosition = CGPointMake(emitter.frame.size.width / 2.0, emitter.frame.size.height / 2.0);

 

CAEmitterCell * cell = [[CAEmitterCell alloc]init];

        //图片

    cell.contents = (__bridge id)[UIImage imageNamed:@"success_star"].CGImage;

    cell.birthRate = 50;

    cell.lifetime = 5.0;

    cell.color = [UIColor yellowColor].CGColor;

    cell.alphaSpeed = -0.4;

    cell.velocity = 50;//速度

    cell.velocityRange = 50;

    cell.emissionRange = M_PI * 2.0;

 

 

    CAEmitterCell * cell1 = [[CAEmitterCell alloc]init];

    

    //  cell.contents

    UIImage * image =imageWithColor([UIColor redColor]);

    

    UIImage *borderImg =imageWithColor([UIColor yellowColor]);

    

    UIImage * a  =[self imageWithIconName:image borderImage:borderImg border:3];

    cell1.contents= (__bridge id)a.CGImage;

    cell1.birthRate = 50;

    cell1.lifetime = 5.0;

    cell1.color = [UIColor yellowColor].CGColor;

    cell1.alphaSpeed = -0.4;

    cell1.velocity = 150;

    cell1.velocityRange = 50;

    cell1.emissionRange = M_PI * 2.0;

    

    self.imageView.image=imageWithColor([UIColor redColor]);

    //add particle template to emitter

    emitter.emitterCells = @[cell,cell1];//可以多个

//改变边缘图像

- (UIImage*)imageWithIconName:(UIImage*)image borderImage:(UIImage * )borderImg border:(int)border{

    //头像图片

    //    UIImage * image = [UIImage imageNamed:icon];

    //边框图片

    // UIImage * borderImg = [UIImage imageNamed:borderImage];

    //

    CGSize size = CGSizeMake(image.size.width + border, image.size.height + border);

    

    //创建图片上下文

    UIGraphicsBeginImageContextWithOptions(size, NO, 0);

    

    //绘制边框的圆

    CGContextRef context = UIGraphicsGetCurrentContext();

    CGContextAddEllipseInRect(context, CGRectMake(0, 0, size.width, size.height));

    

    //剪切可视范围

    CGContextClip(context);

    

    //绘制边框图片

    [borderImg drawInRect:CGRectMake(0, 0, size.width, size.height)];

    

    //设置头像frame

    CGFloat iconX = border / 2;

    CGFloat iconY = border / 2;

    CGFloat iconW = image.size.width;

    CGFloat iconH = image.size.height;

    

    //绘制圆形头像范围

    CGContextAddEllipseInRect(context, CGRectMake(iconX, iconY, iconW, iconH));

    

    //剪切可视范围

    CGContextClip(context);

    

    //绘制头像

    [image drawInRect:CGRectMake(iconX, iconY, iconW, iconH)];

    

    //取出整个图片上下文的图片

    UIImage *iconImage = UIGraphicsGetImageFromCurrentImageContext();

    

    return iconImage;

}

 //颜色形成图片

UIImage *imageWithColor(UIColor *color)

{

    CGRect rect = CGRectMake(0, 0, 13, 17);

    UIGraphicsBeginImageContext(rect.size);

    CGContextRef context = UIGraphicsGetCurrentContext();

    CGContextSetFillColorWithColor(context, [color CGColor]);

    CGContextFillRect(context, rect);

    

    UIImage *image = UIGraphicsGetImageFromCurrentImageContext();

    UIGraphicsEndImageContext();

    return image;

}

 

转载于:https://www.cnblogs.com/hangman/p/6873974.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值