动画·第一个简单的iOS应用升级版

基础动画

基础动画是指在一个开始值和结束值之间制作动画。

alpha

给问题标签的 alpha (视图的透明度)属性添加动画。当用户切换到下一个问题时 ,使用动画让标签逐渐隐藏。

  • 可用的UIView方法
    class func animate(withDuration: TimeInterval, animations: () -> Void)
    使用指定的持续时间为一个或多个视图的更改添加动画效果。
    duration 是 NSTimeinterval 类型(它也属于 Double 类型) ,animations 是一个闭包。

  • 闭包语法

{( arguments ) -> return type in
      code
}

另一个标签

在界面上再添加一个标签,点击下一题时,现有的标签会渐渐消失 ,新的标签(显示了下 一题的文字)会渐渐出现。

import UIKit

//@IBAction
//标签和按钮
//重载:override func viewDidLoad()

class ViewController: UIViewController {

    //@IBOutlet var questionLable: UILabel! //@IBOutlet 关键字告诉 Xcode, 之后会使用 Interface Builder 关联插座变量。
    @IBOutlet var currentQuestionLabel:UILabel!
    @IBOutlet var currentQuestionLabelCenterXConstraint:NSLayoutConstraint!
    //该插座变量的为 NSLayoutConstraint 型,表明该插座变量用于关联 约束。
    @IBOutlet var nextQuestionLabel:UILabel!
    @IBOutlet var nextQuestionLabelCenterXConstraint:NSLayoutConstraint!
    
    @IBOutlet var answerLable: UILabel!
    //新添加的代码为所有 ViewController 对象增加了一个 questionlabel 插座变量和 answerlabel 插座变量。视图控制器可以使用一个插座变量对应一个特定的 UILabel 对象。
    let questions: [String] = ["From what is cognac made?",
                               "What is 7+7?",
                               "What is the capital of Vermont?"]
    let answers:[String] = [ "Montpelir","14", "Grapes"]
    
    var currentQuestionIndex: Int = 0
    
    @IBAction func showNextQuesion(sender: AnyObject){  //只有按下按钮后(@IBAction),该函数才会运行。
        currentQuestionIndex += 1  //用户每点击一次,currentQuestionIndex 就加 1。
        if currentQuestionIndex == questions.count{  //如果currentQuestionIndex = 3,currentQuestionIndex则置为0
            currentQuestionIndex = 0
        }

        let question: String = questions[currentQuestionIndex]
        print(currentQuestionIndex)  //显示 currentQuestionIndex 的值
        
        currentQuestionLabel.textAlignment = .center //让文字居中对齐。
        currentQuestionLabel.adjustsFontSizeToFitWidth = true  //让文字自适应标签的宽度。
//        questionLable.numberOfLines = 0
//        questionLable.lineBreakMode = NSLineBreakMode.byWordWrapping
        
        nextQuestionLabel.text = question
        
        answerLable.text = "???"
        
        animateLabelTransitions()
    
    }
    
    @IBAction func showAnswer(sender: AnyObject){
        let answer: String = answers[currentQuestionIndex]//此处 currentQuestionIndex 的值和 showNextQuesion 里的 currentQuestionIndex 值一样。
        print(currentQuestionIndex)  //这里的 currentQuestionIndex 值随上面的值的变化而变化。
        answerLable.textAlignment = .center
        answerLable.text = answer
    
    }
    
    
    func animateLabelTransitions() {  //动画实现函数
        
//闭包:用于功能实现
//        let animationClosure = {() -> Void in
//            self.questionLable.alpha = 1
//        }
        
//功能实现1
//缺陷:如果再点一次下一题,由于 nextQuestionlabel 的透明度已经是 1 了,所以不会有动画。
//        UIView.animate(withDuration: 0.5, animations: {
//            self.currentQuestionLabel.alpha = 0
//            self.nextQuestionLabel.alpha = 1
//        })
        
        //约束位置动画化
        view.layoutIfNeeded()  //强制更新界面布局
        let screenWidth = view.frame.width
        self.nextQuestionLabelCenterXConstraint.constant = 0
        self.currentQuestionLabelCenterXConstraint.constant += screenWidth
//功能升级2
//交换两个标签的引用关系。在动画完成后,设置 currentQuestionlabel 指向屏幕上的标签, nextQuestionlabel 指向隐藏的标签。
        //动画化标签透明度,使其达到淡入浅出的效果。
        UIView.animate(withDuration: 0.5,
                       delay: 0,
                       options: [],  //默认情况下,动画会使用渐入 渐出的时间方法。
                       //options: [.curveLinear],  //动画变为线性的,从头到尾都是相同的速度。
                       animations: {
                        self.currentQuestionLabel.alpha = 0
                        self.nextQuestionLabel.alpha = 1
                        
                        self.view.layoutIfNeeded()  //迫使视图根据最新的约束来布局其子视图
                       },
                       completion: {_ in
                        swap(&self.currentQuestionLabel, &self.nextQuestionLabel)
                        //使用 swap(_:_:) 方法可以将两个参数接收后再进行交换。
                        swap(&self.currentQuestionLabelCenterXConstraint,
                        &self.nextQuestionLabelCenterXConstraint)
                        self.updateOffScreenLabel()
                       }
                       )
        
        
    }
    
    override func viewWillAppear(_ animated: Bool) {
        super.viewWillAppear(animated)
        nextQuestionLabel.alpha = 0
        
    }
    
    override func viewDidLoad(){
        //重载:应用启动之后,需要从数组中取出第一个问题,然后替换掉 questionlabexl 的占位符"???"。
        super.viewDidLoad()
        currentQuestionLabel.textAlignment = .center
        answerLable.textAlignment = .center
        currentQuestionLabel.text = questions[currentQuestionIndex]
        
        updateOffScreenLabel()  //当加载 ViewController 的视图时,将 nextQuestionLabel 移动到其屏幕外的位置。
        
        currentQuestionLabel.adjustsFontSizeToFitWidth = true  //让文字自适应标签的宽度。
        answerLable.text = "???"
    }
    
    func updateOffScreenLabel() {
        let screenWidth = view.frame.width
        nextQuestionLabelCenterXConstraint.constant = -screenWidth
        //根据storyboard设置的约束可知,父视图的中心约束位置是 nextQuestionLabelCenterXConstraint 和 currentQuestionLabelCenterXConstraint 的初始位置,初始位置默认的 constant 值为 0。

    }

}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容

  • 16宿命:用概率思维提高你的胜算 以前的我是风险厌恶者,不喜欢去冒险,但是人生放弃了冒险,也就放弃了无数的可能。 ...
    yichen大刀阅读 6,042评论 0 4
  • 公元:2019年11月28日19时42分农历:二零一九年 十一月 初三日 戌时干支:己亥乙亥己巳甲戌当月节气:立冬...
    石放阅读 6,877评论 0 2
  • 今天上午陪老妈看病,下午健身房跑步,晚上想想今天还没有断舍离,马上做,衣架和旁边的的布衣架,一看乱乱,又想想自己是...
    影子3623253阅读 2,910评论 1 8