Swift洗牌动画效果的实现方法
目标效果:点击动画按钮之后每张牌各自旋转散开到屏幕上半部分的任意位置之后回到初始位置比较像LOL男刀的技能动画:)
1:创建卡牌对象
for_in0...49{ letcardSet=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消息告诉这个页面的观察者cardset已经创建完毕可以开始执行第二步动画
2:首先需要把开始动画的按钮的用户交互关闭,如果开着的话连续点击每次都会创建50张牌,导致程序卡顿甚至挂掉
这里的delayTime是给线程加一个延迟时间只是为了让动画不很生硬
每次循环给对应下标的card对象添加旋转动画,并且改变它的原点,我在用UIView动画实现这套动画之前想过给每张牌添加贝塞尔曲线,那样的话确实可控性更高,但是由于时间关系我还是只用了UIViewAnimation,给card添加的旋转动画是使用POP动画库实现的,这里使用的是Basic动画.这一步结束之后会把每张牌旋转并散开到不同的位置,在delayTime结束并触发本地通知发送shuffleFinished的时候,这个页面的观察者会执行下一部动画也就是把每张牌还原到动画起点
funcshuffleTheSet(){ self.shuffleButton.userInteractionEnabled=false letdelayTime=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) } forcountin0...49{ UIView.animateWithDuration(0.3,animations:{ letcardRotateAnimation=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设置为切牌状态.
forcountin0...49{ UIView.animateWithDuration(0.3,animations:{ self.cardSetList[count].center=self.landscapeCardBack.center }) self.view.layoutIfNeeded() } self.shuffleButton.userInteractionEnabled=true self.shuffleButton.setTitle("CutCard",forState:.Normal)
牌洗完之后的需求是切牌,由于时间原因下周继续更新后续动画效果…
以上所述是小编给大家介绍的Swift洗牌动画效果的实现方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!