zoukankan      html  css  js  c++  java
  • ios实现下拉刷新,上拉加载

    1、自定义cell

    //#import "EnjoyListModel.h"

    @protocol EnjoyCollectionCellOfViewDelegate <NSObject>

    - (void)freeButtonDelegateAction:(UIButton *)sender;

    @end

     @interface EnjoyCollectionCellOfView : UICollectionViewCell

     @property (nonatomic,strong)id<EnjoyCollectionCellOfViewDelegate>delegate;

    /*免费拿按钮*/

    @property (nonatomic,strong)UIButton *freeButton; 

    //- (void)updateEnjoyCollectionCellOfViewModel:(EnjoyListModel *)model;

    @end

    .m文件实现

    #import "EnjoyCollectionCellOfView.h"

    #import "Masonry.h"

    //#import "UIImageView+WebCache.h"

    #define EnjoyCollectionViewLeftMargin 0

    #define EnjoyCollectionViewTopMargin  0

    @interface EnjoyCollectionCellOfView ()

    /*商品图片*/

    @property (nonatomic,strong)UIImageView *goodsImageView;

    /*商品名称*/

    @property (nonatomic,strong)UILabel *goodsTitleLabel;

    /*收益和名称*/

    @property (nonatomic,strong)UILabel *goodsLastLabel;

    @end

    @implementation EnjoyCollectionCellOfView

    - (instancetype)initWithFrame:(CGRect)frame

    {

        self = [super initWithFrame:frame];

        if (self)

        {

            self.backgroundColor = [UIColor whiteColor];

         __weak __typeof(&*self)weakSelf = self;

            

            [self.contentView addSubview:self.goodsImageView];

            [self.goodsImageView mas_makeConstraints:^(MASConstraintMaker *make)

             {

                 make.left.mas_equalTo(weakSelf.mas_left).offset(EnjoyCollectionViewLeftMargin);

                 make.top.mas_equalTo(weakSelf.mas_top).offset(EnjoyCollectionViewTopMargin);

                 make.width.mas_equalTo(weakSelf.contentView.mas_width).offset(0);

                 make.height.mas_equalTo(weakSelf.contentView.mas_width).offset(0);

            }];

            

            [self.contentView addSubview:self.goodsTitleLabel];

            [self.goodsTitleLabel mas_makeConstraints:^(MASConstraintMaker *make)

            {

                make.left.mas_equalTo(weakSelf.mas_left).offset(EnjoyCollectionViewLeftMargin);

                make.right.mas_equalTo(weakSelf.mas_right).offset(-EnjoyCollectionViewLeftMargin);

                make.top.mas_equalTo(weakSelf.goodsImageView.mas_bottom).offset(0);

                make.height.mas_offset(20);

                

            }];

            

            [self.contentView addSubview:self.goodsLastLabel];

            [self.goodsLastLabel mas_makeConstraints:^(MASConstraintMaker *make)

            {

                make.left.mas_equalTo(weakSelf.mas_left).offset(EnjoyCollectionViewLeftMargin);

                make.right.mas_equalTo(weakSelf.mas_right).offset(-EnjoyCollectionViewLeftMargin);

                make.top.mas_equalTo(weakSelf.goodsTitleLabel.mas_bottom).offset(0);

                make.height.mas_offset(20);

            }];

            

            [self.contentView addSubview:self.freeButton];

            [self.freeButton mas_makeConstraints:^(MASConstraintMaker *make)

             {

            

                 make.left.mas_equalTo(weakSelf.mas_left).offset(35);

                 make.right.mas_equalTo(weakSelf.mas_right).offset(-35);

                 make.bottom.mas_equalTo(weakSelf.contentView.mas_bottom).offset(-10);

                 make.height.mas_offset(30);

            }];

            

            [self.freeButton addTarget:self action:@selector(freeButtonAction:) forControlEvents:UIControlEventTouchUpInside];

            

        }

        return self;

    }

    #pragma mark - buttonAction

    - (void)freeButtonAction:(UIButton *)sender

    {

        if ([self.delegate respondsToSelector:@selector(freeButtonDelegateAction:)])

        {

            

            [self.delegate freeButtonDelegateAction:sender];

        }

        

        

    }

    #pragma mark - updateUI

    #pragma mark -- lazy

    - (UIImageView *)goodsImageView

    {

        if (!_goodsImageView)

        {

            _goodsImageView = [[UIImageView alloc]init];

            _goodsImageView.backgroundColor = [UIColor redColor];

            

        }

        return _goodsImageView;

    }

    - (UILabel *)goodsTitleLabel

    {

        if (!_goodsTitleLabel) {

            _goodsTitleLabel = [[UILabel alloc]init];

            _goodsTitleLabel.text = @"商品名称";

    //        _goodsTitleLabel.backgroundColor = [UIColor lightGrayColor];

            _goodsTitleLabel.textAlignment = NSTextAlignmentCenter;

            _goodsTitleLabel.font = [UIFont systemFontOfSize:12];

        }

        return _goodsTitleLabel;

    }

    - (UILabel *)goodsLastLabel

    {

        if (!_goodsLastLabel) {

            _goodsLastLabel = [[UILabel alloc]init];

            _goodsLastLabel.text = @"商品名称";

    //        _goodsLastLabel.backgroundColor = [UIColor yellowColor];

            _goodsLastLabel.textAlignment = NSTextAlignmentCenter;

            _goodsLastLabel.font = [UIFont systemFontOfSize:12];

        }

        return _goodsLastLabel;

    }

    - (UIButton *)freeButton

    {

        if (!_freeButton)

        {

            _freeButton = [UIButton buttonWithType:UIButtonTypeCustom];

            [_freeButton setTitle:@"随手拿" forState:UIControlStateNormal];

    //        [_freeButton setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];

            [_freeButton setBackgroundColor:[UIColor redColor]];

            _freeButton.layer.masksToBounds = YES;

            _freeButton.layer.cornerRadius = 5;

            

        }

        return _freeButton;

    }

    @end

    其中

    EnjoyWaterFlowLayout与我上篇是一样的,可以前去观看

    然后我的collectionView是放在一个view中的,不是放在VC中的

    #import <UIKit/UIKit.h>

    @protocol ZoneOfEnjoyViewDelegate  <NSObject>

    //- (void)freeBtnGotoBuyView:(UIButton *)sender withListModel:(EnjoyListModel *)listModel;

    @end

    @interface ZoneOfEnjoyView : UIView

    @property (nonatomic,assign)id<ZoneOfEnjoyViewDelegate>delegate;

    @property (nonatomic,strong)UICollectionView *collectionView;

    /*注释*/

    @property (nonatomic,strong)NSMutableArray *goodsMuArray;

    @end

    .m文件实现

    #define kMainScreenWidth    [[UIScreen mainScreen] applicationFrame].size.width

    #define kMainScreenHeight   [[UIScreen mainScreen] applicationFrame].size.height

    #define kDeviceWidth        [UIScreen mainScreen].bounds.size.width      // 界面宽度

    #define kDeviceHeight       [UIScreen mainScreen].bounds.size.height     // 界面高度

    #define kStatusBarHeight    [[UIApplication sharedApplication] statusBarFrame].size.height

    #define kHeight             (kDeviceHeight - kStatusBarHeight - kNavigationBarHeight)   // 高度

    #define kTabBarHeight       49.0

    #import "ZoneOfEnjoyView.h"

    //#import "EnjoyBannerView.h"

    #import "EnjoyCollectionCellOfView.h"

    #import "EnjoyWaterFlowLayout.h"

    @interface ZoneOfEnjoyView ()<UICollectionViewDelegate,UICollectionViewDataSource,WaterFlowLayoutDelegate,EnjoyCollectionCellOfViewDelegate>

    {

        

    }

    //@property (nonatomic,strong)EnjoyBannerView *bannerView;

    /*注释*/

    //@property (nonatomic,strong)NSMutableArray *goodsMuArray;

    @end

    static NSString *const CellIdentifier = @"EnjoyCollectionCellOfViewCell";

    @implementation ZoneOfEnjoyView

    - (instancetype)initWithFrame:(CGRect)frame

    {

        self = [super initWithFrame:frame];

        if (self)

        {

            EnjoyWaterFlowLayout *layout = [[EnjoyWaterFlowLayout alloc]init];

            layout.delegate = self;

             self.collectionView = [[UICollectionView alloc]initWithFrame:CGRectMake(0, 0, kDeviceWidth, kDeviceHeight  - 10 - kTabBarHeight - 44 ) collectionViewLayout:layout];

            self.collectionView.backgroundColor = [UIColor whiteColor];

            _collectionView.dataSource = self;

            _collectionView.delegate = self;

           

            [self addSubview:self.collectionView];

            [self.collectionView registerClass:[EnjoyCollectionCellOfView class] forCellWithReuseIdentifier:CellIdentifier];

            

    //        if (!self.goodsMuArray)

    //        {

    //            self.goodsMuArray = [NSMutableArray array];

    //        }

            

        }

        return self;

    }

    - (void)setGoodsMuArray:(NSMutableArray *)goodsMuArray

    {

        _goodsMuArray = goodsMuArray;

        

        if (_goodsMuArray.count)

        {

            [self.goodsMuArray addObjectsFromArray:goodsMuArray];

            [self.collectionView reloadData];

        }

        else

        {

            return;

        }

        

    }

    #pragma mark -- UICollectionViewDataSource

    #pragma mark - collection数据源代理

    - (NSInteger)collectionView:(UICollectionView *)collectionView numberOfItemsInSection:(NSInteger)section

    {

        if (self.goodsMuArray.count)

        {

            return self.goodsMuArray.count;

        }

        else

        {

            return 0;

        }

    }

    - ( UICollectionViewCell *)collectionView:(UICollectionView *)collectionView cellForItemAtIndexPath:(NSIndexPath *)indexPath

    {

    //    EnjoyListModel *model = [[EnjoyListModel alloc]init];

        

        

        EnjoyCollectionCellOfView *cell = (EnjoyCollectionCellOfView *)[collectionView dequeueReusableCellWithReuseIdentifier:CellIdentifier forIndexPath:indexPath];

        cell.freeButton.tag = indexPath.row;

        cell.delegate = self;

        

        if (self.goodsMuArray.count)

        {

    //        model = self.goodsMuArray[indexPath.row];

    //        [cell updateEnjoyCollectionCellOfViewModel:model];

        }

        else

        {

        }

        

        return cell;

    }

    - (CGFloat)WaterFlowLayout:(EnjoyWaterFlowLayout *)WaterFlowLayout heightForRowAtIndexPath:(NSInteger )index itemWidth:(CGFloat)itemWidth

    {

        return (kDeviceWidth)/2 + 75;

        

    }

    @end

    最后在VC中实现

    #import "ViewController.h"

    #import "ZoneOfEnjoyView.h"

    #import "MJRefresh.h"

    #define kDeviceWidth        [UIScreen mainScreen].bounds.size.width      // 界面宽度

    #define kDeviceHeight       [UIScreen mainScreen].bounds.size.height     // 界面高度

    @interface ViewController ()

    /*注释*/

    @property (nonatomic,strong)ZoneOfEnjoyView *enjoyView;

    /**

     *  存放假数据

     */

    @property (strong, nonatomic) NSMutableArray *fakeColors;

    @end

    @implementation ViewController

    - (void)viewDidLoad {

        [super viewDidLoad];

        

        self.enjoyView = [[ZoneOfEnjoyView alloc]initWithFrame:CGRectMake(0, 0, kDeviceWidth, kDeviceHeight - 45)];

        [self.view addSubview:self.enjoyView];

        

        if (!self.fakeColors) {

            self.fakeColors = [NSMutableArray array];

        }

        

        self.enjoyView.goodsMuArray = [NSMutableArray array];

        // Do any additional setup after loading the view, typically from a nib.

    }

    - (void)viewWillAppear:(BOOL)animated

    {

    //    NSArray *array =@[@"1111",@"2222",@"1111"];

    //    [self.enjoyView resetZoneOfEnjoyView:array withIndex:1];

        

        // 2.集成刷新控件

        [self addHeader];

        [self addFooter];

        

    }

    - (void)addHeader

    {

        __unsafe_unretained typeof(self) vc = self;

        

        __block typeof(self)WeakSelf = self;

        // 添加下拉刷新头部控件

        

        NSMutableArray *array = [NSMutableArray array];

        [WeakSelf.enjoyView.collectionView addHeaderWithCallback:^{

            // 进入刷新状态就会回调这个Block

            

            // 增加5条假数据

            for (int i = 0; i<5; i++)

            {

                [WeakSelf.enjoyView.goodsMuArray insertObject:@"0000" atIndex:0];

            }

            

            

           

            

            // 模拟延迟加载数据,因此2秒后才调用)

            dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{

                [vc.enjoyView.collectionView reloadData];

                // 结束刷新

                [vc.enjoyView.collectionView headerEndRefreshing];

            });

        }];

        

    #warning 自动刷新(一进入程序就下拉刷新)

        [self.enjoyView.collectionView headerBeginRefreshing];

    }

    - (void)addFooter

    {

        __unsafe_unretained typeof(self) vc = self;

          __block typeof(self)WeakSelf = self;

        // 添加上拉刷新尾部控件

        [WeakSelf.enjoyView.collectionView addFooterWithCallback:^{

            // 进入刷新状态就会回调这个Block

            

            // 增加5条假数据

            for (int i = 0; i<5; i++) {

                [WeakSelf.enjoyView.goodsMuArray addObject:@"1111"];

            }

    //       [WeakSelf.enjoyView resetZoneOfEnjoyView:[NSArray arrayWithArray:vc.fakeColors] withIndex:0];

            

            // 模拟延迟加载数据,因此2秒后才调用)

            dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{

                [vc.enjoyView.collectionView reloadData];

                // 结束刷新

                [vc.enjoyView.collectionView footerEndRefreshing];

            });

        }];

    }

    /**

     为了保证内部不泄露,在dealloc中释放占用的内存

     */

    - (void)dealloc

    {

        NSLog(@"MJCollectionViewController--dealloc---");

    }

    - (void)didReceiveMemoryWarning {

        [super didReceiveMemoryWarning];

        // Dispose of any resources that can be recreated.

    }

  • 相关阅读:
    Makefile与shell脚本区别
    Linux fdisk命令参数及用法详解---Linux磁盘分区管理命令fdisk
    李洪强iOS开发之XMPP
    李洪强iOS开发之宏定义方法来初始化一个单例对象
    李洪强iOS开发之拓展篇—UIDynamic(简单介绍)
    李洪强iOS开发之【零基础学习iOS开发】【02-C语言】07-基本数据类型
    李洪强iOS开发之OC[018]对象和方法之间的关系
    李洪强漫谈iOS开发[C语言-011]
    李洪强iOS开发之静态库
    李洪强iOS开发之【零基础学习iOS开发】【02-C语言】06-变量与内存
  • 原文地址:https://www.cnblogs.com/huiyi-520/p/7520182.html
Copyright © 2011-2022 走看看