印象筆記交互效果的實現(xiàn)

啰嗦幾句

起初我是想把這個demo做的和原版一摸一樣钓猬,但在印象筆記的ipa中并沒有找到那些關(guān)鍵的圖片吹零,網(wǎng)上也沒有相關(guān)的素材屑迂,而且當(dāng)我在百度搜索里面赫然敲下印象筆記四個大字的時候拇颅,百度搜索竟然給我推薦印象筆記面臨倒閉這樣的關(guān)鍵字荧恍!好吧镰烧,在當(dāng)下新技術(shù)大潮一波接一波的年代拢军,這種被面臨倒閉的公司還有很多,但我個人感情上希望那一天能來的晚一些拌滋,反倒是些世界500強(qiáng),民族企業(yè)之類的朴沿,我由衷的希望他明天就關(guān)門。我也斗膽嘗試過用sketch畫出所有的切圖败砂,但當(dāng)我畫完一個?后就徹底放棄了這個想法赌渣,索性也就弄成現(xiàn)在這個樣子。

不夸張的說我半路轉(zhuǎn)來做ios和印象筆記這兩個交互效果是有很大關(guān)系的昌犹,在沒有作出這個demo之前坚芜,我對evernote的這兩個交互效果特別的著迷,而在我轉(zhuǎn)做ios之后斜姥,這種感覺反而更加強(qiáng)烈了鸿竖,因為憑我當(dāng)時那點淺薄的ios經(jīng)驗,完全不知道這個效果是怎么做到的铸敏,我也像瘋子一樣在各種code網(wǎng)站瘋狂掃蕩一遍也沒有找到相應(yīng)的demo缚忧,趁著這段時間比較閑就把它實現(xiàn)了。

彈簧效果:
彈簧.gif

使用collectionView杈笔,自定義布局繼承UICollectionViewFlowLayout闪水,想要這些cell按照我們的意思動起來,首先重寫shouldInvalidateLayoutFor
BoundsChange
返回true蒙具。

 override func shouldInvalidateLayoutForBoundsChange(newBounds: CGRect) -> Bool {
        return true
 }

這個動畫只在collectionview滑動到頂部和底部會觸發(fā)球榆,重寫layoutAttributesForElementsInRect這個方法根據(jù)collectionviewcontentoffset計算出cellframe,這樣就ok了禁筏。

override func layoutAttributesForElementsInRect(rect: CGRect) -> [UICollectionViewLayoutAttributes]? {
        let offsetY = self.collectionView!.contentOffset.y
        let attrsArray = super.layoutAttributesForElementsInRect(rect)
        let collectionViewFrameHeight = self.collectionView!.frame.size.height;
        let collectionViewContentHeight = self.collectionView!.contentSize.height;
        let ScrollViewContentInsetBottom = self.collectionView!.contentInset.bottom;
        let bottomOffset = offsetY + collectionViewFrameHeight - collectionViewContentHeight - ScrollViewContentInsetBottom
        let numOfItems = self.collectionView!.numberOfSections()
        
        for attr:UICollectionViewLayoutAttributes in attrsArray! {
            if (attr.representedElementCategory == UICollectionElementCategory.Cell) {
                var cellRect = attr.frame;
                if offsetY <= 0 {
                    let distance = fabs(offsetY) / SpringFactor;
                    cellRect.origin.y += offsetY + distance * CGFloat(attr.indexPath.section + 1);
                }else if bottomOffset > 0 {
                    let distance = bottomOffset / SpringFactor;
                    cellRect.origin.y += bottomOffset - distance *
                        CGFloat(numOfItems - attr.indexPath.section)
                }
                attr.frame = cellRect;
            }
        }
        return attrsArray;
 }
轉(zhuǎn)場效果:
轉(zhuǎn)場效果.gif

自定義類EvernoteTransition遵守UIViewControllerAnimated TransitioningUIViewControllerTransitioningDelegate持钉,
該類的對象作為transitioningDelegate。實現(xiàn)
UIViewControllerAnimatedTransitioning
transitionDurationanimateTransition方法前者返回動畫的時間篱昔,后者用來實現(xiàn)轉(zhuǎn)場時的具體動畫每强。
UIViewControllerTransitioningDelegatepresentdismiss代理方法中返回EvernoteTransition對象,這樣就ok了

func animationControllerForPresentedController(presented: UIViewController, presentingController presenting: UIViewController, sourceController source: UIViewController) -> UIViewControllerAnimatedTransitioning? {
        self.isPresent = true
        return self
}
    
func animationControllerForDismissedController(dismissed: UIViewController) -> UIViewControllerAnimatedTransitioning? {
        self.isPresent = false
        return self
}
手勢互動:

手勢互動.gif

實現(xiàn)UIViewControllerTransitioningDelegate
interactionControllerForDismissal

func interactionControllerForDismissal(animator: UIViewControllerAnimatedTransitioning) -> UIViewControllerInteractiveTransitioning? {
        self.isPresent = false
        return interactionController
}

給第二個controller加上一個UIScreenEdgePanGestureRecognizer手勢方向為left,實時的更新interactionController空执,這樣就ok了.

func handlePanGesture(recognizer:UIScreenEdgePanGestureRecognizer) {
        let view = panViewController.view
        if recognizer.state == UIGestureRecognizerState.Began {
            panViewController.dismissViewControllerAnimated(true, completion: { () -> Void in
            })
        } else if recognizer.state == UIGestureRecognizerState.Changed {
            let translation = recognizer.translationInView(view)
            let d = fabs(translation.x / CGRectGetWidth(view.bounds))
            interactionController.updateInteractiveTransition(d)
        } else if recognizer.state == UIGestureRecognizerState.Ended {
            if recognizer.velocityInView(view).x > 0 {
                interactionController.finishInteractiveTransition()
            } else {
                interactionController.cancelInteractiveTransition()
                listViewController.presentViewController(panViewController, animated: false, completion: { () -> Void in
                    
                })
            }
            interactionController = UIPercentDrivenInteractiveTransition()
        }
}
具體源碼:

** GitHub**
** Bitbucket**

注:在我自認(rèn)為沒有任何商業(yè)意圖的前提下窘茁,從dribbble上面搬來了第一張GIF,如果這篇文章有幸被原制作者看到并且認(rèn)為我這種做法給他帶來了困擾脆烟,我便立即刪除,最后送大家一首克羅地亞狂想曲房待。

如果您發(fā)現(xiàn)文中有任何不妥之處邢羔,還望不吝賜教!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末桑孩,一起剝皮案震驚了整個濱河市拜鹤,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌流椒,老刑警劉巖敏簿,帶你破解...
    沈念sama閱讀 217,406評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異宣虾,居然都是意外死亡惯裕,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評論 3 393
  • 文/潘曉璐 我一進(jìn)店門绣硝,熙熙樓的掌柜王于貴愁眉苦臉地迎上來蜻势,“玉大人,你說我怎么就攤上這事鹉胖∥章辏” “怎么了?”我有些...
    開封第一講書人閱讀 163,711評論 0 353
  • 文/不壞的土叔 我叫張陵甫菠,是天一觀的道長挠铲。 經(jīng)常有香客問我,道長寂诱,這世上最難降的妖魔是什么拂苹? 我笑而不...
    開封第一講書人閱讀 58,380評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮刹衫,結(jié)果婚禮上醋寝,老公的妹妹穿的比我還像新娘。我一直安慰自己带迟,他們只是感情好音羞,可當(dāng)我...
    茶點故事閱讀 67,432評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著仓犬,像睡著了一般嗅绰。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,301評論 1 301
  • 那天窘面,我揣著相機(jī)與錄音翠语,去河邊找鬼。 笑死财边,一個胖子當(dāng)著我的面吹牛肌括,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播酣难,決...
    沈念sama閱讀 40,145評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼谍夭,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了憨募?” 一聲冷哼從身側(cè)響起紧索,我...
    開封第一講書人閱讀 39,008評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎菜谣,沒想到半個月后珠漂,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,443評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡尾膊,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,649評論 3 334
  • 正文 我和宋清朗相戀三年媳危,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片眯停。...
    茶點故事閱讀 39,795評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡济舆,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出莺债,到底是詐尸還是另有隱情滋觉,我是刑警寧澤,帶...
    沈念sama閱讀 35,501評論 5 345
  • 正文 年R本政府宣布齐邦,位于F島的核電站椎侠,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏措拇。R本人自食惡果不足惜我纪,卻給世界環(huán)境...
    茶點故事閱讀 41,119評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望丐吓。 院中可真熱鬧浅悉,春花似錦、人聲如沸券犁。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽粘衬。三九已至荞估,卻和暖如春咳促,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背勘伺。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評論 1 269
  • 我被黑心中介騙來泰國打工跪腹, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人飞醉。 一個月前我還...
    沈念sama閱讀 47,899評論 2 370
  • 正文 我出身青樓冲茸,卻偏偏與公主長得像,于是被迫代替她去往敵國和親缅帘。 傳聞我的和親對象是個殘疾皇子噪裕,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,724評論 2 354

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