欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Swift使用transform 實(shí)現(xiàn)重復(fù)平移動畫效果

 更新時間:2021年07月21日 09:13:45   作者:我為雙魚狂  
這篇文章主要介紹了Swift使用transform 實(shí)現(xiàn)重復(fù)平移動畫效果,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

摘要

要實(shí)現(xiàn)一組重復(fù)的動畫,本質(zhì)上就是找到動畫開始點(diǎn)、結(jié)束點(diǎn)。在動畫結(jié)束的時候,觸發(fā)開始點(diǎn),持續(xù)這樣的動作。

這里面要梳理的邏輯就是1.觸發(fā)開始點(diǎn)和2.監(jiān)聽動畫結(jié)束點(diǎn)。這兩個邏輯是實(shí)現(xiàn)重復(fù)動畫的基礎(chǔ)。

應(yīng)用場景

將 imageView 等 UI 控件,設(shè)置成平移的動畫,并且一直動畫中。

transform 可以實(shí)現(xiàn)控件的平移,但是無法連續(xù)動畫。

API 及語言

核心邏輯/代碼

transform 可以將控件平移,為了達(dá)到連續(xù)動畫,可使用遞歸方式實(shí)現(xiàn)。

動畫實(shí)現(xiàn)

設(shè)置動畫并開始
使用 UIView.animate(withDuration: , animations: , completion: ) 函數(shù)設(shè)置動畫。

這個方法有開始動畫事件,也有監(jiān)聽動畫完成事件(completion 方法)

實(shí)現(xiàn)連續(xù)動畫

在completion 中遞歸調(diào)用開始動畫函數(shù),達(dá)到連續(xù)動畫的效果。

停止動畫

設(shè)置一個全局的標(biāo)示,來記錄動畫的狀態(tài),也可以通過更改這個狀態(tài)來判斷是否需要開始動畫,比如設(shè)置 UI 控件的isHidden屬性,實(shí)現(xiàn)停止動畫

細(xì)節(jié)

在開始動畫的時候,就進(jìn)行判斷,如果isHidden為 true,則直接停止動畫??梢跃珳?zhǔn)控制動畫的次數(shù)。

在開始動畫函數(shù)中設(shè)置閉包,可以在閉包中設(shè)置停止動畫的代碼等。

示例代碼

重復(fù) 3 次平移動畫,在每次動畫開始前都判斷self.guideImageView.isHidden, 在動畫過程中,如果要停止動畫,只需設(shè)置 self.guideImageView.isHidden = false, 就停止動畫。

func guideAnimations() {
        // 動畫執(zhí)行 3 次
        var count = 3
        // 開始動畫
        startAnimation {[weak self] in
            guard let self = self else { return }
            count -= 1
            if count == 0 { self.guideImageView.isHidden = true }
        }
    }
    
    // 設(shè)置并開始動畫
    func startAnimation(_ complete: @escaping ()->()) {
        if self.guideImageView.isHidden { return }
        
        UIView.animate(withDuration: 1, delay: 0, options: .curveEaseInOut) {
            self.guideImageView.transform = self.guideImageView.transform.translatedBy(x: -50, y: 0)

        } completion: { [weak self](finish) in
            // 動畫結(jié)束時,將控件復(fù)原
            guard let self = self else { return }
            self.guideImageView.transform = self.guideImageView.transform.translatedBy(x: 50, y: 0)
            // 先返回閉包,然后再執(zhí)行動畫函數(shù)
            complete()
            self.startAnimation(complete)
        }
    }
    
    // 停止動畫
    func stopAnimation() {
        if self.guideImageView.isHidden == false {
            self.guideImageView.isHidden = true
        }
    }

到此這篇關(guān)于Swift使用transform 實(shí)現(xiàn)重復(fù)平移動畫效果的文章就介紹到這了,更多相關(guān)transform 重復(fù)平移動畫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • swift4.2實(shí)現(xiàn)新聞首頁導(dǎo)航

    swift4.2實(shí)現(xiàn)新聞首頁導(dǎo)航

    這篇文章主要為大家詳細(xì)介紹了swift4.2實(shí)現(xiàn)新聞首頁導(dǎo)航,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • Swift如何使用類型擦除及自定義詳解

    Swift如何使用類型擦除及自定義詳解

    有很多地方會用到類型擦除,并且它們的作用的各不相同。下面這篇文章主要給大家介紹了關(guān)于Swift如何使用類型擦除及自定義的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2018-10-10
  • 倉庫模式及其在Swift?項(xiàng)目中的應(yīng)用詳解

    倉庫模式及其在Swift?項(xiàng)目中的應(yīng)用詳解

    這篇文章主要為大家介紹了倉庫模式及其在Swift?項(xiàng)目中的應(yīng)用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • Swift中的可變參數(shù)函數(shù)介紹

    Swift中的可變參數(shù)函數(shù)介紹

    這篇文章主要介紹了Swift中的可變參數(shù)函數(shù)介紹,本文實(shí)現(xiàn)了和Objective-C調(diào)用方法一樣的變參數(shù)函數(shù),需要的朋友可以參考下
    2015-01-01
  • SwiftUI?引導(dǎo)頁界面實(shí)現(xiàn)示例

    SwiftUI?引導(dǎo)頁界面實(shí)現(xiàn)示例

    這篇文章主要為大家介紹了SwiftUI?引導(dǎo)頁界面實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • 如何在Swift?中使用?async?let?并發(fā)運(yùn)行后臺任務(wù)

    如何在Swift?中使用?async?let?并發(fā)運(yùn)行后臺任務(wù)

    Swift?異步編程是一種編寫允許某些任務(wù)并發(fā)運(yùn)行而不是按順序運(yùn)行的代碼的方法,這篇文章主要介紹了在Swift中使用async?let并發(fā)運(yùn)行后臺任務(wù),需要的朋友可以參考下
    2023-06-06
  • 關(guān)于swift的個人小結(jié)

    關(guān)于swift的個人小結(jié)

    本文是個人對于目前學(xué)習(xí)swift的一些心得的匯總,這里分享給大家,希望大家能夠喜歡
    2016-12-12
  • 舉例講解Swift編程中switch...case語句的用法

    舉例講解Swift編程中switch...case語句的用法

    這篇文章主要介紹了Swift編程中switch...case語句的用法,其中fallthrough關(guān)鍵字在switch語句中的使用是重點(diǎn),需要的朋友可以參考下
    2016-04-04
  • swift實(shí)現(xiàn)自動輪播圖效果(UIScrollView+UIPageControl+Timer)

    swift實(shí)現(xiàn)自動輪播圖效果(UIScrollView+UIPageControl+Timer)

    這篇文章主要為大家詳細(xì)介紹了swift實(shí)現(xiàn)自動輪播圖效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-09-09
  • Swift用final關(guān)鍵字來防止重寫

    Swift用final關(guān)鍵字來防止重寫

    final關(guān)鍵字在大多數(shù)的編程語言中都存在,表示不允許對其修飾的內(nèi)容進(jìn)行繼承或者重新操作。下面通過實(shí)例代碼給大家介紹swift用final關(guān)鍵字來防止重寫
    2016-12-12

最新評論