日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

iOS实现“下雨下雪”动画效果和“烟花”动画效果

發布時間:2024/5/21 编程问答 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 iOS实现“下雨下雪”动画效果和“烟花”动画效果 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

“下雨”的動畫效果

一、效果展示

二、實現流程

  • 設置背景
func setupUI() {self.imageView = UIImageView.init()self.imageView?.frame = CGRect.init(x: 0, y: 0, width: UIScreen.main.bounds.size.width, height: UIScreen.main.bounds.size.height)self.imageView?.image = UIImage.init(named: "rain")self.view.addSubview(self.imageView!)self.view.sendSubviewToBack(self.imageView!)}
  • 設置發射源
self.rainLayer = CAEmitterLayer.init()self.imageView?.layer.addSublayer(self.rainLayer!)// 發射形狀:線性self.rainLayer!.emitterShape = CAEmitterLayerEmitterShape.line// 發射模式self.rainLayer!.emitterMode = CAEmitterLayerEmitterMode.surface// 發射源大小self.rainLayer!.emitterSize = self.view.frame.size// 發射源位置 y最好不要設置為0 最好<0self.rainLayer!.emitterPosition = CGPoint.init(x: self.view.bounds.size.width * 0.5, y: -10)
  • 設置發射粒子
let snowCell = CAEmitterCell.init()// 每秒產生的粒子數量的系數snowCell.birthRate = 25.0// 粒子內容snowCell.contents = UIImage.init(named: "rain_white")?.cgImage// 粒子的生命周期snowCell.lifetime = 20.0// speed粒子速度.圖層的速率。用于將父時間縮放為本地時間,例如,如果速率是2,則本地時間的進度是父時間的兩倍。默認值為1snowCell.speed = 10.0// 粒子速度系數, 默認1.0snowCell.velocity = 10.0// 每個發射物體的初始平均范圍,默認等于0snowCell.velocityRange = 10.0// 粒子在y方向的加速的snowCell.yAcceleration = 1000.0// 粒子縮放比例: scalesnowCell.scale = 0.1// 粒子縮放比例范圍:scaleRangesnowCell.scaleRange = 0.0self.rainLayer?.emitterCells = [snowCell]
  • 點擊事件處理
// MARK: Events Responder@IBAction func responderToRainBig(_ sender: UIButton) {if self.rainLayer!.birthRate < 30 {self.rainLayer?.setValue(self.rainLayer!.birthRate + 1, forKey: "birthRate")self.rainLayer?.setValue(self.rainLayer!.scale + 0.05, forKey: "scale")}}@IBAction func respondertToRainStop(_ sender: UIButton) {sender.isSelected = !sender.isSelectedif sender.isSelected {self.rainLayer?.setValue(0.0, forKey: "birthRate")} else {self.rainLayer?.setValue(1.0, forKey: "birthRate")}}@IBAction func responderToRainSmall(_ sender: UIButton) {if self.rainLayer!.birthRate > 1 {self.rainLayer?.setValue(self.rainLayer!.birthRate - 1, forKey: "birthRate")self.rainLayer?.setValue(self.rainLayer!.scale - 0.05, forKey: "scale")}}

“煙花”的動畫效果

一、效果展示

實現
self.view.backgroundColor = UIColor.black// cell產生在底部,向上移動let fireworkdEmitter = CAEmitterLayer.init()fireworkdEmitter.emitterPosition = CGPoint.init(x: self.view.frame.size.width/2, y: self.view.frame.size.height)fireworkdEmitter.emitterMode = CAEmitterLayerEmitterMode.outlinefireworkdEmitter.emitterShape = CAEmitterLayerEmitterShape.linefireworkdEmitter.renderMode = CAEmitterLayerRenderMode.additivefireworkdEmitter.seed = (arc4random()%100)+1// 創建火箭celllet rocket = CAEmitterCell.init()rocket.birthRate = 1rocket.emissionRange = CGFloat(0.25 * Double.pi);rocket.velocity = 300rocket.velocityRange = 75rocket.lifetime = 1.02rocket.contents = UIImage.init(named: "rain_white")?.cgImagerocket.scale = 0.5rocket.scaleRange = 0.5rocket.color = UIColor.red.cgColorrocket.greenRange = 1.0rocket.redRange = 1.0rocket.blueRange = 1.0rocket.spinRange = CGFloat(Double.pi)// 破裂對象不能被看到,但會產生火花// 這里改變顏色,因為火花繼承它的值let fireCell = CAEmitterCell.init()fireCell.birthRate = 1fireCell.velocity = 0fireCell.scale = 1fireCell.redSpeed = -1.5fireCell.blueSpeed = +1.5fireCell.greenSpeed = +1.5fireCell.lifetime = 0.34// and finally, the sparkslet spark = CAEmitterCell.init()// 炸開后產生400個小煙花spark.birthRate = 400// 速度spark.velocity = 125// 360度spark.emissionRange = CGFloat(2 * Double.pi)// 重力spark.yAcceleration = 40spark.lifetime = 3spark.contents = UIImage.init(named: "rain_white")?.cgImagespark.scaleSpeed = -0.2spark.greenSpeed = -0.1spark.redSpeed = +0.1spark.blueSpeed = -0.1spark.alphaSpeed = -0.25spark.spin = CGFloat(2 * Double.pi)spark.spinRange = CGFloat(2 * Double.pi)fireworkdEmitter.emitterCells = [rocket]rocket.emitterCells = [fireCell]fireCell.emitterCells = [spark];self.view.layer.addSublayer(fireworkdEmitter)

完整示例

  • iOS實現各種粒子的動畫效果

總結

以上是生活随笔為你收集整理的iOS实现“下雨下雪”动画效果和“烟花”动画效果的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 久久这里只有精品99 | www国产在线 | 国内激情 | 成人av影院在线观看 | 青青青网 | 国产在线观看免费 | 一区二区国产电影 | 99在线精品视频 | 欧美成人三级在线观看 | 国产在线免费av | 国产乱国产乱老熟 | 男生裸体视频网站 | 欧美成人aa| 一区二区三区高清不卡 | 国产人妻精品一区二区三区不卡 | 久久22 | 久久电影一区 | 浪漫樱花动漫在线观看免费 | 色婷婷综合五月 | 欧美性久久 | 黑人巨大精品欧美一区二区蜜桃 | 日韩精品成人一区二区在线 | 亚洲久久在线 | 一区二区免费在线观看 | 91精品国产色综合久久不8 | 国产精品区二区三区日本 | 色婷婷国产精品综合在线观看 | 强迫凌虐淫辱の牝奴在线观看 | 九一网站在线观看 | 污漫网站| 亚洲男人天堂 | 亚洲精品福利视频 | 欧美爱爱网站 | av在线高清观看 | 热久久影院 | 暖暖成人免费视频 | 大桥未久视频在线观看 | 欧美人与zoxxxx另类 | 亚洲国产精品午夜久久久 | 男女激情大尺度做爰视频 | 在线看免费毛片 | 亚洲综合五月 | 国产精品国产三级国产aⅴ下载 | 亚日韩欧美 | 日韩3p | xxxx日本少妇 | jizz日本女人| www.啪啪| 成人在线观看你懂的 | 大地资源中文在线观看免费版 | 91本色 | 欧美成人dvd在线视频 | 亚洲欧洲精品在线 | 日韩不卡视频在线 | 狼人综合av | 亚洲v国产v| 国产三级日本三级在线播放 | 日本无遮羞调教打屁股网站 | 嫩草一二三 | 免费99精品国产自在在线 | 日本亲近相奷中文字幕 | 国产一区二区在线免费观看 | 日韩国产精品一区二区三区 | www,超碰 | 波多野结衣在线影院 | 国产精品免费在线播放 | 91中文字幕在线 | 久久精品蜜桃 | jizz视频在线观看 | 外国黄色录像 | 亚洲欧美日韩一区二区三区在线观看 | 久久国产人妻一区二区免色戒电影 | av高清一区二区 | 欧美一级一区 | 成人免费黄色片 | 在线看免费 | 高跟av| 131mm少妇做爰视频 | 99视频网址| 久久精品国产亚洲av麻豆蜜芽 | 激情网站在线 | 亚洲一级在线 | 欧美激情xxxxx | 亚洲伦理一区二区三区 | 欧美一卡二卡在线观看 | 国产欧美精品 | 欧美一级视频在线观看 | 中日韩毛片| 人人舔人人干 | 快射视频网站 | jvid视频| 国产精品第八页 | 久久久久亚洲色欲AV无码网站 | 国产视频第一区 | 麻豆精品国产传媒 | 欧美日皮视频 | 波多野结衣电车 | 林雅儿欧洲留学恋爱日记在线 | 亚洲伦理中文字幕 |