linux dd 进度条,Progress 进度条 – DDProgressHUD
DDProgressHUD
Progress 進(jìn)度條,UIActivityIndicatorView 小菊花,彈窗,狀態(tài)顯示,高度自定義
DDProgressHUD的介紹
提供了四種類型的展示:
顯示無限旋轉(zhuǎn)的加載圖(比如小菊花,可以自定義),顯示文字信息。網(wǎng)絡(luò)刷新時(shí)經(jīng)常用到。
顯示加載進(jìn)度的動(dòng)畫,也可以顯示文字。網(wǎng)絡(luò)下載時(shí)用的比較多,加載網(wǎng)頁時(shí)也可以用。
與用戶彈窗交互的彈窗,告知用戶當(dāng)前操作的狀態(tài),成功還是失敗,顯示一張圖片和文字。圖片和文字也都可自定義
可高度自定義的彈窗,將一個(gè)view顯示在遮罩上面,相當(dāng)于做了一個(gè)蒙版
最后旋轉(zhuǎn)的菊花,提供了一個(gè)view的擴(kuò)展,將UIActivityIndicatorView小菊花顯示在調(diào)用者中間位置。
DDProgressHUD的簡(jiǎn)單使用與方法介紹
準(zhǔn)備
下載代碼:使用很簡(jiǎn)單,將工程從github: https://github.com/mddios/DDProgressHUD 下載下來,將DDProgressHUD文件全部拖入工程
包含DDProgressHUD.h頭文件即可使用
不用考慮線程的問題,主線程和非主線程均可以
工程現(xiàn)在下來可以看到是一個(gè)demo,點(diǎn)擊上面的按鈕就一目了然
為了方便管理與自定義,建議還是fork一份到自己的github
簡(jiǎn)單使用與方法介紹
第一類顯示提供三個(gè)類方法:無限循化的圖片
/// 只顯示圖片,一直顯示直到調(diào)用dismiss方法
+ (void)show;
/// 顯示圖片和文字,一直顯示直到調(diào)用dismiss方法
+ (void)showWithStatus:(NSString *)status;
/// 很明顯,顯示時(shí)間由duration決定,當(dāng)然,中途也可以調(diào)用dismiss方法來取消顯示
+ (void)showWithStatus:(NSString *)status andDuration:(NSTimeInterval)duration;
第二類顯示提供2個(gè)類方法:加載進(jìn)度
/// 顯示進(jìn)度,不會(huì)自動(dòng)消失,需要調(diào)用dismiss方法,progress 取值范圍0~1
+ (void)showProgress:(CGFloat)progress;
/// 顯示進(jìn)度,和一段描述,不會(huì)自動(dòng)消失,需要調(diào)用dismiss方法
+ (void)showProgress:(CGFloat)progress withStatus:(NSString *)status;
第三類顯示提供6個(gè)類方法:彈窗,顯示圖片和文字
/// 成功彈窗,只顯示圖片,
+ (void)showSuccessImage;
/// 成功狀態(tài)圖片和info
+ (void)showSuccessImageWithInfo:(NSString *)info;
/// 錯(cuò)誤彈窗,只顯示圖片
+ (void)showErrorImage;
/// 錯(cuò)誤狀態(tài)圖片和info
+ (void)showErrorImageWithInfo:(NSString *)info;
/// 顯示自定義圖片和文字信息,視圖大小會(huì)根據(jù)文字和圖片的大小自動(dòng)調(diào)整
+ (void)showImage:(UIImage *)image andInfo:(NSString *)info;
/// 顯示自定義圖片和文字信息時(shí)間到后自動(dòng)消失,視圖大小會(huì)根據(jù)文字和圖片的大小自動(dòng)調(diào)整
+ (void)showImage:(UIImage *)image andInfo:(NSString *)info andDuration:(CGFloat)duration;
關(guān)于顯示時(shí)間的問題:會(huì)根據(jù)傳入的Info長(zhǎng)短來計(jì)算一個(gè)時(shí)間,然后和最大時(shí)間、最小時(shí)間做比較,防止超過預(yù)期值,最大最小值都可以程序設(shè)置,具體參照下面關(guān)于設(shè)置的介紹。
成功和失敗的圖片沒有提供接口來替換,如果需要顯示自定義的圖片,上面也提供了方法。
當(dāng)然你也將程序默認(rèn)成功和失敗的圖片自己替換掉(在bundle中),程序會(huì)根據(jù)圖片的大小來自動(dòng)計(jì)算Frame,所以圖片大小也不受限制,但是圖片名字必須與默認(rèn)的保持一致。
第四類顯示:在maskview(相當(dāng)于蒙版)上顯示view,高度自定義
+ (void)showWithView:(UIView *)view andDuration:(NSTimeInterval)duration;
隨意顯示,和上面最大的不同就是,它的frame需要使用者自己定義與計(jì)算,HUD只是提供一個(gè)蒙版,還有就是點(diǎn)擊蒙版后的操作(隱藏,發(fā)送通知,或者什么也不做)
最后,也算第五類吧
顯示系統(tǒng)的菊花到view的中間,view的擴(kuò)展方法
/// 將DDProgressHUD無限循環(huán)動(dòng)畫添加到view, @return 返回DDProgressHUD實(shí)例
- (UIActivityIndicatorView *)showActivityView;
/// 將最頂層的ActivityView從父視圖刪除,如果添加了多次則只會(huì)刪除最頂層! @return 找到并刪除成功返回YES,否則NO
- (BOOL)hiddenActivityView;
DDProgressHUD的全局設(shè)置
設(shè)置有兩種:
頭文件里面的默認(rèn)設(shè)置(宏定義),相當(dāng)于初始化,全局有效。位置:DDDefaultSetup.h頭文件
程序提供的類方法,會(huì)覆蓋之前的設(shè)置,全局有效。接口頭文件:DDProgressHUD.h
簡(jiǎn)單看下視圖和對(duì)應(yīng)的名稱,還有層級(jí)
maskview顯示在window上
DDProgressHUD(下面簡(jiǎn)稱hud)的backgroundView
大部分視圖處于這一層級(jí),比如上面提到的第一類、第二類、第三類顯示的視圖都在這個(gè)層級(jí),下面示意圖展示的是第二類:進(jìn)度
3.1: 進(jìn)度條的,有兩個(gè),黑色的為foregroundRing,灰色的為backgroundRing
3.2:顯示的lbl
也可以根據(jù)上面顯示類別和view的層級(jí)關(guān)系,分為以下幾種
1 maskview,蒙版的設(shè)置
首先默認(rèn)設(shè)置,一共有4個(gè)
/// 遮罩默認(rèn)不透明度
#define kMaskViewAlpha 0.6f
/// 遮罩默認(rèn)顏色
#define kMaskViewBackgroundColorRGB 0x999999
/// 默認(rèn)展示動(dòng)畫時(shí)間
#define kShowAnimateDuration 0.2f
/// 默認(rèn)隱藏動(dòng)畫時(shí)間
#define kDismissAnimateDuration 0.2f
前兩個(gè)好理解,后面兩個(gè)是展示maskview和隱藏時(shí)的動(dòng)畫時(shí)間,是對(duì)alpha做的動(dòng)畫。
對(duì)應(yīng)類方法設(shè)置為:(void)setMaskviewColor:(UIColor *)color,顏色和透明度,一起設(shè)置。動(dòng)畫時(shí)間沒有提供。
另外還有setMaskViewAutomaticHidden:,即點(diǎn)擊蒙版后是否自動(dòng)消失視圖,即調(diào)用dismiss方法。無論YES或者NO,點(diǎn)擊后都會(huì)發(fā)送一個(gè)通知static const NSNotificationName DDMaskViewDidClicked = @”DDMaskViewDidClicked”;
2 白色的背景設(shè)置
頭文件默認(rèn)設(shè)置
/// 圓角半徑
#define kCornerRadius 10
#define kHudColor 0xF0F0F0
/// hud最大寬度與屏幕寬度比例
#define kMaxWidthRatioScreenWidth (2.0/3.0)
/// hud最大高度與屏幕高度比例
#define kMaxHeightRatioScreenHeight (2.0/3.0)
/// hud最小寬高比,避免hud顯得太瘦,使用者可以通過將文本換行(
)來避免太胖
#define kMinimumWidthRatioHeight 0.95
/// 圖片與文字之間的間隙(豎直方向)
#define kViewMargin 12
/// 與父視圖間隙
#define kTopAndBottomMargin 16
/// 與父視圖間隙
#define kLeftAndRightMargin 16
與屏幕的寬高比:主要是計(jì)算字符串文字信息是給的限定,防止超過限制,從而顯得不美觀
hud自身的寬高比:主要是避免顯得太瘦,比如文字信息很短,就會(huì)現(xiàn)的很瘦,而太胖的話,可以對(duì)文字信息進(jìn)行換行處理
還有間隙的設(shè)置:主要是針對(duì)hud的子view
類方法的設(shè)置:有的沒有提供(比如寬高比,比如視圖間隙)
/// 設(shè)置圓角,默認(rèn)為10,具體參照:DDDefaultSetup.h為準(zhǔn)
+ (void)setBackgroundViewCornerRadius:(CGFloat)radius;
/// 設(shè)置背景顏色,默認(rèn)為0xF0F0F0,具體參照:DDDefaultSetup.h為準(zhǔn)
+ (void)setBackgroundViewColor:(UIColor *)color;
/// 設(shè)置字體,默認(rèn)為偏好設(shè)置字體
+ (void)setFont:(UIFont *)font;
3 彈窗、無限旋轉(zhuǎn)的圖片、進(jìn)度圈的設(shè)置
共同的設(shè)置,即文字(lbl)字體:
類方法:setFont:,默認(rèn)設(shè)置為跟隨偏好設(shè)置的小標(biāo)題大小變化[UIFont preferredFontForTextStyle:UIFontTextStyleSubheadline]
彈窗
默認(rèn):
/// 最長(zhǎng)10秒,最短3秒
#define kDDMaxImageShowDuration 10.0f
#define kDDMinimumImageShowDuration 3.0f
/// 每個(gè)文字顯示時(shí)間
#define kEveryWordShowDuration 0.2f
類方法:
+ (void)setMaxImageShowDuration:(CGFloat)duration;
+ (void)setMinimumImageShowDuration:(CGFloat)duration;
/// 默認(rèn)每個(gè)文字0.2s,具體參照:DDDefaultSetup.h為準(zhǔn)
+ (void)setEveryWordShowDuration:(CGFloat)duration;
主要用于計(jì)算彈窗顯示時(shí)間長(zhǎng)短
無限旋轉(zhuǎn)的圖片
默認(rèn):
/// 旋轉(zhuǎn)一周所用的時(shí)間,控制旋轉(zhuǎn)的速度
#define kOneRoundDuration 1.0f
類方法:多提供了旋轉(zhuǎn)的圖片設(shè)置,可以在這里設(shè)置,也可以直接將bundle里面的替換,替換后全局有效
/// 自定義旋轉(zhuǎn)的圖片
+ (void)setLoopImage:(UIImage *)image;
/// 控制旋轉(zhuǎn)的速度:旋轉(zhuǎn)一圈所用的時(shí)間,默認(rèn)為1s,具體參照:DDDefaultSetup.h為準(zhǔn)
+ (void)setLoopOneRingDuration:(CGFloat)duration;
進(jìn)度圈
默認(rèn):
/// 進(jìn)度圓環(huán)線半徑大小
#define kRingRadius 25.0f
/// 進(jìn)度圓環(huán)線寬度
#define kRingLineWidth 3.0f
/// 進(jìn)度圓環(huán)顏色
#define kForegroundRingLineColorRGB 0x333333
#define kBackgroundRingLineColorRGB 0xE0E0E0
類方法:
/// 圓弧半徑,默認(rèn)為25,具體參照:DDDefaultSetup.h為準(zhǔn)
+ (void)setForegroundRingRadius:(CGFloat)radius;
+ (void)setBackgroundRingRadius:(CGFloat)radius;
/// 圓弧線寬度,默認(rèn)為3,具體參照:DDDefaultSetup.h為準(zhǔn)
+ (void)setForegroundRingLineWidth:(CGFloat)width;
+ (void)setBackgroundRingLineWidth:(CGFloat)width;
/// 圓弧線顏色,默認(rèn)為0xE0E0E0 0x333333,具體參照:DDDefaultSetup.h為準(zhǔn)
+ (void)setForegroundRingLineColor:(UIColor *)color;
+ (void)setBackgroundRingLineColor:(UIColor *)color;
總結(jié)
以上是生活随笔為你收集整理的linux dd 进度条,Progress 进度条 – DDProgressHUD的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: esc指令检查打印状态_Z.115 胶
- 下一篇: linux装redis环境变量,linu