使用OC和Swift两种语言写一个发射烟花的小项目
OC与Swift两种实现方式基本上区别不大,主要是在一些对象或方法的调用方式不同,附带源码。
OC代码样式:
self.view.backgroundColor = [UIColor blackColor];
//加载颗粒状的火花图片
CAEmitterLayer *emitterLa = [CAEmitterLayer layer];
emitterLa.emitterPosition = CGPointMake(self.view.bounds.size.width/2, self.view.bounds.size.height*(.75));//*(0.75)
emitterLa.renderMode = kCAEmitterLayerAdditive;
//在爆炸前逐渐隐藏发射颗粒
CAEmitterCell *emitterCeRocket = [CAEmitterCell emitterCell];
emitterCeRocket.emissionLongitude = -M_PI/2;
emitterCeRocket.emissionLatitude = 0;
emitterCeRocket.lifetime = 1.6;
emitterCeRocket.birthRate = 1;
emitterCeRocket.velocity = 400;
emitterCeRocket.velocityRange = 100;
emitterCeRocket.yAcceleration = 250;
emitterCeRocket.emissionRange = M_PI/4;
emitterCeRocket.color = CGColorCreateCopy([UIColor colorWithRed:0.5 green:0.5 blue:0.5 alpha:0.5].CGColor);
emitterCeRocket.redRange = 0.5;
emitterCeRocket.greenRange = 0.5;
emitterCeRocket.blueRange = 0.5;
//设置动画效果的路径名称
[emitterCeRocket setName:@"rocket"];
//添加路径状态
CAEmitterCell *emitterCeFly = [CAEmitterCell emitterCell];
emitterCeFly.contents = (id)[UIImage imageNamed:@"tspark.png"].CGImage;
emitterCeFly.emissionLongitude = (4*M_PI)/2;
emitterCeFly.scale = 0.4;
emitterCeFly.velocity = 100;
emitterCeFly.birthRate = 45;
emitterCeFly.lifetime = 1.5;
emitterCeFly.yAcceleration = 350;
emitterCeFly.emissionRange = M_PI/7;
emitterCeFly.alphaSpeed = -0.7;
emitterCeFly.scaleSpeed = -0.1;
emitterCeFly.scaleRange = 0.1;
emitterCeFly.beginTime = 0.01;
emitterCeFly.duration = 0.7;
//设置爆炸
CAEmitterCell *emitterCeFirework = [CAEmitterCell emitterCell];
emitterCeFirework.contents = (id)[UIImage imageNamed:@"tspark.png"].CGImage;
emitterCeFirework.birthRate = 9999;
emitterCeFirework.scale = 0.6;
emitterCeFirework.velocity = 130;
emitterCeFirework.lifetime = 2;
emitterCeFirework.alphaSpeed = -0.2;
emitterCeFirework.yAcceleration = 80;
emitterCeFirework.beginTime = 1.5;
emitterCeFirework.duration = 0.1;
emitterCeFirework.emissionRange = 2*M_PI;
emitterCeFirework.scaleSpeed = -0.1;
emitterCeFirework.spin = 2;
//设置爆炸动画名称
[emitterCeFirework setName:@"firework"];
//添加重复过程
CAEmitterCell *emitterCePreSpark = [CAEmitterCell emitterCell];
emitterCePreSpark.birthRate = 80;
emitterCePreSpark.velocity = emitterCeFirework.velocity*0.7;
emitterCePreSpark.lifetime = 1.7;
emitterCePreSpark.yAcceleration = emitterCeFirework.yAcceleration*0.85;
emitterCePreSpark.beginTime = emitterCeFirework.beginTime-0.2;
emitterCePreSpark.emissionRange = emitterCeFirework.emissionRange;
emitterCePreSpark.greenSpeed = 100;
emitterCePreSpark.blueSpeed = 100;
emitterCePreSpark.redSpeed = 100;
//设置重复动画名称
[emitterCePreSpark setName:@"preSpark"];
//烟花最后的闪光
CAEmitterCell *emitterCeSparkle = [CAEmitterCell emitterCell];
emitterCeSparkle.contents = (id)[UIImage imageNamed:@"tspark.png"].CGImage;
emitterCeSparkle.lifetime = 0.05;
emitterCeSparkle.yAcceleration = 250;
emitterCeSparkle.beginTime = 0.8;
emitterCeSparkle.scale = 0.4;
emitterCeSparkle.birthRate = 10;
emitterCePreSpark.emitterCells = [NSArray arrayWithObjects:emitterCeSparkle, nil];
emitterCeRocket.emitterCells = [NSArray arrayWithObjects:emitterCeFly,emitterCeFirework,emitterCePreSpark, nil];
emitterLa.emitterCells = [NSArray arrayWithObjects:emitterCeRocket, nil];
[self.view.layer addSublayer:emitterLa];
Swift的代码样式:
self.view.backgroundColor = UIColor.blackColor();
//加载颗粒状的火花图片
let emitterLa = CAEmitterLayer();
emitterLa.emitterPosition = CGPointMake(self.view.bounds.size.width/2, self.view.bounds.size.height*0.75);
emitterLa.renderMode = kCAEmitterLayerAdditive;
//爆炸前逐渐隐藏发射颗粒
let emitterCeRocket = CAEmitterCell();
emitterCeRocket.emissionLongitude = CGFloat(-M_PI_2);
emitterCeRocket.emissionLatitude = 0;
emitterCeRocket.lifetime = 1.6;
emitterCeRocket.birthRate = 1;
emitterCeRocket.velocity = 400;
emitterCeRocket.velocityRange = 100;
emitterCeRocket.yAcceleration = 250;
emitterCeRocket.emissionRange = CGFloat(M_PI/4);
emitterCeRocket.color = CGColorCreateCopy(UIColor(red: 0.5, green:0.5, blue:0.5, alpha:0.5).CGColor);
emitterCeRocket.redRange = 0.5;
emitterCeRocket.greenRange = 0.5;
emitterCeRocket.blueRange = 0.5;
//设置动画效果的路径名称
emitterCeRocket.name = "rocket";
//添加路径状态
let emitterCeFly = CAEmitterCell();
emitterCeFly.contents = UIImage(named: "tspark.png")!.CGImage;
emitterCeFly.emissionLongitude = CGFloat((4*M_PI)/2);
emitterCeFly.scale = 0.4;
emitterCeFly.velocity = 100;
emitterCeFly.birthRate = 45;
emitterCeFly.lifetime = 1.5;
emitterCeFly.yAcceleration = 350;
emitterCeFly.emissionRange = CGFloat(M_PI/7);
emitterCeFly.alphaSpeed = -0.7;
emitterCeFly.scaleSpeed = -0.1;
emitterCeFly.scaleRange = 0.1;
emitterCeFly.beginTime = 0.01;
emitterCeFly.duration = 0.7;
//设置爆炸
let emitterCeFirework = CAEmitterCell();
emitterCeFirework.contents = UIImage(named: "tspark.png")!.CGImage;
emitterCeFirework.birthRate = 9999;
emitterCeFirework.scale = 0.6;
emitterCeFirework.velocity = 130;
emitterCeFirework.lifetime = 2;
emitterCeFirework.alphaSpeed = -0.2;
emitterCeFirework.yAcceleration = 80;
emitterCeFirework.beginTime = 1.5;
emitterCeFirework.duration = 0.1;
emitterCeFirework.emissionRange = CGFloat(2*M_PI);
emitterCeFirework.scaleSpeed = -0.1;
emitterCeFirework.spin = 2;
//设置爆炸动画名称
emitterCeFirework.name = "firework";
//添加重复过程
let emitterCePreSpark = CAEmitterCell();
emitterCePreSpark.birthRate = 80;
emitterCePreSpark.velocity = emitterCeFirework.velocity*0.7;
emitterCePreSpark.lifetime = 1.7;
emitterCePreSpark.yAcceleration = emitterCeFirework.yAcceleration*0.85;
emitterCePreSpark.beginTime = emitterCeFirework.beginTime-0.2;
emitterCePreSpark.emissionRange = emitterCeFirework.emissionRange;
emitterCePreSpark.greenSpeed = 100;
emitterCePreSpark.blueSpeed = 100;
emitterCePreSpark.redSpeed = 100;
//设置重复动画名称
emitterCePreSpark.name = "preSpark";
//烟花最后的闪光
let emitterCeSparkle = CAEmitterCell();
emitterCeSparkle.contents = UIImage(named: "tspark.png")!.CGImage;
emitterCeSparkle.lifetime = 0.05;
emitterCeSparkle.yAcceleration = 250;
emitterCeSparkle.beginTime = 0.8;
emitterCeSparkle.scale = 0.4;
emitterCeSparkle.birthRate = 10;
emitterCePreSpark.emitterCells = NSArray.init(objects:emitterCeSparkle) as? [CAEmitterCell];
emitterCeRocket.emitterCells = NSArray.init(objects:emitterCeFly,emitterCeFirework,emitterCePreSpark) as? [CAEmitterCell];
emitterLa.emitterCells = NSArray.init(objects: emitterCeRocket) as? [CAEmitterCell];
self.view.layer.addSublayer(emitterLa);
源码下载:http://download.csdn.net/detail/hbblzjy/9584992
效果图:
使用OC和Swift两种语言写一个发射烟花的小项目的更多相关文章
- 【Swfit】Swift与OC两种语法写单例的区别
Swift与OC两种语法写单例的区别 例如写一个NetworkTools的单例 (1)OC写单例 + (instancetype)sharedNetworkTools { static id inst ...
- 一个label两种颜色,一个label两种字体
-(void)addLabel{ UILabel *label = [[UILabel alloc]init]; label.backgroundColor = [UIColor grayColor] ...
- 用C语言写一个“事件”的模拟程序
源:用C语言写一个“事件”的模拟程序 Example.c //定义一个函数指针 func int (*func) (void); //调用该函数相当于触发了事件. //该事件触发后,会检查函数指针fu ...
- 用 C# 写一个 Redis 数据同步小工具
用 C# 写一个 Redis 数据同步小工具 Intro 为了实现 redis 的数据迁移而写的一个小工具,将一个实例中的 redis 数据同步到另外一个实例中.(原本打算找一个已有的工具去做,找了一 ...
- 两种语言实现设计模式(C++和Java)(一:工厂模式)
本篇开始记录实现设计模式在工作中的两种常见语言上的实现. 本篇介绍最简单的工厂模式. 工厂模式有一种非常形象的描述,建立对象的类就如一个工厂,而需要被建立的对象就是一个个产品:在工厂中加工产品,使用产 ...
- 两种语言实现设计模式(C++和Java)(三:策略模式)
策略模式是指定义一系列的算法,把它们一个个封装起来,并且使它们可相互替换.本模式使得算法可独立于使用它的客户而变化.也就是说这些算法所完成的功能一样,对外的接口一样,只是各自实现上存在差异.用策略模式 ...
- JavaScript两种方法来定义一个函数
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- 可采用两种方法得到一个EJB对象
(本文是转载其他人的技术文章,觉得说得挺浅显易懂,特借来学习) 在前面学习的例子中,只有一个EJB,但是对于一个真实的项目,EJB的数量可以有很多,而且EJB之间也会互相调用,那么在一个EJB ...
- 网络编程—【自己动手】用C语言写一个基于服务器和客户端(TCP)!
如果想要自己写一个服务器和客户端,我们需要掌握一定的网络编程技术,个人认为,网络编程中最关键的就是这个东西--socket(套接字). socket(套接字):简单来讲,socket就是用于描述IP地 ...
随机推荐
- Docker 数据卷容器
如果你有一些持续更新的数据需要在容器之间共享,最好创建数据卷容器. 数据卷容器,其实就是一个正常的容器,专门用来提供数据卷供其它容器挂载的. 首先,创建一个命名的数据卷容器 dbdata: $ sud ...
- Android开发技巧——BaseAdapter的另一种优雅封装
RecyclerView虽然因其灵活性.高效性等特点而备受好评,但也不是一定得用它把ListView给替代掉.在某些场景中,ListView还是相对更适合的.比如数据量不大,不频繁更新,并且需要简单地 ...
- npm killed有可能是内存不够, 为Ubuntu增加swap
参考 http://www.cnblogs.com/owenyang/p/4282283.html 查看swap使用策略 cat /proc/sys/vm/swappiness 0代表尽量使用物理内存 ...
- 亲密接触Redis-第三天(Redis的Load Balance)
前言 上两天讲述了Redis的基本搭建和基于HA的集群布署方式以及相关的策略和注意点.今天开始讲述Redis的Cluster功能,而这块目前来说网上资料不是太全,就算有1,2篇也只是单讲服务端的搭建也 ...
- 将Gradle项目发布到Jcenter和Maven Central
Jcenter和Maven Central 为了方便我们理解Android studio是如何帮助我们获取开源库的,我们需要理清几个概念.Apache Maven是Apache开发的一个工具,提供了用 ...
- springMVC源码分析--AbstractUrlHandlerMapping(三)
上一篇博客springMVC源码分析--AbstractHandlerMapping(二)中我们介绍了AbstractHandlerMapping了,接下来我们介绍其子类AbstractUrlHand ...
- 代码优化>>>Android ListView适配器三级优化详解
转载本专栏每一篇博客请注明转载出处地址,尊重原创.此博客转载链接地址:点击打开链接 http://blog.csdn.net/qq_32059827/article/details/52718489 ...
- Scala actor的使用
Actor 为什么需要Actor? Actor的本质即万物皆Actor, Actor之间只有发送消息这一种通信方式.例如,无论是管理员让工作者干活,还是工作者把成果交还给管理员,它们之间也要通过发送消 ...
- Dynamics CRM Trace Reader for Microsoft Dynamics CRM
CRM中抓取日志的视窗工作叫做Diagnastics Tools For Dyanmics CRM,这个工具我们只是作为一个开关来用就不做多介绍了,日志生成后是个文本文档可读性是很差的,那就需要个视窗 ...
- Hadoop:Hadoop单机伪分布式的安装和配置
http://blog.csdn.net/pipisorry/article/details/51623195 因为lz的linux系统已经安装好了很多开发环境,可能下面的步骤有遗漏. 之前是在doc ...