Android開發(fā)中MJRefresh自定義刷新動畫效果
【一】常見用法
最原始的用法,耦合度低,但是不能統(tǒng)一管理。我們需要在每一個控制器都寫以下代碼,很繁瑣,以后項目修改起來更繁瑣,得一個控制器一個控制器的去定位、修改。
1.1 使用默認(rèn)刷新(耦合度底,但是想統(tǒng)一修改起來特別麻煩)
self.tableView.mj_header = [MJRefreshNormalHeader headerWithRefreshingBlock:^{ //在這里執(zhí)行刷新操作 }]; self.tableView.mj_header = [MJRefreshNormalHeader headerWithRefreshingTarget:self refreshingAction:@selector(刷新方法)];
1.2 自定義刷新(耦合度底,但是想統(tǒng)一修改起來特別麻煩)
//1.2.1新建一個自定義刷新 MJRefreshNormalHeader *customRef =[MJRefreshNormalHeader headerWithRefreshingBlock:^{ //1.2.2在這里執(zhí)行刷新操作 }]; //1.2.3 自定義刷新狀態(tài)文字 [customRef setTitle:@"普通閑置狀態(tài)" forState:MJRefreshStateIdle]; [customRef setTitle:@"松開就可以進(jìn)行刷新的狀態(tài)" forState:MJRefreshStatePulling]; [customRef setTitle:@"正在刷新中的狀態(tài)" forState:MJRefreshStateRefreshing]; [customRef setTitle:@"即將刷新的狀態(tài)" forState:MJRefreshStateWillRefresh]; [customRef setTitle:@"所有數(shù)據(jù)加載完畢,沒有更多的數(shù)據(jù)了" forState:MJRefreshStateNoMoreData]; //1.2.4添加下拉刷新 self.tableView.mj_header = customRef; //一些其他屬性設(shè)置 /* // 設(shè)置字體 customRef.stateLabel.font = [UIFont systemFontOfSize:15]; customRef.lastUpdatedTimeLabel.font = [UIFont systemFontOfSize:14]; // 設(shè)置顏色 customRef.stateLabel.textColor = [UIColor redColor]; customRef.lastUpdatedTimeLabel.textColor = [UIColor blueColor]; // 隱藏時間 customRef.lastUpdatedTimeLabel.hidden = YES; // 隱藏狀態(tài) customRef.stateLabel.hidden = YES; // 設(shè)置自動切換透明度(在導(dǎo)航欄下面自動隱藏) customRef.automaticallyChangeAlpha = YES; */
【二】正確用法(統(tǒng)一管理項目所有下拉刷新控件)
一共有6種刷新對象(圖片末尾帶紅色的都是)。
假如我們想實現(xiàn)默認(rèn)的下拉刷新,
【2.1】只要新建一個對象,
繼承自MJRefreshNormalHeader,
#import "MJRefreshNormalHeader.h" @interface HSNormalHeader : MJRefreshNormalHeader @end
【2.2】然后重寫方法- (void)prepare,重寫后記得實現(xiàn)[super prepare],
#import "HSNormalHeader.h" @implementation HSNormalHeader #pragma mark - 重寫父類的方法 - (void)prepare{ [super prepare]; //所有的自定義東西都放在這里 [self setTitle:@"普通閑置狀態(tài)" forState:MJRefreshStateIdle]; [self setTitle:@"松開就可以進(jìn)行刷新的狀態(tài)" forState:MJRefreshStatePulling]; [self setTitle:@"正在刷新中的狀態(tài)" forState:MJRefreshStateRefreshing]; [self setTitle:@"即將刷新的狀態(tài)" forState:MJRefreshStateWillRefresh]; [self setTitle:@"所有數(shù)據(jù)加載完畢,沒有更多的數(shù)據(jù)了" forState:MJRefreshStateNoMoreData]; //一些其他屬性設(shè)置 /* // 設(shè)置字體 self.stateLabel.font = [UIFont systemFontOfSize:15]; self.lastUpdatedTimeLabel.font = [UIFont systemFontOfSize:14]; // 設(shè)置顏色 self.stateLabel.textColor = [UIColor redColor]; self.lastUpdatedTimeLabel.textColor = [UIColor blueColor]; // 隱藏時間 self.lastUpdatedTimeLabel.hidden = YES; // 隱藏狀態(tài) self.stateLabel.hidden = YES; // 設(shè)置自動切換透明度(在導(dǎo)航欄下面自動隱藏) self.automaticallyChangeAlpha = YES; */ } //如果需要自己重新布局子控件 - (void)placeSubviews{ [super placeSubviews]; //如果需要自己重新布局子控件,請在這里設(shè)置 //箭頭 // self.arrowView.center = } @end
然后我們再對應(yīng)的控制器實現(xiàn)刷新只要這樣既可:
【2.3】引入自定義對象,比如叫HSNormalHeader(繼承自MJRefreshNormalHeader),
#import "HSNormalHeader.h"
【2.4】在需要下拉刷新的控制器這樣實現(xiàn)既可
self.tableView.mj_header = [HSNormalHeader headerWithRefreshingBlock:^{ //刷新請求 }];
同理,對應(yīng)的下拉動畫只需新建對象繼承自MJRefreshGifHeader
#pragma mark - 重寫父類的方法 - (void)prepare{ [super prepare]; // 設(shè)置普通狀態(tài)的動畫圖片 NSMutableArray *idleImages = [NSMutableArray array]; for (NSUInteger i = 1; i<=60; i++) { UIImage *image = [UIImage imageNamed:[NSString stringWithFormat:@"dropdown_anim__000%zd", i]]; [idleImages addObject:image]; } [self setImages:idleImages forState:MJRefreshStateIdle]; // 設(shè)置即將刷新狀態(tài)的動畫圖片(一松開就會刷新的狀態(tài)) NSMutableArray *refreshingImages = [NSMutableArray array]; for (NSUInteger i = 1; i<=3; i++) { UIImage *image = [UIImage imageNamed:[NSString stringWithFormat:@"dropdown_loading_0%zd", i]]; [refreshingImages addObject:image]; } [self setImages:refreshingImages forState:MJRefreshStatePulling]; // 設(shè)置正在刷新狀態(tài)的動畫圖片 [self setImages:refreshingImages forState:MJRefreshStateRefreshing]; //隱藏時間 self.lastUpdatedTimeLabel.hidden = YES; //隱藏狀態(tài) self.stateLabel.hidden = YES; }
至此,可以說MJRefresh的常用主要功能都已經(jīng)被你掌握完畢,如需掌握更多請去參考MJ的地址
https://github.com/CoderMJLee/MJRefresh
本案例的demo地址為https://github.com/wolfhous/HSUpdateApp
注:里面還包含一個的自動檢測更新,大家覺得好用請加星哦!
以上所述是小編給大家介紹的Android開發(fā)中MJRefresh自定義刷新動畫效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Android中創(chuàng)建對話框(確定取消對話框、單選對話框、多選對話框)實例代碼
這篇文章主要介紹了詳解Android中創(chuàng)建對話框(確定取消對話框、單選對話框、多選對話框)的相關(guān)資料,需要的朋友可以參考下2016-04-04Android編程視頻播放API之MediaPlayer用法示例
這篇文章主要介紹了Android編程視頻播放API之MediaPlayer用法,結(jié)合實例形式分析了基于Android API實現(xiàn)視頻播放功能的多媒體文件讀取、判斷、事件響應(yīng)及流媒體播放等相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2017-08-08Android項目類似淘寶 電商 搜索功能,監(jiān)聽軟鍵盤搜索事件,延遲自動搜索,以及時間排序的搜索歷史記錄的實現(xiàn)
本篇文章主要介紹了Android實現(xiàn)類似淘寶、電商、搜索功能(監(jiān)聽軟鍵盤搜索事件,延遲自動搜索,以及時間排序的搜索歷史記錄),感興趣的小伙伴們可以參考一下。2016-10-10Android 數(shù)據(jù)庫SQLite 寫入SD卡的方法
如果手機(jī)沒有root,數(shù)據(jù)庫文件是無法查看到的,不方便調(diào)試。最好的辦法是把數(shù)據(jù)庫寫進(jìn)SD卡。通過本文給大家介紹Android 數(shù)據(jù)庫SQLite 寫入SD卡的方法,需要的朋友參考下吧2016-04-04如何設(shè)置Android studio 3.0顯示光標(biāo)返回上一次瀏覽位置的箭頭圖標(biāo)
這篇文章主要介紹了如何設(shè)置Android studio 3.0顯示光標(biāo)返回上一次瀏覽位置的箭頭圖標(biāo) 很多朋友反映剛升級了Android studio 3.0,發(fā)現(xiàn)光標(biāo)返回上一次瀏覽位置的箭頭圖標(biāo)沒有了,下文給大家介紹的非常詳細(xì),需要的朋友可以參考下2017-11-11Flutter開發(fā)之對角棋游戲?qū)崿F(xiàn)實例詳解
這篇文章主要為大家介紹了Flutter開發(fā)之對角棋游戲?qū)崿F(xiàn)實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11