iOS动画实现雨花与樱花特效

 更新时间:2016年08月02日 09:48:16   投稿:daisy  
小编今天为大家带来一场淅淅沥沥的夜空之雨和满天飞舞的樱花之恋,希望能在炎炎夏日为您带来一丝清爽的凉意!学习iOS动画的小伙伴们可以参考学习。

先来看看效果图:

下面直接上代码:

粒子特效的话我只服苹果系统的,CAEmitter粒子特效提供了非常丰富的属性来实现各种效果(雨滴、雪花、流星),用法简单B格高。首先创建好CAEmitterLayer粒子发射器图层,CAEmitterCell粒子单元,然后根据需要设置somany粒子单元的属性就OK了,最后注意要将粒子发射器图层的layer添加到整个背景的sublayer上。

@interface XMWeatherView ()

@property(nonatomic,strong) CAEmitterLayer *sunshineEmitterLayer;

@property(nonatomic,strong) CAEmitterLayer *rainDropEmitterLayer;

@property(nonatomic,strong) UIImageView *backgroundView;

@end

每个属性都有详细注释,最后就发挥您的想象力,爱怎么玩怎么玩吧!

#pragma mark - 下雨特效
-(void)addRainningEffect{

  self.backgroundView.image=[UIImage imageNamed:@"rainning.jpeg"];

  //粒子发射器图层
  self.rainDropEmitterLayer=[CAEmitterLayer layer];

  //粒子发射器位置
  _rainDropEmitterLayer.emitterPosition=CGPointMake(100, -30);

  //粒子发射器的范围
  _rainDropEmitterLayer.emitterSize=CGSizeMake(self.bounds.size.width*4, 0);

  //发射模式
  _rainDropEmitterLayer.emitterMode=kCAEmitterLayerOutline;

  //粒子模式
  _rainDropEmitterLayer.emitterShape=kCAEmitterLayerLine;

  //创建粒子
  CAEmitterCell *emitterCell=[CAEmitterCell emitterCell];

  //设置粒子内容
  emitterCell.contents=(__bridge id)([UIImage imageNamed:@"42-Raindrop"].CGImage);

  //设置粒子缩放比例
  emitterCell.scale=0.9;

  //缩放范围
  emitterCell.scaleRange=0.5;

  //每秒粒子产生数量
  emitterCell.birthRate=130;

  //粒子生命周期
  emitterCell.lifetime=5;

  //粒子透明速度
  emitterCell.alphaSpeed=-0.1;

  //粒子速度
  emitterCell.velocity=280;
  emitterCell.velocityRange=100;

  //设置发射角度
  emitterCell.emissionLongitude=-M_PI;
//  emitterCell.emissionRange=M_PI;

  //设置粒子旋转角速度
//  emitterCell.spin=M_PI_4;

  //设置layer阴影
  _rainDropEmitterLayer.shadowOpacity=1.0;

  //设置圆角
  _rainDropEmitterLayer.shadowRadius=2;

  //设置偏移
  _rainDropEmitterLayer.shadowOffset=CGSizeMake(1, 1);

  //设置颜色
  _rainDropEmitterLayer.shadowColor=[UIColor whiteColor].CGColor
  ;

  //设置layer的粒子
  _rainDropEmitterLayer.emitterCells=@[emitterCell];

  _rainDropEmitterLayer.transform=CATransform3DMakeRotation(-M_PI/4, 0, 0, 1);

  [self.layer addSublayer:_rainDropEmitterLayer];
}

樱花的代码大同小异,请自行脑补。

这一篇就到这里了,大家有什么意见和问题记得及时反馈哦,希望本文对大家开发iOS有所帮助。

相关文章

  • iOS开发教程之识别图片中二维码功能的实现

    iOS开发教程之识别图片中二维码功能的实现

    长按识别二维码这个功能相信对大家来说都不陌生,最近工作中就遇到了这个需求,所以下面这篇文章主要给大家介绍了关于利用iOS识别图片中二维码的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2018-07-07
  • IOS LaunchScreen设置启动图片与启动页停留时间详解

    IOS LaunchScreen设置启动图片与启动页停留时间详解

    这篇文章主要介绍了IOS LaunchScreen设置启动图片与启动页停留时间详解的相关资料,需要的朋友可以参考下
    2017-02-02
  • 实例解析iOS中音乐播放器应用开发的基本要点

    实例解析iOS中音乐播放器应用开发的基本要点

    这篇文章主要介绍了iOS开发中制作一个简单的音乐播放器的基本要点解析,代码基于传统的Objective-C,需要的朋友可以参考下
    2016-01-01
  • iOS表视图之下拉刷新控件功能的实现方法

    iOS表视图之下拉刷新控件功能的实现方法

    下拉刷新是重新刷新表视图或列表,以便重新加载数据,这种模式广泛用于移动平台,相信大家对于此也是非常熟悉的,那么iOS是如何做到的下拉刷新呢?下面小编给大家分享iOS表视图之下拉刷新控件的实现方法,一起看看吧
    2017-01-01
  • iOS中日志同步获取NSLog重定向以及其他详解

    iOS中日志同步获取NSLog重定向以及其他详解

    在Objective-c开发程序的时候,有专门的日志操作类NSLog,它将指定的输出,输出到(stderr),我们可以利用Xcode的日志输出窗口,下面这篇文章主要给大家介绍了关于iOS中日志同步获取NSLog重定向以及其他的相关资料,需要的朋友可以参考下。
    2017-12-12
  • iOS组件依赖避免冲突的小技巧分享

    iOS组件依赖避免冲突的小技巧分享

    这篇文章主要给大家介绍了关于iOS组件依赖避免冲突的小技巧,文中通过示例代码介绍的非常详细,对各位iOS开发者们具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-09-09
  • iOS Tabbar中间添加凸起可旋转按钮功能

    iOS Tabbar中间添加凸起可旋转按钮功能

    最近的项目中有需求在tabbar中间添加凸起按钮,并且点击时按钮要旋转,看了仿斗鱼的凸起,点击后是present出来View,这篇文章主要介绍了iOS Tabbar中间添加凸起可旋转按钮,需要的朋友可以参考下
    2017-12-12
  • ios 11和iphone x的相关适配问题及解决方法

    ios 11和iphone x的相关适配问题及解决方法

    这篇文章主要介绍了ios 11和iphone x的相关适配,文中给大家提到了在ios 11中,tableView会莫名偏移问题的解决方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-11-11
  • iOS应用设计模式开发中对简单工厂和工厂方法模式的运用

    iOS应用设计模式开发中对简单工厂和工厂方法模式的运用

    这篇文章主要介绍了iOS应用设计模式开发中对简单工厂和工厂方法模式的运用,示例代码为传统的Objective-C,需要的朋友可以参考下
    2016-03-03
  • iOS开发教程之UIView和UIViewController的生命周期详解

    iOS开发教程之UIView和UIViewController的生命周期详解

    UIViewController是IOS程序中的一个重要组成部分,下面这篇文章主要给大家介绍了关于iOS开发教程之UIView和UIViewController的生命周期的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2018-04-04

最新评论