日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

android 自定义刷新控件,Android开发中MJRefresh自定义刷新动画效果

發布時間:2024/10/8 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 android 自定义刷新控件,Android开发中MJRefresh自定义刷新动画效果 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

有時候我們對自己開發的項目經常不滿意,但是我們要達到自定義刷新動畫的效果有一定的難度,別著急,下面愛站技術頻道和大家分享Android開發中MJRefresh自定義刷新動畫效果,一起來學習吧!

【一】常見用法

最原始的用法,耦合度低,但是不能統一管理。我們需要在每一個控制器都寫以下代碼,很繁瑣,以后項目修改起來更繁瑣,得一個控制器一個控制器的去定位、修改。

1.1 使用默認刷新(耦合度底,但是想統一修改起來特別麻煩)

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

//在這里執行刷新操作

}];

self.tableView.mj_header = [MJRefreshNormalHeader headerWithRefreshingTarget:self refreshingAction:@selector(刷新方法)];

1.2 自定義刷新(耦合度底,但是想統一修改起來特別麻煩)

//1.2.1新建一個自定義刷新

MJRefreshNormalHeader *customRef =[MJRefreshNormalHeader headerWithRefreshingBlock:^{

//1.2.2在這里執行刷新操作

}];

//1.2.3 自定義刷新狀態文字

[customRef setTitle:@"普通閑置狀態" forState:MJRefreshStateIdle];

[customRef setTitle:@"松開就可以進行刷新的狀態" forState:MJRefreshStatePulling];

[customRef setTitle:@"正在刷新中的狀態" forState:MJRefreshStateRefreshing];

[customRef setTitle:@"即將刷新的狀態" forState:MJRefreshStateWillRefresh];

[customRef setTitle:@"所有數據加載完畢,沒有更多的數據了" forState:MJRefreshStateNoMoreData];

//1.2.4添加下拉刷新

self.tableView.mj_header = customRef;

//一些其他屬性設置

/*

// 設置字體

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

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

// 設置顏色

customRef.stateLabel.textColor = [UIColor redColor];

customRef.lastUpdatedTimeLabel.textColor = [UIColor blueColor];

// 隱藏時間

customRef.lastUpdatedTimeLabel.hidden = YES;

// 隱藏狀態

customRef.stateLabel.hidden = YES;

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

customRef.automaticallyChangeAlpha = YES;

*/

【二】正確用法(統一管理項目所有下拉刷新控件)

一共有6種刷新對象(圖片末尾帶紅色的都是)。

假如我們想實現默認的下拉刷新,

【2.1】只要新建一個對象,

繼承自MJRefreshNormalHeader,

#import "MJRefreshNormalHeader.h"

@interface HSNormalHeader : MJRefreshNormalHeader

@end

【2.2】然后重寫方法- (void)prepare,重寫后記得實現[super prepare],

#import "HSNormalHeader.h"

@implementation HSNormalHeader

#pragma mark - 重寫父類的方法

- (void)prepare{

[super prepare];

//所有的自定義東西都放在這里

[self setTitle:@"普通閑置狀態" forState:MJRefreshStateIdle];

[self setTitle:@"松開就可以進行刷新的狀態" forState:MJRefreshStatePulling];

[self setTitle:@"正在刷新中的狀態" forState:MJRefreshStateRefreshing];

[self setTitle:@"即將刷新的狀態" forState:MJRefreshStateWillRefresh];

[self setTitle:@"所有數據加載完畢,沒有更多的數據了" forState:MJRefreshStateNoMoreData];

//一些其他屬性設置

/*

// 設置字體

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

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

// 設置顏色

self.stateLabel.textColor = [UIColor redColor];

self.lastUpdatedTimeLabel.textColor = [UIColor blueColor];

// 隱藏時間

self.lastUpdatedTimeLabel.hidden = YES;

// 隱藏狀態

self.stateLabel.hidden = YES;

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

self.automaticallyChangeAlpha = YES;

*/

}

//如果需要自己重新布局子控件

- (void)placeSubviews{

[super placeSubviews];

//如果需要自己重新布局子控件,請在這里設置

//箭頭

// self.arrowView.center =

}

@end

然后我們再對應的控制器實現刷新只要這樣既可:

【2.3】引入自定義對象,比如叫HSNormalHeader(繼承自MJRefreshNormalHeader),

#import "HSNormalHeader.h"

【2.4】在需要下拉刷新的控制器這樣實現既可

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

//刷新請求

}];

同理,對應的下拉動畫只需新建對象繼承自MJRefreshGifHeader

#pragma mark - 重寫父類的方法

- (void)prepare{

[super prepare];

// 設置普通狀態的動畫圖片

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

// 設置即將刷新狀態的動畫圖片(一松開就會刷新的狀態)

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

// 設置正在刷新狀態的動畫圖片

[self setImages:refreshingImages forState:MJRefreshStateRefreshing];

//隱藏時間

self.lastUpdatedTimeLabel.hidden = YES;

//隱藏狀態

self.stateLabel.hidden = YES;

}

至此,可以說MJRefresh的常用主要功能都已經被你掌握完畢,如需掌握更多請去參考MJ的地址

https://github.com/CoderMJLee/MJRefresh

本案例的demo地址為https://github.com/wolfhous/HSUpdateApp

注:里面還包含一個的自動檢測更新,大家覺得好用請加星哦!

通過愛站技術頻道小編介紹的Android開發中MJRefresh自定義刷新動畫效果,大家都了解了嗎?專業的技術人員,行業的技術精英都是通過不斷的積累才能成為技術大牛的哦。

總結

以上是生活随笔為你收集整理的android 自定义刷新控件,Android开发中MJRefresh自定义刷新动画效果的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。