ios拓展23-自定義下拉刷新(原理)

ios開發(fā)中,刷新數(shù)據(jù)很常見.但是系統(tǒng)tableView提供的如果不符合我們的要求,那就需要自己自定義控件刷新.像MJRefresh就很有名. 這里我們可以仿照系統(tǒng)自己寫一個(gè)。

(原理效果圖)自定義一個(gè)refreshControl控件,繼承自 UIControl

1.在refreshControl中獲取將要加載到的父類視圖,強(qiáng)轉(zhuǎn)為scrollView, 一般添加到tableView上,也轉(zhuǎn)為scrollView
/**
 *  獲取將要加載到的父類視圖
 *
 *  @param newSuperview 父View
 */
-(void)willMoveToSuperview:(UIView *)newSuperview{
    //通過kvo,監(jiān)聽滾動
    if (newSuperview) {
        // 獲取View進(jìn)行強(qiáng)轉(zhuǎn), 通過kvo監(jiān)聽滾動
        self.scrollView = (UIScrollView *)newSuperview;
        // 監(jiān)聽scrollView的contentOffset
        [self.scrollView addObserver:self forKeyPath:@"contentOffset" options:NSKeyValueObservingOptionNew context:nil];
    }
    
}
2. 通過kvo,監(jiān)聽scrollView偏移量, 對其內(nèi)部進(jìn)行改變
/**
 *  監(jiān)聽方法
 */
-(void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary<NSString *,id> *)change context:(void *)context{
    [self refreshChangeState];
}
/**
 *  通過監(jiān)聽當(dāng)前scrollView的狀態(tài),來改變r(jià)efreshControl控件的狀態(tài)
 */
- (void)refreshChangeState{
    CGFloat offsetY = self.scrollView.contentOffset.y;
    // 用戶是否在拖動
    if (self.scrollView.dragging) {
        if (offsetY > -128) {//這里的數(shù)值是根據(jù)frame來的
            self.label.text = @"正常";
        }else if(offsetY <= -128){
            self.label.text = @"下拉中";
        }
    }
}
原理效果圖


具體效果圖
具體效果思路實(shí)現(xiàn):細(xì)節(jié)以及源碼(只是用來說明原理的,備注很詳細(xì))
  • 1.在監(jiān)聽滾動后,定義一個(gè)屬性,記錄其狀態(tài)
typedef NS_ENUM(NSInteger,YYRrefreshControlState) {
    Normal = 0,
    Pulling = 1,
    Rrefreshing = 2,
};

@property (nonatomic, assign) YYRrefreshControlState refreshState;
  • 2.重寫狀態(tài)的setter方法,
/**
 *  刷新狀態(tài)發(fā)生改變,進(jìn)行對應(yīng)的修改
 *
 *  @param refreshState 刷新狀態(tài)
 */
-(void)setRefreshState:(YYRrefreshControlState)refreshState{
    // 這句話千萬不能少,
    _refreshState = refreshState;
    UIEdgeInsets inset = self.scrollView.contentInset;
    
    switch (refreshState) {
        case Normal:
        {
            self.label.text = @"正常";
          
            if (self.oldState == Rrefreshing) {//======= 這里要做判斷, 不然會有bug
                [UIView animateWithDuration:0.5 animations:^{
                    self.scrollView.contentInset = UIEdgeInsetsMake(inset.top - 64, inset.left, inset.bottom, inset.right);
                } completion:^(BOOL finished) {
                    
                }];
            }
        }
            break;
        case Pulling:
            self.label.text = @"下拉中";
            break;
        case Rrefreshing:
        {
            // 告知外界刷新了,相當(dāng)于發(fā)送通知
            [self sendActionsForControlEvents:UIControlEventValueChanged];
            
            // 動畫效果
            [UIView animateWithDuration:0.5 animations:^{
                self.scrollView.contentInset = UIEdgeInsetsMake(inset.top + 64, inset.left, inset.bottom, inset.right);
                
            } completion:^(BOOL finished) {

            }];
        }
            break;
        default:
            break;
    }
    
    self.oldState = refreshState;//======用來做判斷的
    
}
  • 3.YYRrefreshControl提供一個(gè)可供外界調(diào)用的endRefreshing方法(為什么提供,仿照系統(tǒng)寫的)
.h
@interface YYRrefreshControl : UIControl
/**
 *  提供給外界調(diào)用的方法
 */
- (void)endRefreshing;
@end

.m
/**
 *  提供給外界調(diào)用的方法,  .h文件里面聲明這個(gè)方法
 */
- (void)endRefreshing{
    // 1.把狀態(tài)改為正常
    self.refreshState = Normal;
    // 2.恢復(fù)contentInset
        // 2.1在setter方法里面修改
//  -(void)setRefreshState:(YYRrefreshControlState)refreshState
}
  • 4.在外界接收通知
- (void)viewDidLoad {
    [super viewDidLoad];

    // 相當(dāng)于接收通知
    [self.refreshControl addTarget:self action:@selector(did) forControlEvents:UIControlEventValueChanged];
    
    [self.tableView addSubview:self.refreshControl];
    
}

// 接收通知監(jiān)聽的方法
- (void)did{
        [self.refreshControl endRefreshing];
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末丘跌,一起剝皮案震驚了整個(gè)濱河市夫壁,隨后出現(xiàn)的幾起案子赤炒,更是在濱河造成了極大的恐慌键闺,老刑警劉巖稻薇,帶你破解...
    沈念sama閱讀 219,188評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件惨撇,死亡現(xiàn)場離奇詭異创坞,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)凤优,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評論 3 395
  • 文/潘曉璐 我一進(jìn)店門悦陋,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人筑辨,你說我怎么就攤上這事俺驶。” “怎么了棍辕?”我有些...
    開封第一講書人閱讀 165,562評論 0 356
  • 文/不壞的土叔 我叫張陵暮现,是天一觀的道長。 經(jīng)常有香客問我楚昭,道長栖袋,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,893評論 1 295
  • 正文 為了忘掉前任哪替,我火速辦了婚禮栋荸,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘凭舶。我一直安慰自己晌块,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,917評論 6 392
  • 文/花漫 我一把揭開白布帅霜。 她就那樣靜靜地躺著匆背,像睡著了一般。 火紅的嫁衣襯著肌膚如雪身冀。 梳的紋絲不亂的頭發(fā)上钝尸,一...
    開封第一講書人閱讀 51,708評論 1 305
  • 那天,我揣著相機(jī)與錄音搂根,去河邊找鬼珍促。 笑死,一個(gè)胖子當(dāng)著我的面吹牛剩愧,可吹牛的內(nèi)容都是我干的猪叙。 我是一名探鬼主播,決...
    沈念sama閱讀 40,430評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼穴翩!你這毒婦竟也來了犬第?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,342評論 0 276
  • 序言:老撾萬榮一對情侶失蹤芒帕,失蹤者是張志新(化名)和其女友劉穎歉嗓,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體背蟆,經(jīng)...
    沈念sama閱讀 45,801評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡鉴分,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,976評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了带膀。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片冠场。...
    茶點(diǎn)故事閱讀 40,115評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖本砰,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情钢悲,我是刑警寧澤点额,帶...
    沈念sama閱讀 35,804評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站莺琳,受9級特大地震影響还棱,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜惭等,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,458評論 3 331
  • 文/蒙蒙 一珍手、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧辞做,春花似錦琳要、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至框喳,卻和暖如春课幕,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背五垮。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評論 1 272
  • 我被黑心中介騙來泰國打工乍惊, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人放仗。 一個(gè)月前我還...
    沈念sama閱讀 48,365評論 3 373
  • 正文 我出身青樓润绎,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子凡橱,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,055評論 2 355

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

  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫小作、插件、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,107評論 4 62
  • 1.感恩生物鐘準(zhǔn)時(shí)啟動稼钩,早起的感覺真好顾稀!能量滿滿滴!2.感恩今天是周日坝撑,又可以休息静秆!謝謝宇宙爸爸!3.感恩老公一大...
    O紅葉O閱讀 156評論 0 0
  • 無數(shù)次深夜難眠時(shí) 內(nèi)心總有一個(gè)聲音 我這一生 怎樣才算不枉費(fèi)? 人生的高度在哪里侨拦? 一個(gè)渾渾噩噩的人不會想 一個(gè)碌...
    寫手墨菲閱讀 169評論 0 0
  • 這是一種很好殊橙、很理想的狀態(tài),發(fā)現(xiàn)并學(xué)習(xí)身邊所有人身上的“好”狱从。 雖然通過父母膨蛮、老師、書本能隨時(shí)聽到季研、看到這些字眼敞葛,...
    鑒證成長閱讀 252評論 0 0