靈活、可高度自定義的——Progress進度圈、彈窗、載入進度、小菊花

来源:http://www.cnblogs.com/mddblog/archive/2017/01/08/6262279.html
-Advertisement-
Play Games

DDProgressHUD的介紹 提供了四種類型的展示: 顯示無限旋轉的載入圖(比如小菊花,可以自定義),顯示文字信息。網路刷新時經常用到。 顯示載入進度的動畫,也可以顯示文字。網路下載時用的比較多,載入網頁時也可以用。 與用戶彈窗交互的彈窗,告知用戶當前操作的狀態,成功還是失敗,顯示一張圖片和文字 ...


DDProgressHUD的介紹

提供了四種類型的展示:

  • 顯示無限旋轉的載入圖(比如小菊花,可以自定義),顯示文字信息。網路刷新時經常用到。

loading圖片

  • 顯示載入進度的動畫,也可以顯示文字。網路下載時用的比較多,載入網頁時也可以用。

進度提示動畫

  • 與用戶彈窗交互的彈窗,告知用戶當前操作的狀態,成功還是失敗,顯示一張圖片和文字。圖片和文字也都可自定義

成功彈窗提示

失敗彈窗提示

自定義圖片彈窗提示

  • 可高度自定義的彈窗,將一個view顯示在遮罩上面,相當於做了一個蒙版

自定義圖片

最後旋轉的菊花,提供了一個view的擴展,將UIActivityIndicatorView小菊花顯示在調用者中間位置。

小菊花

DDProgressHUD的簡單使用與方法介紹

準備

  • 下載代碼:使用很簡單,將工程從github:https://github.com/mddios/DDProgressHUD下載下來,將DDProgressHUD文件全部拖入工程
  • 包含DDProgressHUD.h頭文件即可使用
  • 不用考慮線程的問題,主線程和非主線程均可以

工程現在下來可以看到是一個demo,點擊上面的按鈕就一目瞭然

為了方便管理與自定義,建議還是fork一份到自己的github

簡單使用與方法介紹

  • 第一類顯示提供三個類方法:無限循化的圖片
/// 只顯示圖片,一直顯示直到調用dismiss方法
+ (void)show;

/// 顯示圖片和文字,一直顯示直到調用dismiss方法
+ (void)showWithStatus:(NSString *)status;

/// 很明顯,顯示時間由duration決定,當然,中途也可以調用dismiss方法來取消顯示
+ (void)showWithStatus:(NSString *)status andDuration:(NSTimeInterval)duration;
  • 第二類顯示提供2個類方法:載入進度
/// 顯示進度,不會自動消失,需要調用dismiss方法,progress 取值範圍0~1
+ (void)showProgress:(CGFloat)progress;

/// 顯示進度,和一段描述,不會自動消失,需要調用dismiss方法
+ (void)showProgress:(CGFloat)progress withStatus:(NSString *)status;
  • 第三類顯示提供6個類方法:彈窗,顯示圖片和文字
/// 成功彈窗,只顯示圖片,
+ (void)showSuccessImage;

/// 成功狀態圖片和info
+ (void)showSuccessImageWithInfo:(NSString *)info;

/// 錯誤彈窗,只顯示圖片
+ (void)showErrorImage;

/// 錯誤狀態圖片和info
+ (void)showErrorImageWithInfo:(NSString *)info;

/// 顯示自定義圖片和文字信息,視圖大小會根據文字和圖片的大小自動調整
+ (void)showImage:(UIImage *)image andInfo:(NSString *)info;

/// 顯示自定義圖片和文字信息時間到後自動消失,視圖大小會根據文字和圖片的大小自動調整
+ (void)showImage:(UIImage *)image andInfo:(NSString *)info andDuration:(CGFloat)duration;

關於顯示時間的問題:會根據傳入的Info長短來計算一個時間,然後和最大時間、最小時間做比較,防止超過預期值,最大最小值都可以程式設置,具體參照下麵關於設置的介紹。

成功和失敗的圖片沒有提供介面來替換,如果需要顯示自定義的圖片,上面也提供了方法。

當然你也將程式預設成功和失敗的圖片自己替換掉(在bundle中),程式會根據圖片的大小來自動計算Frame,所以圖片大小也不受限制,但是圖片名字必須與預設的保持一致。

  • 第四類顯示:在maskview(相當於蒙版)上顯示view,高度自定義
+ (void)showWithView:(UIView *)view andDuration:(NSTimeInterval)duration;

隨意顯示,和上面最大的不同就是,它的frame需要使用者自己定義與計算,HUD只是提供一個蒙版,還有就是點擊蒙版後的操作(隱藏,發送通知,或者什麼也不做)

  • 最後,也算第五類吧

顯示系統的菊花到view的中間,view的擴展方法

/// 將DDProgressHUD無限迴圈動畫添加到view, @return 返回DDProgressHUD實例
- (UIActivityIndicatorView *)showActivityView;

/// 將最頂層的ActivityView從父視圖刪除,如果添加了多次則只會刪除最頂層! @return 找到並刪除成功返回YES,否則NO
- (BOOL)hiddenActivityView;

DDProgressHUD的全局設置

設置有兩種:

  • 頭文件裡面的預設設置(巨集定義),相當於初始化,全局有效。位置:DDDefaultSetup.h頭文件
  • 程式提供的類方法,會覆蓋之前的設置,全局有效。介面頭文件:DDProgressHUD.h

簡單看下視圖和對應的名稱,還有層級

  1. maskview顯示在window上
  2. DDProgressHUD(下麵簡稱hud)的backgroundView
  3. 大部分視圖處於這一層級,比如上面提到的第一類、第二類、第三類顯示的視圖都在這個層級,下麵示意圖展示的是第二類:進度
    • 3.1: 進度條的,有兩個,黑色的為foregroundRing,灰色的為backgroundRing
    • 3.2:顯示的lbl

也可以根據上面顯示類別和view的層級關係,分為以下幾種

1 maskview,蒙版的設置

首先預設設置,一共有4個

/// 遮罩預設不透明度
#define kMaskViewAlpha              0.6f
/// 遮罩預設顏色
#define kMaskViewBackgroundColorRGB 0x999999

/// 預設展示動畫時間
#define kShowAnimateDuration        0.2f
/// 預設隱藏動畫時間
#define kDismissAnimateDuration     0.2f

前兩個好理解,後面兩個是展示maskview和隱藏時的動畫時間,是對alpha做的動畫。

對應類方法設置為:(void)setMaskviewColor:(UIColor *)color,顏色和透明度,一起設置。動畫時間沒有提供。

另外還有setMaskViewAutomaticHidden:,即點擊蒙版後是否自動消失視圖,即調用dismiss方法。無論YES或者NO,點擊後都會發送一個通知static const NSNotificationName DDMaskViewDidClicked = @"DDMaskViewDidClicked";

2 白色的背景設置

頭文件預設設置

/// 圓角半徑
#define kCornerRadius               10
#define kHudColor                   0xF0F0F0
/// hud最大寬度與屏幕寬度比例
#define kMaxWidthRatioScreenWidth   (2.0/3.0)
/// hud最大高度與屏幕高度比例
#define kMaxHeightRatioScreenHeight (2.0/3.0)
/// hud最小寬高比,避免hud顯得太瘦,使用者可以通過將文本換行(\n\r)來避免太胖
#define kMinimumWidthRatioHeight    0.95

/// 圖片與文字之間的間隙(豎直方向)
#define kViewMargin                 12
/// 與父視圖間隙
#define kTopAndBottomMargin         16
/// 與父視圖間隙
#define kLeftAndRightMargin         16
  • 與屏幕的寬高比:主要是計算字元串文字信息是給的限定,防止超過限制,從而顯得不美觀
  • hud自身的寬高比:主要是避免顯得太瘦,比如文字信息很短,就會現的很瘦,而太胖的話,可以對文字信息進行換行處理
  • 還有間隙的設置:主要是針對hud的子view

類方法的設置:有的沒有提供(比如寬高比,比如視圖間隙)

/// 設置圓角,預設為10,具體參照:DDDefaultSetup.h為準
+ (void)setBackgroundViewCornerRadius:(CGFloat)radius;
/// 設置背景顏色,預設為0xF0F0F0,具體參照:DDDefaultSetup.h為準
+ (void)setBackgroundViewColor:(UIColor *)color;
/// 設置字體,預設為偏好設置字體
+ (void)setFont:(UIFont *)font;

3 彈窗、無限旋轉的圖片、進度圈的設置

共同的設置,即文字(lbl)字體:

類方法:setFont:,預設設置為跟隨偏好設置的小標題大小變化[UIFont preferredFontForTextStyle:UIFontTextStyleSubheadline]

  • 彈窗

預設:

/// 最長10秒,最短3秒
#define kDDMaxImageShowDuration     10.0f
#define kDDMinimumImageShowDuration 3.0f
/// 每個文字顯示時間
#define kEveryWordShowDuration      0.2f

類方法:

+ (void)setMaxImageShowDuration:(CGFloat)duration;
+ (void)setMinimumImageShowDuration:(CGFloat)duration;
/// 預設每個文字0.2s,具體參照:DDDefaultSetup.h為準
+ (void)setEveryWordShowDuration:(CGFloat)duration;

主要用於計算彈窗顯示時間長短

  • 無限旋轉的圖片

預設:

/// 旋轉一周所用的時間,控制旋轉的速度
#define kOneRoundDuration           1.0f

類方法:多提供了旋轉的圖片設置,可以在這裡設置,也可以直接將bundle裡面的替換,替換後全局有效

/// 自定義旋轉的圖片
+ (void)setLoopImage:(UIImage *)image;
/// 控制旋轉的速度:旋轉一圈所用的時間,預設為1s,具體參照:DDDefaultSetup.h為準
+ (void)setLoopOneRingDuration:(CGFloat)duration;
  • 進度圈

預設:

/// 進度圓環線半徑大小
#define kRingRadius                 25.0f
/// 進度圓環線寬度
#define kRingLineWidth              3.0f
/// 進度圓環顏色
#define kForegroundRingLineColorRGB 0x333333
#define kBackgroundRingLineColorRGB 0xE0E0E0

類方法:

/// 圓弧半徑,預設為25,具體參照:DDDefaultSetup.h為準
+ (void)setForegroundRingRadius:(CGFloat)radius;
+ (void)setBackgroundRingRadius:(CGFloat)radius;
/// 圓弧線寬度,預設為3,具體參照:DDDefaultSetup.h為準
+ (void)setForegroundRingLineWidth:(CGFloat)width;
+ (void)setBackgroundRingLineWidth:(CGFloat)width;
/// 圓弧線顏色,預設為0xE0E0E0 0x333333,具體參照:DDDefaultSetup.h為準
+ (void)setForegroundRingLineColor:(UIColor *)color;
+ (void)setBackgroundRingLineColor:(UIColor *)color;

github地址:https://github.com/mddios/DDProgressHUD
如果幫到了你,給顆星吧!



您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、錯誤提示 今天在開發的時候遇到一個崩潰問題,“This application is modifying the autolayout engine from a background thread, which can lead to engine corruption and weird c ...
  • 前言 最近項目集成了Tinker,開始認為集成會比較簡單,但是在實際操作的過程中還是遇到了一些問題,本文就會介紹在集成過程大家基本會遇到的主要問題。 考慮一:後臺的選取 目前後臺功能可以通過三種方式實現: 1、自己搭建後臺布丁下發系統2、第三方提供的服務,目前如原微信simsun大神的個人tinke ...
  • 無論是哪種交易軟體,對於程式員來講,最麻煩的就是去實現各種演算法。本文以SAR演算法的實現過程為例,為大家說明如何使用Warensoft Stock Service來實現高頻交易軟體的快速開發。 目前WarensoftStockService已經實現了C# 版本的客戶端驅動,可以直接在Nuget上搜索... ...
  • 以下內容為原創,歡迎轉載,轉載請註明 來自天天博客: 在Dagger 2中Activities和Subcomponents的多綁定 原文: 幾個月前,在 "MCE^3" 會議中,Gregory Kick在他的 "演講" 中展示了一個提供Subcomponents(比如,為Activity)的新概念。 ...
  •   現在很多程式都開始使用Swift開發了,但是第三方庫大多數都是用OC寫的,所以我們要使用Swift和OC混編。今天的內容主要講Swift3.0集成極光推送。 1.準備工作    "集成指南" ,極光上說的都很清楚,把創建應用和配置工程實現。 "SDK下載地 ...
  • 開發環境是OS X系統下的Xcode Xcode的兩個快捷鍵以及打開Xcode項目的正確方式 Xcode的兩個快捷鍵以及打開Xcode項目的正確方式 代碼的實時檢測和手動編譯鏈接的區別(command + B) 代碼實時檢測: 不是對代碼的編譯,是xcode的一個智能的功能,有時候不准確 手動編譯鏈 ...
  • 最近項目設計到App抓包,所以採用Fiddler工具來採集獲取APP數據包,但是fiddler對有些app是無法捕獲到數據包的,以下是我的處理方法: 1. 我預設代理埠使用的是自定義的埠而不是預設的8888埠; 2. 手機端安裝Fiddler證書,電腦端關閉防火牆 對我採集的app來說親測有效 ...
  • Your project path contains non-ASCII characters 錯誤原因:引用項目的路徑中包含中文 解決方法:重新新建一個項目,項目的路徑為英文。2:把現有的項目的路徑修改為不包含英文的。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...