ios加載狀態(tài)圖——StatusProvider分析

最近開始學(xué)習(xí)使用markdown來寫博客志鞍,所以拿了一個比較簡單的github項目做例子此洲。這個例子用于在頁面加載過程中出現(xiàn)的Loading汁汗、Error角寸、Empty等幾種情況。

整個一個項目主要是提供了一個協(xié)議#StatusProvider,用以統(tǒng)一解決在頁面加載過程出現(xiàn)的 加載中照卦、內(nèi)容為空、加載錯誤 這幾種情況的頁面提示。

這幾種狀態(tài)統(tǒng)一的使用一個枚舉類型來表示

public enum StatusProviderType {
   case Loading
   case Error(error: NSError?, retry(()-> Void)?)
   case Empty(action: (()-> Void?)
   case None
}

其中Loading 表示加載中拆撼,Error 表示加載出現(xiàn)錯誤闸度,Empty表示出現(xiàn)空內(nèi)容竭贩。retry和action作為閉包是外部傳入用以相應(yīng)內(nèi)容具體的點擊事件。

具體的使用方法 需要加載該view的頁面實現(xiàn)協(xié)議 StatusProvider筋岛,然后才能對應(yīng)的使用該協(xié)議內(nèi)部的顯示方法show() 和隱藏方法hide()娶视。

有兩種:默認情況以及自定義方案晒哄。

1.默認情況
show(statusType: StatusProvideType.Loading) //顯示LoadingView
show(statusType: StatusProvideType.Empty(action:{...})) //顯示空內(nèi)容的提示
show(statusType: StatusProvideType.Error(error:error,retry:{...})) //加載錯誤時的提示
2.自定義情況

這種情況睁宰,三種提示view都是自己根據(jù)需求進行定制的。
自己根據(jù)產(chǎn)品的具體需求構(gòu)造對應(yīng)的view就可以了寝凌。

源碼分析

整個源代碼主要分為4個文件柒傻,分別是StatusProvider.swift、 EmptyStatusView.swift 较木、ErrorStatusView.swift 红符、LoadingStatusView.swift四個文件。其中3個StatusView分別是源碼提供的默認頁面伐债。
StatusProvider.swift提供了最主要的協(xié)議以及相應(yīng)的方法预侯。
首先該文件定義了一個枚舉類型 StatusProviderType,分別定義了不同情況下對應(yīng)的類型以及view的相應(yīng)tag。

協(xié)議StatusOnViewProvider作為一個最基本的協(xié)議峰锁,針對不同的情況獲取需要加載的superView萎馅。

extension StatusOnViewProvider where Self : UIViewController{
  public var onView: UIView {
     return view
    }
  }

extension StatusOnViewProvider where Self: UITableViewController {
  public var onView: UIView {
     return view
   }
}

extension StatusOnViewProvider where Self: UIView {
  public var onView: UIView {
    return self
  }
}

其中,where起一個類型約束的作用虹蒋。確保定義的關(guān)于類型參數(shù)的需求和泛型函數(shù)或類型有關(guān)聯(lián)糜芳。

另外有兩個協(xié)議 ,用于限定empty 和error兩種情況的view。這是必須要對應(yīng)實現(xiàn)的魄衅。

public protocol EmptyStatusDisplaying: class{
  var action: (()-> Void)?     { set get }
}

public protocol ErrorStatusDisplaying: class{
 var error: NSError?    { set get }
 var retry: (() -> Void)?    { set get }
}

然后statusProvider 還有一個擴展峭竣,實現(xiàn)了協(xié)議內(nèi)的一些默認設(shè)定,在沒有選擇自定義view的情況下晃虫,提供默認配置皆撩。

 extension StatusProvider{
      public var loadingView: UIView? {  
        get{
           #if os(tvOS)
             return LoadingStatusView(loadingStyle: .Activity))
          #elseif os(iOS)
             return LoadingStatusView(loadingStyle: .LabelWithActivity)
          #else 
              return nil
         #endif
    } 
}

public var errorView: ErrorStatusDisplaying? {
    get { return ErrorStatusView() }
}   

public var emptyView: EmptyStatusDisplaying? {
    get {  return nil } }  //這里下面講
    
public func hide(statusType type: StatusProviderType){
    remove(viewTagL type.viewTag())
}

public func remove(viewTag tag:Int){
   onView.viewWithTag(tag)?.removeFromSuperview()
}

public func show(statusType type: StatusProviderType){
    StatusProviderType.allViewTags().forEach({remove(viewTag: $0)})
    var statusView: UIView? = nil
    switch type {
      case let .Error(error,retry):
        statusView = errorView as? UIView
        (statusView as? ErrorStatusDisplaying)?.error = error
        (statusView as? ErrorStatusDisplaying)?.retry = retry

     case .Loading: statusView = loadingView

     case let .Empty(action):
          statusView = emptyView as? UIView
          (statusView as? EmptyStatusDisplaying)?.action = action
     case .None: break
  }
   statusView?.tag = type.viewTag()
    addViewAndCenterConstraints(statusView) //具體view添加 詳細請看項目內(nèi)容 這里就不貼了
}

這里給出了3中情況下view的默認頁面。其中只有emptyView返回的是個view哲银,需要用戶在具體的頁面進行設(shè)定扛吞。以下給出例子:

//具體viewController 下重新定義的emptyView沮榜。
 var emptyView: EmptyStatusDisplaying?{
        return EmptyStatusView(title: "No Data", caption: "No data available.??", image:  UIImage(named: "placeholder_instagram"), actionTitle: "Create ??")
    }

這算是一種具體的實現(xiàn)形式。
hide()通過調(diào)用remove()方法將具體view 消除掉
show()方法首先將在顯示的所有狀態(tài)view清除喻粹,然后根據(jù)類型進行重新加載蟆融。

暫時先寫到這里,后續(xù)會進行補充和完善守呜。有問題可以郵件聯(lián)系我showme11211@163.com

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末型酥,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子查乒,更是在濱河造成了極大的恐慌弥喉,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,036評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件玛迄,死亡現(xiàn)場離奇詭異由境,居然都是意外死亡,警方通過查閱死者的電腦和手機蓖议,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評論 3 395
  • 文/潘曉璐 我一進店門虏杰,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人勒虾,你說我怎么就攤上這事纺阔。” “怎么了修然?”我有些...
    開封第一講書人閱讀 164,411評論 0 354
  • 文/不壞的土叔 我叫張陵笛钝,是天一觀的道長。 經(jīng)常有香客問我愕宋,道長玻靡,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,622評論 1 293
  • 正文 為了忘掉前任中贝,我火速辦了婚禮囤捻,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘雄妥。我一直安慰自己最蕾,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,661評論 6 392
  • 文/花漫 我一把揭開白布老厌。 她就那樣靜靜地躺著瘟则,像睡著了一般。 火紅的嫁衣襯著肌膚如雪枝秤。 梳的紋絲不亂的頭發(fā)上醋拧,一...
    開封第一講書人閱讀 51,521評論 1 304
  • 那天,我揣著相機與錄音,去河邊找鬼丹壕。 笑死庆械,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的菌赖。 我是一名探鬼主播缭乘,決...
    沈念sama閱讀 40,288評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼琉用!你這毒婦竟也來了堕绩?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,200評論 0 276
  • 序言:老撾萬榮一對情侶失蹤邑时,失蹤者是張志新(化名)和其女友劉穎奴紧,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體晶丘,經(jīng)...
    沈念sama閱讀 45,644評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡黍氮,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,837評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了浅浮。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片沫浆。...
    茶點故事閱讀 39,953評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖脑题,靈堂內(nèi)的尸體忽然破棺而出件缸,到底是詐尸還是另有隱情铜靶,我是刑警寧澤叔遂,帶...
    沈念sama閱讀 35,673評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站争剿,受9級特大地震影響已艰,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜蚕苇,卻給世界環(huán)境...
    茶點故事閱讀 41,281評論 3 329
  • 文/蒙蒙 一哩掺、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧涩笤,春花似錦嚼吞、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,889評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至恩沽,卻和暖如春誊稚,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,011評論 1 269
  • 我被黑心中介騙來泰國打工里伯, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留城瞎,地道東北人。 一個月前我還...
    沈念sama閱讀 48,119評論 3 370
  • 正文 我出身青樓疾瓮,卻偏偏與公主長得像脖镀,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子狼电,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,901評論 2 355

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

  • 前言 最近在讀《圖解HTTP》认然,以下理解從這本書中學(xué)到的。 一.Web基礎(chǔ)及網(wǎng)絡(luò)基礎(chǔ) 1.TCP/IP協(xié)議族 計算...
    __素顏__閱讀 1,753評論 1 7
  • [TOC] thinkphp-queue 筆記 前言 當(dāng)前筆記中的內(nèi)容針對的是 thinkphp-queue 的 ...
    Arvin7閱讀 2,427評論 0 3
  • 微信模式識別中心 lr 損失函數(shù)漫萄,梯度下降求導(dǎo)rf與gbdt的區(qū)別dbscan譜聚類n-gram模型公式(還讓寫沒...
    貳拾貳畫生閱讀 257評論 0 0
  • 只要一想起遠方的你 每一片云朵都在下雨 雨點打濕干涸的眼角 你的微笑旖旎 讓轟鳴的雷聲沉寂 沒有人會在雨天撐傘 夢...
    言射手閱讀 211評論 0 4