iOS:一分鐘集成主流APP個人資料頁(如簡書、微博等)

個人中心示意圖

Github

倉庫地址 如果你喜歡甲锡,記得點顆??喲

前言

伴隨著APP不斷迭代更新,各種功能也是越堆越多羽戒。對于用戶來說缤沦,在個人資料頁面需要顯示的元素也越來越多。如何井然有序的展示且交互簡單易稠,變成了一個難事缸废。當(dāng)然這一點也難不倒產(chǎn)品經(jīng)理,他們總會想出各種奇淫怪術(shù)來折磨我們(程序員)驶社。下面以簡書和微博來解讀下主流APP是如何處理的企量。

簡書&微博

簡書
微博

正如上圖所示,簡書和微博的布局如出一轍亡电。一個TableHeaderView顯示背景圖届巩、頭像、簡介等基礎(chǔ)信息份乒。然后有一個SectionHeaderView恕汇,承載不同的內(nèi)容分類指引(動態(tài)腕唧、文章、更多等)瘾英,可以懸浮在頂部枣接。然后就是不同分類的數(shù)據(jù)流的TableView,可以直接滾動缺谴。建議大家打開簡書和微博但惶,把玩一下。

第一眼看上去湿蛔,感覺沒有什么難度嘛膀曾,就是一個主TableView嵌套一個ScrollView,支持左右滾動切換煌集,然后ScrollView放三個TableView妓肢。但是仔細思考會有許多難點需要解決,比如主TableView和嵌套TableView的手勢沖突苫纤,三個子TableView的位置更新等碉钠。

如果要自己解決這些問題,且要調(diào)試到目標(biāo)效果卷拘,可能要花上你大半天時間了喊废。而且本身個人資料頁面的業(yè)務(wù)邏輯就特別多,如果還要插入這種頁面交互邏輯栗弟,說實話污筷,當(dāng)你看到許多零散的代碼交織在一起時,你的頭會和足球一樣大UШ铡0曛!


足球頭

所以這篇文章不會著重講解如何解決上面的問題(可以查看源碼分析)雷厂,而是將頁面結(jié)構(gòu)封裝好惋增,你只需要花一分鐘填充你的業(yè)務(wù)邏輯即可。媽媽再也不用擔(dān)心我去調(diào)試頁面交互邏輯了??

核心原理

讓滑動手勢給每個ScrollView都可以處理改鲫,只是對于mainTableView和listView有不同的邏輯

class JXUserProfileMainTableView: UITableView, UIGestureRecognizerDelegate {
    func gestureRecognizer(_ gestureRecognizer: UIGestureRecognizer, shouldRecognizeSimultaneouslyWith otherGestureRecognizer: UIGestureRecognizer) -> Bool {
        return gestureRecognizer.isKind(of: UIPanGestureRecognizer.classForCoder()) && otherGestureRecognizer.isKind(of: UIPanGestureRecognizer.classForCoder())
    }
}
  • 對于mainTableView的滾動事件處理
func scrollViewDidScroll(_ scrollView: UIScrollView) {
        self.delegate.mainTableViewDidScroll?(scrollView)

        if (self.listItemScrollView != nil && self.listItemScrollView!.contentOffset.y > 0) {
            //mainTableView的header已經(jīng)滾動不見诈皿,開始滾動某一個listView,那么固定mainTableView的contentOffset像棘,讓其不動
            self.mainTableView.contentOffset = CGPoint(x: 0, y: self.delegate.tableHeaderViewHeight(in: self))
        }

        if (scrollView.contentOffset.y < self.delegate.tableHeaderViewHeight(in: self)) {
            //mainTableView已經(jīng)顯示了header稽亏,listView的contentOffset需要重置
            for index in 0..<self.delegate.numberOfListViews(in: self) {
                let listView = self.delegate.userProfileView(self, listViewInRow: index)
                listView.scrollView.contentOffset = CGPoint.zero
            }
        }
    }
  • 對于listView的滾動事件處理
/// 外部傳入的listView,當(dāng)其內(nèi)部的scrollView滾動時缕题,需要調(diào)用該方法
    open func listViewDidScroll(scrollView: UIScrollView) {
        self.listItemScrollView = scrollView

        if (self.mainTableView.contentOffset.y < self.delegate.tableHeaderViewHeight(in: self)) {
            //mainTableView的header還沒有消失截歉,讓listScrollView一直為0
            scrollView.contentOffset = CGPoint.zero;
            scrollView.showsVerticalScrollIndicator = false;
        } else {
            //mainTableView的header剛好消失,固定mainTableView的位置避除,顯示listScrollView的滾動條
            self.mainTableView.contentOffset = CGPoint(x: 0, y: self.delegate.tableHeaderViewHeight(in: self));
            scrollView.showsVerticalScrollIndicator = true;
        }
    }

實現(xiàn)效果

JXUserProfileViewGif.gif

使用

1.實例化JXUserProfileView

        userProfileView = JXUserProfileView(delegate: self)
        userProfileView.delegate = self
        self.view.addSubview(userProfileView)

2.實現(xiàn)JXUserProfileViewDelegate

@objc protocol JXUserProfileViewDelegate {

    ///mainTableView的滾動回調(diào)怎披,用于實現(xiàn)頭圖跟隨縮放
    @objc optional func mainTableViewDidScroll(_ scrollView: UIScrollView)

    ///tableHeaderView的高度
    func tableHeaderViewHeight(in userProfileView: JXUserProfileView) -> CGFloat

    ///返回tableHeaderView
    func tableHeaderView(in userProfileView: JXUserProfileView) -> UIView

    ///heightForHeaderOfSection胸嘁,就是分類視圖的高度
    func heightForHeaderOfSection(in userProfileView: JXUserProfileView) -> CGFloat

    ///viewForHeaderOfSection,分類視圖凉逛,我用的是自己封裝的JXCategoryView性宏,你也可以選擇其他的或者自己寫
    func viewForHeaderOfSection(in userProfileView: JXUserProfileView) -> UIView

    ///底部listView的條數(shù)
    func numberOfListViews(in userProfileView: JXUserProfileView) -> Int

    ///返回對應(yīng)index的listView,需要是UIView的子類状飞,且要遵循JXUserProfileListViewDelegate毫胜。這里要求返回一個UIView而不是一個UIScrollView,因為listView可能并不只是一個單純的TableView诬辈,還會有其他的元素
    func userProfileView(_ userProfileView: JXUserProfileView, listViewInRow row: Int) -> JXUserProfileListViewDelegate & UIView
}

3.讓外部listView遵從JXUserProfileListViewDelegate協(xié)議

//該協(xié)議主要用于mainTableView已經(jīng)顯示了header酵使,listView的contentOffset需要重置時,內(nèi)部需要訪問到外部傳入進來的listView內(nèi)的scrollView
@objc protocol JXUserProfileListViewDelegate {
    var scrollView: UIScrollView { get }
}

4.將外部listView的滾動事件傳入userProfileView

func listViewDidScroll(_ scrollView: UIScrollView) {
        userProfileView.listViewDidScroll(scrollView: scrollView)
    }

不用一分鐘焙糟,就可以集成完畢??

Github

倉庫地址 如果你喜歡口渔,記得點顆??喲

推薦閱讀

SGPagingView

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市穿撮,隨后出現(xiàn)的幾起案子缺脉,更是在濱河造成了極大的恐慌,老刑警劉巖悦穿,帶你破解...
    沈念sama閱讀 206,126評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件攻礼,死亡現(xiàn)場離奇詭異,居然都是意外死亡栗柒,警方通過查閱死者的電腦和手機礁扮,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來瞬沦,“玉大人太伊,你說我怎么就攤上這事」渥辏” “怎么了倦畅?”我有些...
    開封第一講書人閱讀 152,445評論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長绣的。 經(jīng)常有香客問我,道長欲账,這世上最難降的妖魔是什么屡江? 我笑而不...
    開封第一講書人閱讀 55,185評論 1 278
  • 正文 為了忘掉前任,我火速辦了婚禮赛不,結(jié)果婚禮上惩嘉,老公的妹妹穿的比我還像新娘。我一直安慰自己踢故,他們只是感情好文黎,可當(dāng)我...
    茶點故事閱讀 64,178評論 5 371
  • 文/花漫 我一把揭開白布惹苗。 她就那樣靜靜地躺著,像睡著了一般耸峭。 火紅的嫁衣襯著肌膚如雪桩蓉。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 48,970評論 1 284
  • 那天劳闹,我揣著相機與錄音院究,去河邊找鬼。 笑死本涕,一個胖子當(dāng)著我的面吹牛业汰,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播菩颖,決...
    沈念sama閱讀 38,276評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼样漆,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了晦闰?” 一聲冷哼從身側(cè)響起放祟,我...
    開封第一講書人閱讀 36,927評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎鹅髓,沒想到半個月后舞竿,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,400評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡窿冯,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,883評論 2 323
  • 正文 我和宋清朗相戀三年骗奖,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片醒串。...
    茶點故事閱讀 37,997評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡执桌,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出芜赌,到底是詐尸還是另有隱情仰挣,我是刑警寧澤,帶...
    沈念sama閱讀 33,646評論 4 322
  • 正文 年R本政府宣布缠沈,位于F島的核電站膘壶,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏洲愤。R本人自食惡果不足惜颓芭,卻給世界環(huán)境...
    茶點故事閱讀 39,213評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望柬赐。 院中可真熱鬧亡问,春花似錦、人聲如沸肛宋。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,204評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至床玻,卻和暖如春毁涉,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背笨枯。 一陣腳步聲響...
    開封第一講書人閱讀 31,423評論 1 260
  • 我被黑心中介騙來泰國打工薪丁, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人馅精。 一個月前我還...
    沈念sama閱讀 45,423評論 2 352
  • 正文 我出身青樓严嗜,卻偏偏與公主長得像,于是被迫代替她去往敵國和親洲敢。 傳聞我的和親對象是個殘疾皇子漫玄,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,722評論 2 345

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

  • 表姐又換工作了睦优,這是她畢業(yè)三年來換的第N份工作了。從外貿(mào)銷售到房產(chǎn)中介壮不、售樓小姐汗盘、公司客服、企業(yè)前臺….. 每份工...
    未末小七閱讀 2,015評論 2 6
  • 人生所有的問題询一, 都要靠成功來解決隐孽。 人生所有的成功,都要靠成長來解決健蕊。 人生所有的成長菱阵, 都要靠學(xué)習(xí)來解...
    京兆笑林閱讀 101評論 0 0