全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Swift洗牌动画效果的实现方法

目标效果: 点击动画按钮之后每张牌各自旋转 散开到屏幕上半部分的任意位置之后回到初始位置 比较像LOL男刀的技能动画 : )

1: 创建卡牌对象

for _ in 0...49 {
        let cardSet = UIImageView(image: UIImage(named: "cardBackLandscape"))
        self.view.addSubview(cardSet)
        cardSet.frame = self.landscapeCardBack.frame
        self.cardSetList.append(cardSet)
      }
      NSNotificationCenter.defaultCenter().postNotificationName("setCreated", object: nil)

把每个卡牌作为UIImageView创建出来,为了之后对这些牌进行操作 我用数组把他们持有住 在同一位置创建好了之后 使用本地通知发送setCreated消息 告诉这个页面的观察者card set已经创建完毕 可以开始执行第二步动画

2: 首先需要把开始动画的按钮的用户交互关闭,如果开着的话连续点击每次都会创建50张牌,导致程序卡顿甚至挂掉

这里的delayTime是给线程加一个延迟时间 只是为了让动画不很生硬

每次循环给对应下标的card对象添加旋转动画,并且改变它的原点,我在用UIView动画实现这套动画之前想过给每张牌添加贝塞尔曲线,那样的话确实可控性更高,但是由于时间关系我还是只用了UIViewAnimation,给card添加的旋转动画是使用POP动画库实现的,这里使用的是Basic动画.这一步结束之后会把每张牌旋转并散开到不同的位置,在delayTime结束并触发本地通知发送shuffleFinished的时候,这个页面的观察者会执行下一部动画 也就是把每张牌还原到动画起点

func shuffleTheSet() {
    self.shuffleButton.userInteractionEnabled = false
    let delayTime = dispatch_time(DISPATCH_TIME_NOW, Int64(0.5 * Double(NSEC_PER_SEC)))
    dispatch_after(delayTime, dispatch_get_main_queue()) {
      NSNotificationCenter.defaultCenter().postNotificationName("shuffleFinished", object: nil)
    }
    for count in 0...49 {
      UIView.animateWithDuration(0.3, animations: {
        let cardRotateAnimation = POPBasicAnimation(propertyNamed: kPOPLayerRotation)
        cardRotateAnimation.fromValue = 0
        cardRotateAnimation.toValue = CGFloat(M_PI * 2.0)
        cardRotateAnimation.duration = 1
        //        cardRotateAnimation.duration = Double(count>5 ? count/2 : count/10)
        cardRotateAnimation.timingFunction = CAMediaTimingFunction(name: kCAMediaTimingFunctionLinear)
        self.cardSetList[count].layer.pop_addAnimation(cardRotateAnimation, forKey: "cardRotation")
        self.cardSetList[count].frame.origin = CGPointMake(CGFloat(arc4random()) % (250 - 0 + 1) + 0, CGFloat(arc4random()) % (300 - 74 + 1) + 74)
        self.view.layoutIfNeeded()
        self.landscapeCardBack.removeFromSuperview()
      })
    }
  }

3: 把每张牌的还原到初始位置,并把button的title设置为切牌状态.

for count in 0...49 {
      UIView.animateWithDuration(0.3, animations: {
        self.cardSetList[count].center = self.landscapeCardBack.center
      })
      self.view.layoutIfNeeded()
    }
    self.shuffleButton.userInteractionEnabled = true
    self.shuffleButton.setTitle("Cut Card", forState: .Normal)

牌洗完之后的需求是切牌,由于时间原因下周继续更新后续动画效果…

以上所述是小编给大家介绍的Swift洗牌动画效果的实现方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# swift  # 洗牌动画效果  # Swift自定义iOS中的TabBarController并为其添加动画  # Swift语言实现地图坐标弹跳动画  # 利用swift实现卡片横向滑动动画效果的方法示例  # iOS swift实现转场动画的方法示例  # 利用Swift实现各类的CATransition动画详解  # 小编  # 的是  # 我在  # 好了  # 在此  # 卡牌  # 我用  # 更高  # 给大家  # 想过  # 会把  # 这套  # 开着  # 设置为  # 并把  # 第二步  # 所述  # 给我留言  # 洗完  # 感谢大家 


相关文章: 如何制作算命网站,怎么注册算命网站?  如何在IIS管理器中快速创建并配置网站?  如何快速建站并高效导出源代码?  建站主机如何选?高性价比方案全解析  如何在阿里云域名上完成建站全流程?  网站制作员失业,怎样查看自己网站的注册者?  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  网站制作软件免费下载安装,有哪些免费下载的软件网站?  如何有效防御Web建站篡改攻击?  专业网站制作服务公司,有哪些网站可以免费发布招聘信息?  建站之星ASP如何实现CMS高效搭建与安全管理?  香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧  建站主机功能解析:服务器选择与快速搭建指南    如何在服务器上配置二级域名建站?  建站之星3.0如何解决常见操作问题?  如何快速生成ASP一键建站模板并优化安全性?  网站企业制作流程,用什么语言做企业网站比较好?  娃派WAP自助建站:免费模板+移动优化,快速打造专业网站  行程制作网站有哪些,第三方机票电子行程单怎么开?  建站上传速度慢?如何优化加速网站加载效率?  实现点击下箭头变上箭头来回切换的两种方法【推荐】  制作网站外包平台,自动化接单网站有哪些?  建站之星好吗?新手能否轻松上手建站?  如何在VPS电脑上快速搭建网站?  网站网页制作专业公司,怎样制作自己的网页?  存储型VPS适合搭建中小型网站吗?  建站之星安装需要哪些步骤及注意事项?  定制建站模板如何实现SEO优化与智能系统配置?18字教程  网站按钮制作软件,如何实现网页中按钮的自动点击?  建站主机系统SEO优化与智能配置核心关键词操作指南  如何快速生成可下载的建站源码工具?  广州网站建站公司选择指南:建站流程与SEO优化关键词解析  官网网站制作腾讯审核要多久,联想路由器newifi官网  建站主机与服务器功能差异如何区分?  广州美橙建站如何快速搭建多端合一网站?  上海网站制作开发公司,上海买房比较好的网站有哪些?  如何在腾讯云免费申请建站?  如何在万网主机上快速搭建网站?  详解jQuery中基本的动画方法  太平洋网站制作公司,网络用语太平洋是什么意思?  如何在阿里云服务器自主搭建网站?  建站之星云端配置指南:模板选择与SEO优化一键生成  如何通过网站建站时间优化SEO与用户体验?  建站主机服务器选型指南与性能优化方案解析  制作企业网站建设方案,怎样建设一个公司网站?  网站微信制作软件,如何制作微信链接?  名字制作网站免费,所有小说网站的名字?  高防服务器租用如何选择配置与防御等级?  阿里云网站制作公司,阿里云快速搭建网站好用吗? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。