利用MJRefresh自定義刷新動(dòng)畫

在一些主流的app中宜雀,我們經(jīng)彻谈茫可以看到各式各樣獨(dú)特的刷新動(dòng)畫。這些刷新動(dòng)畫獨(dú)特新穎脆诉,能夠很好的契合app的內(nèi)容甚亭,抓住用戶的眼球。本文就講用一個(gè)簡(jiǎn)單的例子介紹下使用MJRefresh來(lái)自定義刷新動(dòng)畫击胜。先看下效果亏狰。

GaugeBoard.gif

這個(gè)刷新動(dòng)畫就是模擬一個(gè)汽車儀表盤指針轉(zhuǎn)動(dòng)的效果。制作主要分為兩步偶摔,動(dòng)畫效果的完成和MJRefresh集成動(dòng)畫暇唾。

一:動(dòng)畫效果制作

這個(gè)動(dòng)畫制作用到的素材是兩張圖片,一張是背景圖儀表盤(gaugeView)辰斋,另外一張圖是紅色的指針(pointView)策州。首先讓兩張圖片的中心位于同一個(gè)點(diǎn)。
pointView.center = gaugeView.center
然后通過設(shè)置pointViewtransform屬性宫仗,讓其先逆時(shí)針偏移60度够挂。完成之后再順時(shí)針偏移60度(相對(duì)于pointView的起始位置)。這樣整個(gè)動(dòng)畫效果就完成了锰什。

    func startAnimation()  {
        if self.stop {
            return
        }
        UIView.animate(withDuration: 0.4, animations: {
            let transform = CGAffineTransform.init(rotationAngle: CGFloat(M_PI / 3))
            self.pointView.transform = transform
        }, completion: {(complete: Bool) in
            if complete {
               self.oppisoteDirection()
            }
        })
    }

    func oppisoteDirection()  {
        if self.stop {
            return
        }
        UIView.animate(withDuration: 0.4, animations: {
            let transform = CGAffineTransform.init(rotationAngle: CGFloat(-(M_PI / 3)))
            self.pointView.transform = transform
        }, completion: {(complete: Bool) in
            if complete {
                self.startAnimation()
            }
        })
    }
    
    func stopAnimation()  {
        UIView.animate(withDuration: 0.4, animations: {
            self.stop = true
            let transform = CGAffineTransform.init(rotationAngle: 0)
            self.pointView.transform = transform
        })
    }

二:MJRefresh集成動(dòng)畫

首先定義一個(gè)MJRefreshHeader的子類GaugeBoardRefreshHeader,在子類中重新定義不同state狀態(tài)下執(zhí)行的事件。

override func prepare() {
        super.prepare()
        mj_h = gaugeView.size.height + 30  //下拉之后視圖的高度
    }
    
    override func placeSubviews() {
        super.placeSubviews()
    
        gaugeView.center.y = 40
        gaugeView.center.x = self.center.x
        pointView.center = gaugeView.center
        
        self.addSubview(gaugeView)
        self.addSubview(pointView)
    }
    
    override var state: MJRefreshState {
        didSet {
            if state == .idle {
                self.stopAnimation()
            }
            if state == .pulling {
                self.prepareAnimation()
            }
            if state == .refreshing {
                stop = false
                self.startAnimation()
            }
        }
    }

這樣一個(gè)新的header就完成了丁逝。要定義其他各式各樣的header也都是同樣的做法汁胆。先完成要展示的動(dòng)畫內(nèi)容,然后在定義MJRefreshHeader子類的時(shí)候設(shè)置好視圖的大小霜幼,以及不同狀態(tài)(state)下執(zhí)行的動(dòng)畫就好嫩码。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市罪既,隨后出現(xiàn)的幾起案子铸题,更是在濱河造成了極大的恐慌铡恕,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,464評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件丢间,死亡現(xiàn)場(chǎng)離奇詭異探熔,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)烘挫,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,033評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門诀艰,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人饮六,你說(shuō)我怎么就攤上這事其垄。” “怎么了卤橄?”我有些...
    開封第一講書人閱讀 169,078評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵绿满,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我窟扑,道長(zhǎng)喇颁,這世上最難降的妖魔是什么什乙? 我笑而不...
    開封第一講書人閱讀 59,979評(píng)論 1 299
  • 正文 為了忘掉前任辽俗,我火速辦了婚禮,結(jié)果婚禮上谤狡,老公的妹妹穿的比我還像新娘厂抖。我一直安慰自己茎毁,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,001評(píng)論 6 398
  • 文/花漫 我一把揭開白布忱辅。 她就那樣靜靜地躺著七蜘,像睡著了一般。 火紅的嫁衣襯著肌膚如雪墙懂。 梳的紋絲不亂的頭發(fā)上橡卤,一...
    開封第一講書人閱讀 52,584評(píng)論 1 312
  • 那天,我揣著相機(jī)與錄音损搬,去河邊找鬼碧库。 笑死,一個(gè)胖子當(dāng)著我的面吹牛巧勤,可吹牛的內(nèi)容都是我干的嵌灰。 我是一名探鬼主播,決...
    沈念sama閱讀 41,085評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼颅悉,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼沽瞭!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起剩瓶,我...
    開封第一講書人閱讀 40,023評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤驹溃,失蹤者是張志新(化名)和其女友劉穎城丧,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體豌鹤,經(jīng)...
    沈念sama閱讀 46,555評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡亡哄,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,626評(píng)論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了傍药。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片磺平。...
    茶點(diǎn)故事閱讀 40,769評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖拐辽,靈堂內(nèi)的尸體忽然破棺而出拣挪,到底是詐尸還是另有隱情,我是刑警寧澤俱诸,帶...
    沈念sama閱讀 36,439評(píng)論 5 351
  • 正文 年R本政府宣布菠劝,位于F島的核電站,受9級(jí)特大地震影響睁搭,放射性物質(zhì)發(fā)生泄漏赶诊。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,115評(píng)論 3 335
  • 文/蒙蒙 一园骆、第九天 我趴在偏房一處隱蔽的房頂上張望舔痪。 院中可真熱鬧,春花似錦锌唾、人聲如沸锄码。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,601評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)滋捶。三九已至,卻和暖如春余黎,著一層夾襖步出監(jiān)牢的瞬間重窟,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,702評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工惧财, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留巡扇,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,191評(píng)論 3 378
  • 正文 我出身青樓垮衷,卻偏偏與公主長(zhǎng)得像厅翔,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子帘靡,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,781評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容