欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

iOS實(shí)現(xiàn)MJRefresh下拉刷新(上拉加載)使用詳解

 更新時間:2017年01月20日 16:53:32   作者:那一抹風(fēng)情  
本篇文章主要介紹了iOS實(shí)現(xiàn)MJRefresh下拉刷新(上拉加載)使用詳解,具有一定的參考價值,感興趣的小伙伴們可以參考一下。

下拉刷新控件目前比較火的有好幾種,本人用過MJRefresh 和 SVPullToRefresh,相對而言,前者比后者可定制化、拓展新都更高一點(diǎn)。

因此本文著重講一下MJRefresh的簡單用法。

導(dǎo)入項目:

cocoapods導(dǎo)入:pod 'MJRefresh'

手動導(dǎo)入:

  •  將MJRefresh文件夾中的所有文件拽入項目中
  • 導(dǎo)入主頭文件:#import "MJRefresh.h"

使用介紹:

廣泛性分為6種使用場景,分別對應(yīng):默認(rèn)、動畫圖片、隱藏時間、隱藏時間和狀態(tài)、自定義文字說明、以及自定義刷新控件。 

下面就各種場景分別講一下:

1、默認(rèn)場景

包含刷新菊花、下拉說明、時間

使用代碼:

#pragma mark UITableView + 下拉刷新 默認(rèn)

- (void)example01

{

  __weak __typeof(self) weakSelf = self; 

  // 設(shè)置回調(diào)(一旦進(jìn)入刷新狀態(tài)就會調(diào)用這個refreshingBlock)

  self.tableView.mj_header = [MJRefreshNormalHeader headerWithRefreshingBlock:^{

    [weakSelf loadNewData];

  }];

  // 馬上進(jìn)入刷新狀態(tài)

  [self.tableView.mj_header beginRefreshing];

} 

2、使用動畫圖片

PS:這里的動畫并不是用gif實(shí)現(xiàn)的,而是利用序列幀(即若干圖片組成一個不同狀態(tài)下的圖片數(shù)組,然后根據(jù)位置顯示不同圖片)去展現(xiàn)。

#pragma mark UITableView + 下拉刷新 動畫圖片

- (void)example02

{

  // 設(shè)置回調(diào)(一旦進(jìn)入刷新狀態(tài),就調(diào)用target的action,也就是調(diào)用self的loadNewData方法)

  self.tableView.mj_header = [MJChiBaoZiHeader headerWithRefreshingTarget:self refreshingAction:@selector(loadNewData)];

   

  // 馬上進(jìn)入刷新狀態(tài)

  [self.tableView.mj_header beginRefreshing];

} 

這里用大眾點(diǎn)評吃包子圖片為例,新建一個自定義類 MJChiBaoZiHeader,繼承:MJRefreshGifHeader

#import "MJRefreshGifHeader.h" 

@interface MJChiBaoZiHeader : MJRefreshGifHeader 

@end

然后重寫prepare方法,代碼:

- (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];

} 

關(guān)鍵點(diǎn)就是這里的兩個圖片數(shù)組,60是因為下拉控件默認(rèn)拉動距離就是60距離,這里比較嚴(yán)謹(jǐn),利用60張不同圖片去對應(yīng)每個距離點(diǎn),當(dāng)然實(shí)際中,我們可以縮減,不需要精確到每個距離點(diǎn)對應(yīng)一張圖片,這里個人自己決定。

這里需要先了解下,下拉的五種狀態(tài)。如下:

/** 刷新控件的狀態(tài) */

typedef NS_ENUM(NSInteger, MJRefreshState) {

  /** 普通閑置狀態(tài) */

  MJRefreshStateIdle = 1,

  /** 松開就可以進(jìn)行刷新的狀態(tài) */

  MJRefreshStatePulling,

  /** 正在刷新中的狀態(tài) */

  MJRefreshStateRefreshing,

  /** 即將刷新的狀態(tài) */

  MJRefreshStateWillRefresh,

  /** 所有數(shù)據(jù)加載完畢,沒有更多的數(shù)據(jù)了 */

  MJRefreshStateNoMoreData

}; 

idleImages圖片數(shù)組對應(yīng)閑置下拉狀態(tài),表示下拉到臨界值前的展示圖片。

refreshingImages圖片數(shù)組對應(yīng)正在刷新時的動畫展示圖片,一般這里需要3~5張圖片去模擬動畫。<br><br>重寫完<span class="s1">prepare方法,就可以實(shí)現(xiàn)動畫了。<br><br></span>

3、下拉刷新 隱藏時間

 

這里與默認(rèn)的區(qū)別就是不顯示上次刷新時間,使用方法:

#pragma mark UITableView + 下拉刷新 隱藏時間

- (void)example03

{

  // 設(shè)置回調(diào)(一旦進(jìn)入刷新狀態(tài),就調(diào)用target的action,也就是調(diào)用self的loadNewData方法)

  MJRefreshNormalHeader *header = [MJRefreshNormalHeader headerWithRefreshingTarget:self refreshingAction:@selector(loadNewData)];

   

  // 設(shè)置自動切換透明度(在導(dǎo)航欄下面自動隱藏)

  header.automaticallyChangeAlpha = YES;

  // 隱藏時間

  header.lastUpdatedTimeLabel.hidden = YES;
  // 馬上進(jìn)入刷新狀態(tài)

  [header beginRefreshing];
  // 設(shè)置header

  self.tableView.mj_header = header;

} 


4、下拉刷新 隱藏狀態(tài)和時間

 

這個場景一般適用于只需要動畫展示,簡潔清爽,也是用的蠻多的。

同樣,處理很簡單。

#pragma mark UITableView + 下拉刷新 隱藏狀態(tài)和時間

- (void)example04

{

  // 設(shè)置回調(diào)(一旦進(jìn)入刷新狀態(tài),就調(diào)用target的action,也就是調(diào)用self的loadNewData方法)

  MJChiBaoZiHeader *header = [MJChiBaoZiHeader headerWithRefreshingTarget:self refreshingAction:@selector(loadNewData)];

   

  // 隱藏時間

  header.lastUpdatedTimeLabel.hidden = YES;

 

  // 隱藏狀態(tài)

  header.stateLabel.hidden = YES;

   

  // 馬上進(jìn)入刷新狀態(tài)

  [header beginRefreshing];

   

  // 設(shè)置header

  self.tableView.mj_header = header;

} 

5、下拉刷新 自定義文字

想自己DIY個性文字描述,一樣很簡單。

不管是文字text、文字大小、還是顏色都一句話搞定。

#pragma mark UITableView + 下拉刷新 自定義文字

- (void)example05

{

  // 設(shè)置回調(diào)(一旦進(jìn)入刷新狀態(tài),就調(diào)用target的action,也就是調(diào)用self的loadNewData方法)

  MJRefreshNormalHeader *header = [MJRefreshNormalHeader headerWithRefreshingTarget:self refreshingAction:@selector(loadNewData)];

   

  // 設(shè)置文字

  [header setTitle:@"快扯我,快點(diǎn)" forState:MJRefreshStateIdle];

  [header setTitle:@"數(shù)據(jù)要來啦" forState:MJRefreshStatePulling];

  [header setTitle:@"服務(wù)器正在狂奔 ..." forState:MJRefreshStateRefreshing];

   

  // 設(shè)置字體

  header.stateLabel.font = [UIFont systemFontOfSize:15];

  header.lastUpdatedTimeLabel.font = [UIFont systemFontOfSize:14];

 

  // 設(shè)置顏色

  header.stateLabel.textColor = [UIColor redColor];

  header.lastUpdatedTimeLabel.textColor = [UIColor grayColor];

   

  // 馬上進(jìn)入刷新狀態(tài)

  [header beginRefreshing];

   

  // 設(shè)置刷新控件

  self.tableView.mj_header = header;

} 

6、下拉刷新 自定義刷新控件

上面的都不夠玩,怎么辦,沒關(guān)系,還有最后一種更定制化的方法:自己加控件樣式。

這里不限于任何控件,我們可以在頭部的這片區(qū)域,盡情添加Subviews,但記住一點(diǎn),高度千萬不要吵過header高度(默認(rèn)60)。

除了控件,甚至可以自己繪制動畫等等。

實(shí)現(xiàn)原理:同樣先自定義自己的類,繼承 MJRefreshHeader

重寫 prepare 方法,再重寫 placeSubviews 方法 設(shè)置位置。

代碼:

a、定義控件屬性

@interface MJDIYHeader()

@property (weak, nonatomic) UILabel *label;

@property (weak, nonatomic) UISwitch *s;

@property (weak, nonatomic) UIImageView *logo;

@property (weak, nonatomic) UIActivityIndicatorView *loading;

@end 

b、重寫prepare方法

#pragma mark 在這里做一些初始化配置(比如添加子控件)

- (void)prepare

{

  [super prepare];  

  // 設(shè)置控件的高度

  self.mj_h = 50;

   

  // 添加label

  UILabel *label = [[UILabel alloc] init];

  label.textColor = [UIColor colorWithRed:1.0 green:0.5 blue:0.0 alpha:1.0];

  label.font = [UIFont boldSystemFontOfSize:16];

  label.textAlignment = NSTextAlignmentCenter;

  [self addSubview:label];

  self.label = label;

   

  // 打醬油的開關(guān)

  UISwitch *s = [[UISwitch alloc] init];

  [self addSubview:s];

  self.s = s;

   

  // logo

  UIImageView *logo = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"Logo"]];

  logo.contentMode = UIViewContentModeScaleAspectFit;

  [self addSubview:logo];

  self.logo = logo;

   

  // loading

  UIActivityIndicatorView *loading = [[UIActivityIndicatorView alloc] initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleGray];

  [self addSubview:loading];

  self.loading = loading;

} 

c、重寫 placeSubviews

#pragma mark 在這里設(shè)置子控件的位置和尺寸

- (void)placeSubviews

{

  [super placeSubviews];

 

  self.label.frame = self.bounds;

   

  self.logo.bounds = CGRectMake(0, 0, self.bounds.size.width, 100);

  self.logo.center = CGPointMake(self.mj_w * 0.5, - self.logo.mj_h + 20);

   

  self.loading.center = CGPointMake(self.mj_w - 30, self.mj_h * 0.5);

} 

d、根據(jù)下拉位移,自定義不同位移的控件展示,比如顯示不同文字,顏色等

#pragma mark 監(jiān)聽控件的刷新狀態(tài)

- (void)setState:(MJRefreshState)state

{

  MJRefreshCheckState;

 

  switch (state) {

    case MJRefreshStateIdle:

      [self.loading stopAnimating];

      [self.s setOn:NO animated:YES];

      self.label.text = @"趕緊下拉吖(開關(guān)是打醬油滴)";

      break;

    case MJRefreshStatePulling:

      [self.loading stopAnimating];

      [self.s setOn:YES animated:YES];

      self.label.text = @"趕緊放開我吧(開關(guān)是打醬油滴)";

      break;

    case MJRefreshStateRefreshing:

      [self.s setOn:YES animated:YES];

      self.label.text = @"加載數(shù)據(jù)中(開關(guān)是打醬油滴)";

      [self.loading startAnimating];

      break;

    default:

      break;

  }

} 

上拉刷新加載其實(shí)和下拉是同理,只不過區(qū)別就是:

self.tableView.mj_header  變成 self.tableView.mj_footer,后面的類也由

MJRefreshNormalHeader 變成  MJRefreshAutoNormalFooter。

實(shí)現(xiàn)原理是相同的。

下載源碼:http://xiazai.jb51.net/201701/yuanma/MJRefresh_jb51.rar

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 如何在iOS中高效的加載圖片詳解

    如何在iOS中高效的加載圖片詳解

    這篇文章主要給大家介紹了關(guān)于如何在iOS中高效的加載圖片的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用iOS具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2021-10-10
  • iOS如何跳轉(zhuǎn)到App Store下載評分頁面示例代碼

    iOS如何跳轉(zhuǎn)到App Store下載評分頁面示例代碼

    最近在工作中遇到一個需求,需要跳轉(zhuǎn)到App Store下載評分,通過查找相關(guān)的資料最終解決了,下面這篇文章主要給大家介紹了關(guān)于iOS如何跳轉(zhuǎn)到App Store下載評分頁面的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-12-12
  • IOS實(shí)現(xiàn)簡單的進(jìn)度條功能

    IOS實(shí)現(xiàn)簡單的進(jìn)度條功能

    這篇文章主要介紹了IOS實(shí)現(xiàn)簡單的進(jìn)度條功能的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • iOS中常見的視圖和圖片處理示例詳解

    iOS中常見的視圖和圖片處理示例詳解

    在日常ios開發(fā)中經(jīng)常會遇到視圖和圖片的處理,下面這篇文章主要給大家總結(jié)介紹了關(guān)于iOS中常見的視圖和圖片處理的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)和工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下。
    2017-10-10
  • iOS開發(fā)中對于攝像頭的一些基本使用方法分享

    iOS開發(fā)中對于攝像頭的一些基本使用方法分享

    這篇文章主要介紹了iOS開發(fā)中對于攝像頭的一些基本使用方法分享,包括判斷攝像頭是否可用的方法,需要的朋友可以參考下
    2015-10-10
  • ios端ijkplayer編譯教程

    ios端ijkplayer編譯教程

    下面小編就為大家分享一篇ios端ijkplayer編譯教程,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01
  • IOS中多手勢之間的沖突和解決辦法

    IOS中多手勢之間的沖突和解決辦法

    這篇文章主要介紹了IOS中多手勢之間的沖突和解決辦法的相關(guān)資料,需要的朋友可以參考下
    2017-07-07
  • iOS App開發(fā)中Objective-C使用正則表達(dá)式進(jìn)行匹配的方法

    iOS App開發(fā)中Objective-C使用正則表達(dá)式進(jìn)行匹配的方法

    這篇文章主要介紹了iOS App開發(fā)中Objective-C使用正則表達(dá)式進(jìn)行匹配的方法,文中舉了在iOS中驗證用戶郵箱與手機(jī)號的例子,非常實(shí)用,匹配需要的朋友可以參考下
    2016-05-05
  • iOS中只讓textField使用鍵盤通知的實(shí)例代碼

    iOS中只讓textField使用鍵盤通知的實(shí)例代碼

    本文通過實(shí)例代碼給大家介紹了OS中只讓textField使用鍵盤通知的操作方法,代碼簡單易懂,非常不錯,具有參考借鑒加載,需要的的朋友參考下吧
    2017-07-07
  • iOS中日志同步獲取NSLog重定向以及其他詳解

    iOS中日志同步獲取NSLog重定向以及其他詳解

    在Objective-c開發(fā)程序的時候,有專門的日志操作類NSLog,它將指定的輸出,輸出到(stderr),我們可以利用Xcode的日志輸出窗口,下面這篇文章主要給大家介紹了關(guān)于iOS中日志同步獲取NSLog重定向以及其他的相關(guān)資料,需要的朋友可以參考下。
    2017-12-12

最新評論